# ACE User Guide (UG070)

Achronix Tool Suite



### Copyrights, Trademarks and Disclaimers

Copyright © 2024 Achronix Semiconductor Corporation. All rights reserved. Achronix, Speedcore, Speedster, and ACE are trademarks of Achronix Semiconductor Corporation in the U.S. and/or other countries All other trademarks are the property of their respective owners. All specifications subject to change without notice.

#### Notice of Disclaimer

The information given in this document is believed to be accurate and reliable. However, Achronix Semiconductor Corporation does not give any representations or warranties as to the completeness or accuracy of such information and shall have no liability for the use of the information contained herein. Achronix Semiconductor Corporation reserves the right to make changes to this document and the information contained herein at any time and without notice. All Achronix trademarks, registered trademarks, disclaimers and patents are listed at http://www.achronix.com/legal.

#### Achronix Semiconductor Corporation

2903 Bunker Hill Lane Santa Clara, CA 95054 USA

Website: www.achronix.com E-mail : info@achronix.com

## **Table of Contents**

| Chapter 1 : Pr | eface                                                   | 1  |
|----------------|---------------------------------------------------------|----|
| Pre            | eface                                                   | .1 |
|                | About This Guide                                        | .1 |
|                | Related Documents                                       | .1 |
|                | Conventions Used in this Guide                          | .2 |
| Chapter 2 : Ge | etting Started                                          | 3  |
| Int            | roduction                                               | 3  |
| AC             | E Quickstart Tutorial                                   | 3  |
|                | 1. Create your Project                                  | .3 |
|                | 2. Add your Design Files and Set Implementation Options | .4 |
|                | 3. Run the Flow                                         | .4 |
|                | 4. Analyze the Results                                  | .5 |
|                | Congratulations!!!                                      | .5 |
| Chapter 3 : Co | oncepts                                                 | 6  |
| We             | orkbench                                                | 6  |
| Pe             | rspectives                                              | 6  |
|                | Projects Perspective                                    | 6  |
|                | Floorplanner Perspective                                | .7 |
|                | IP Configuration Perspective                            | .7 |

| U       | IG  | )7   | 0      |
|---------|-----|------|--------|
| $\circ$ | C C | ,,,, | $\sim$ |

| 2D NoC Performance Perspective                                    |    |
|-------------------------------------------------------------------|----|
| Programming and Debug Perspective                                 |    |
| HW Demo Perspective                                               |    |
| Editors                                                           | 9  |
| HTML Report Browser                                               | 9  |
| Text Editor                                                       | 10 |
| VCD Waveform Editor                                               |    |
| VCD Viewer Preferences                                            |    |
| Views                                                             | 16 |
| Clock Domains View                                                | 21 |
| Organizing Table Data                                             | 23 |
| Drag-and-Drop                                                     | 25 |
| Clock Regions View                                                |    |
| Using the Table to Display Clock Regions in the Floorplanner View |    |
| Organizing Table Data                                             |    |
| Partial Reconfig Cluster Value                                    |    |
| Clusters View                                                     |    |
| Using the Table to Display Clusters in the Floorplanner View      |    |
| Organizing Table Data                                             |    |
| Partial Reconfig Cluster Value                                    |    |
| Critical Path Diagram View                                        |    |
| Fly-Out Palette                                                   |    |
| Critical Paths View                                               |    |
| Download View                                                     |    |
| Floorplanner View                                                 |    |
| Panning and Zooming                                               |    |

| Fly-Out Palette                 |    |
|---------------------------------|----|
| Flow View                       |    |
| HW Demo View                    | 60 |
| I/O Designer Toolkit Views      |    |
| I/O Designer Toolkit Views      | 63 |
| I/O Ring Design File Generation | 63 |
| I/O Utilization View            |    |
| I/O Package Diagram View        | 65 |
| I/O Pin Assignment View         |    |
| I/O Core Pin Assignment View    |    |
| I/O Layout Diagram View         |    |
| IP Diagram View                 | 71 |
| IP Libraries View               | 73 |
| IP Problems View                |    |
| Multiprocess View               |    |
| Execution Queue Management      |    |
| Multiprocess Flow Management    |    |
| Select Implementations          |    |
| Multiprocess Run Logs           |    |
| Netlist Browser View            |    |
| Filtering Displayed Instances   |    |
| Drag-and-Drop                   |    |
| NoC Performance View            |    |
| Loading Simulation Log Files    |    |
| Browsing Time Slices            |    |
| NoC Time Slice View             |    |
| Adjusting View Properties       |    |

|     | Options View                                                          |     |
|-----|-----------------------------------------------------------------------|-----|
|     | Outline View                                                          |     |
|     | Partitions View                                                       | 111 |
|     | Drag-and-Drop                                                         |     |
|     | Partial Reconfig Cluster Value                                        |     |
|     | Placement Regions View                                                |     |
|     | Using the Table to Display Placement Regions in the Floorplanner View |     |
|     | Organizing Table Data                                                 |     |
|     | Partial Reconfig Cluster Value                                        |     |
|     | Projects View                                                         |     |
|     | Properties View                                                       |     |
|     | General Tab                                                           |     |
|     | Parameters Tab                                                        |     |
|     | Pins Tab                                                              |     |
|     | Diagram Tab                                                           |     |
|     | Save Properties                                                       |     |
|     | Register Browser View                                                 |     |
|     | Search View                                                           |     |
|     | Search Results and ACE Selection                                      |     |
|     | Search Highlights                                                     |     |
|     | Selection View                                                        |     |
|     | Snapshot Debugger View                                                | 141 |
|     | Tcl Console View                                                      |     |
| Dia | logs                                                                  | 150 |
|     | Add Signals to Waveform Viewer Dialog                                 |     |
|     | Add Source Files Dialogs                                              |     |
|     | Add IP Configuration Files Dialog                                     |     |
|     |                                                                       |     |

| Add RTL Files Dialog                        |     |
|---------------------------------------------|-----|
| Add Synthesis Constraint Files Dialog       |     |
| Add Place and Route Constraint Files Dialog |     |
| Add Place and Route Netlist Files Dialog    |     |
| Add Simulation Testbench Files Dialog       |     |
| Assign Bussed Signal Names Dialog           | 155 |
| Assign Bussed Values Dialog                 | 157 |
| Method 1                                    |     |
| Method 2                                    |     |
| Configure Clock Pre-Routes Dialog           | 159 |
| Create a New Constraints File Dialog        |     |
| Create a New Flow Step dialog               |     |
| Create a New Text File Dialog               |     |
| Create a SecureShare Zip File Dialog        |     |
| Configuration                               |     |
| ACE Input Files                             |     |
| ACE Output Files                            |     |
| Create Implementation Dialog                | 170 |
| Create Placement Region Dialog              |     |
| Create Project Dialog                       | 174 |
| Generate I/O Ring Design Files Dialog       | 175 |
| Generate IP Design Files Dialog             |     |
| Load Acxdb Dialog                           |     |
| Load Project Dialog                         |     |
| New IP Configuration Dialog                 |     |
| Plot SerDes Diagram Dialog                  |     |
| MATLAB SerDes Eye Plot Y-axis Unit Formula  |     |

| Restore Implementation Dialog                                      |     |
|--------------------------------------------------------------------|-----|
| Save Implementation Dialog                                         |     |
| Save Placement Dialog                                              |     |
| Save Placement Regions Dialog                                      |     |
| Search Filter Builder Dialog                                       |     |
| Toolbars                                                           |     |
| Preferences                                                        |     |
| Configure DCC Connection Preference Page                           |     |
| Configure JTAG Connection Preference Page                          |     |
| Multi-device JTAG Scan Chain (IEEE 1149.1) Example                 |     |
| Critical Path Diagram View Preference Page                         |     |
| Cross Probe Preference Page                                        |     |
| Floorplanner View Colors and Layers Preference Page                |     |
| Floorplanner View Optimizations Preference Page                    | 203 |
| I/O Designer Preference Page                                       | 207 |
| IP Diagram Color and Font Preferences Section                      |     |
| Multiprocess: Configure Custom Job Submission Tool Preference Page |     |
| Netlist Browser Preference Page                                    |     |
| NoC Performance View Preference Page                               | 212 |
| Other Colors and Fonts Preference Page                             |     |
| Placement Regions Preference Page                                  |     |
| Project Management Preference Page                                 | 217 |
| Tcl Console View Preference Page                                   |     |
| Text Editors Preference Page                                       |     |
| Quick Diff Preference Page                                         | 223 |
| Projects                                                           | 224 |

| Project File                       | 224 |
|------------------------------------|-----|
| Source Files                       | 226 |
| RTL Files                          | 228 |
| Synthesis Constraints Files        | 228 |
| Place and Route Constraints Files  | 228 |
| Place and Route Netlist Files      | 229 |
| Simulation Testbench Files         |     |
| Port Mapping Files                 |     |
| Implementations                    | 231 |
| Active Project and Implementation  | 231 |
| Project and Implementation Options | 231 |
| Project Options                    | 232 |
| Implementation Options             | 232 |
| Option Sets                        | 232 |
| Output Files                       | 233 |
| Log Files                          | 233 |
| Flow                               | 235 |
| Flow Steps                         | 235 |
| IP Configuration Steps             |     |
| RTL Simulation Steps               |     |
| Synthesis Steps                    |     |
| Place and Route Steps              |     |
| Design Completion Steps            | 241 |
| FPGA Programming Steps             | 242 |
| Flow Status                        | 243 |
| Flow Mode                          | 243 |

| Reports                                                      |     |
|--------------------------------------------------------------|-----|
| Utilization Report                                           | 244 |
| Pin Assignment Report                                        | 245 |
| Clock Report                                                 | 245 |
| Timing Report                                                | 245 |
| Report Content                                               |     |
| Routing Report                                               | 246 |
| Partitions Report                                            | 246 |
| Power Dissipation Report                                     | 246 |
| Example Power Dissipation Report                             |     |
| Power Calculation Methodology                                |     |
| How to Generate the Power Dissipation Report                 |     |
| How to Generate a Simulation-Driven Power Dissipation Report |     |
| Design Statistics Report                                     | 256 |
| Multiprocess Summary Report                                  | 256 |
| Timing Results Summary Section                               | 257 |
| Runtime Results Summary Section                              |     |
| Implementation Options Report                                | 258 |
| Advanced Concepts                                            |     |
| ACE Verilog Attributes                                       | 259 |
| locked                                                       |     |
| fanout_limit                                                 |     |
| must_keep                                                    |     |
| do_not_rewire                                                |     |
| do_not_clone                                                 |     |
|                                                              |     |

| clock_type                                       | .260  |
|--------------------------------------------------|-------|
| local_clock_type                                 | 261   |
| ace_useioff                                      | 261   |
| ace_virtualize                                   | 261   |
| ace_virtualize_clock_port                        | 261   |
| ace_virtualize_clock_net                         | 261   |
| async_capture                                    | . 262 |
| location                                         | . 262 |
| Clock Regions                                    | .262  |
| Instance States                                  | .262  |
| Filter Properties                                | .264  |
| Timing Across All Temperature Corners            | 266   |
| Temperature Corners and Place and Route          | .266  |
| Temperature Corners and Timing Analysis/Reports: | 267   |
| ECO Commands                                     | 268   |
| ECO Use Cases                                    | .268  |
| Net Legality Definition                          | .268  |
| Disclaimers                                      | .268  |
| ECO Commands                                     | .269  |
| GUI Support                                      | 275   |
| Add Instance Pin Dialog                          | 276   |
| ECO Insert Instance Dialog                       | 276   |
| ECO Insert Net Dialog                            | 278   |
| ECO Rewire Instance Dialog                       | 279   |
| ECO Rewire Net Dialog                            | .280  |
| Fabric Clusters                                  | . 281 |

| U | G   | 07  | 70 |
|---|-----|-----|----|
| ~ | ~ ` | ~ ^ | ~  |

| Chapter 4 : Tasks                                       | 282 |
|---------------------------------------------------------|-----|
| Running ACE                                             | 282 |
| GUI Mode                                                |     |
| Command-line Mode                                       |     |
| Batch Mode                                              | 283 |
| Lab Mode (Reduced Functionality)                        |     |
| ACE Initialization Script (ACE_INIT_SCRIPT)             |     |
| Relative paths                                          |     |
| Example Log Output                                      |     |
| ACE Startup Arguments                                   | 285 |
| Working With Perspectives                               | 286 |
| Switching Between Perspectives                          |     |
| Resetting Perspectives                                  |     |
| Working with Views and Editors                          | 287 |
| Opening Views                                           |     |
| Moving and Docking Views and Editors                    |     |
| Rearranging Tabbed Views and Editors                    |     |
| Detaching Views and Editors                             |     |
| Tiling Editors                                          | 289 |
| Maximizing, Minimizing, and Restoring Views and Editors |     |
| Maximize:                                               |     |
| Minimize:                                               |     |
| Working with Projects and Implementations               | 293 |
| Creating Projects                                       | 293 |
| Saving Projects                                         | 293 |

| Loading Projects                                                     | 294                                                                                              |
|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|
| Loading a Project Using the GUI                                      |                                                                                                  |
| Loading a Project Using Tcl                                          |                                                                                                  |
| Project Locking and Lock Files                                       |                                                                                                  |
| Removing Projects                                                    | 296                                                                                              |
| Opening Project Files in an Editor                                   | 296                                                                                              |
| Adding Source Files                                                  | 296                                                                                              |
| Source File Load Order                                               |                                                                                                  |
| Enabling/Disabling Netlists and Constraint Files for Implementations |                                                                                                  |
| Removing Source Files                                                |                                                                                                  |
| Disabling Constraint Files                                           |                                                                                                  |
| Opening Source Files in an Editor                                    |                                                                                                  |
| Creating Implementations                                             |                                                                                                  |
| Saving Implementations                                               |                                                                                                  |
| Restoring Implementations                                            |                                                                                                  |
| Copying Implementations                                              |                                                                                                  |
| Setting the Active Implementation                                    |                                                                                                  |
| Removing Implementations                                             |                                                                                                  |
| Configuring Project and Implementation Options                       | 303                                                                                              |
| Opening Output Files in an Editor                                    | 303                                                                                              |
| Opening Report Files in an Editor                                    | 303                                                                                              |
| Cleaning Projects                                                    | 303                                                                                              |
| nning the Flow                                                       |                                                                                                  |
| Running the Entire Flow                                              | 305                                                                                              |
| Running a Sub-Flow                                                   |                                                                                                  |
| Run an Individual Flow Step                                          |                                                                                                  |
|                                                                      | Loading a Project Using the GUI<br>Loading a Project Using Tcl<br>Project Locking and Lock Files |

| 1 | 10 | $\sim$ | - | $\sim$ |
|---|----|--------|---|--------|
| L | JG | U      | / | U      |

| Run Remaining Enabled Flow Steps (Resume Flow)                              |     |
|-----------------------------------------------------------------------------|-----|
| Stopping the Flow                                                           | 307 |
| Running Multiple Flows in Parallel                                          |     |
| Finding the Multiprocess View                                               | 307 |
| Configuring the Execution Queues                                            | 307 |
| Configuring the Desired Flow to be Followed by the Selected Implementations |     |
| Selecting the Implementations to be Run in Parallel                         |     |
| Starting Background Execution                                               |     |
| Stopping/Canceling Background Execution                                     |     |
| Viewing the Results                                                         |     |
| Multiprocess Batch Mode                                                     | 317 |
| Detecting Changes to Project Source Files                                   |     |
| Files Open in the ACE Editor Area                                           | 323 |
| Smart Change Detection Using Custom Checksums                               | 323 |
| Saving the Active Implementation                                            | 323 |
| Restoring the Active Implementation                                         | 323 |
| Caching the Project Source File State                                       | 324 |
| Automatic Checking while Running the Flow                                   | 324 |
| Warning Visualization in the Flow View                                      | 324 |
| Pop-up Dialog Warnings                                                      | 325 |
| Managing Pop-up Preferences                                                 | 326 |
| Tcl Command Support                                                         | 329 |
| Custom Flow Steps                                                           |     |
| Using the Tcl Console                                                       | 331 |
| Sending Commands from GUI Actions                                           |     |
| Sending Commands from the Console                                           |     |
| Command Highlighting                                                        | 331 |

| С     | ommand Auto-Completion                                | 331 |
|-------|-------------------------------------------------------|-----|
| С     | ommand Help                                           |     |
| Te    | ext Limit                                             |     |
| CI    | learing the Console                                   | 334 |
| Vi    | iewing the ACE Log File                               | 334 |
| 01    | bject Type Prefixes                                   | 334 |
| Creat | ing an IP Configuration                               | 335 |
| Сі    | reating and Naming an IP Configuration                | 336 |
| Se    | etting the IP Configuration                           | 336 |
|       | Editable Fields                                       |     |
|       | Calculated Fields                                     |     |
|       | IP Editor Navigation                                  |     |
| G     | enerating the IP Design Files                         | 338 |
| A     | dding Configuration Files to a Project                | 338 |
| Viewi | ing the Floorplanner                                  | 338 |
| O     | pening and Closing the Floorplanner's Fly-Out Palette | 338 |
| Zo    | ooming the Floorplanner In and Out                    | 338 |
| FI    | loorplanner Panning                                   | 339 |
| Se    | electing Floorplanner Objects                         | 340 |
| De    | eselecting Floorplanner Objects                       | 340 |
| То    | oggling Floorplanner Mouse Tools                      |     |
| Fi    | iltering the Floorplanner View                        | 341 |
|       | Filtering with Layers                                 |     |
|       | Filtering with Selection                              |     |
| CI    | hoosing Floorplanner Object Tooltips                  |     |
| Vi    | iewing Floorplanner Object Labels                     | 342 |

| UG070 |  |
|-------|--|
|       |  |

| Highlighting Objects in the Floorplanner View                     | 342 |
|-------------------------------------------------------------------|-----|
| Selection vs. Highlighting                                        |     |
| Objects May Be Both Selected and Highlighted Simultaneously       |     |
| Batch Mode Highlighting                                           |     |
| Pre-Placing a Design                                              |     |
| Placing an Object                                                 | 346 |
| Changing Between Fixed and Soft Placement                         |     |
| Fixing placement of soft-placement objects                        |     |
| Un-fixing (softening) placement of fixed-placement objects        |     |
| Group Placement Mode                                              |     |
| Adjusting the Existing Placement of a Group of Selected Instances |     |
| Removing Placement                                                | 350 |
| Saving Pre-Placement Constraints                                  | 350 |
| Using Pre-Placement in the Flow                                   |     |
| Types of Pre-Placement                                            |     |
| Recommended Typical Flow                                          |     |
| Analyzing Critical Paths                                          |     |
| Generating Timing Reports                                         | 352 |
| Highlighting Critical Paths                                       | 353 |
| Selecting Critical Path Objects                                   | 353 |
| Zooming to Critical Paths                                         | 354 |
| Printing Critical Path Details                                    | 354 |
| Using Critical Path Diagrams                                      | 355 |
| Graph Elements                                                    |     |
| Critical Path Diagram Types                                       |     |
| Adding Portions of the Graph to the ACE Selection Set             |     |

| Applying and Checking Properties             | 356 |
|----------------------------------------------|-----|
| Applying Properties                          |     |
| defparam                                     |     |
| RTL Attribute                                |     |
| set_property Tcl Command                     |     |
| Checking Whether Properties Were Applied     |     |
| Configuring External Connections to Hardware | 357 |
| Configuring the DCC Connection               |     |
| Background Info                              |     |
| Installing DCC USB Drivers                   |     |
| Configuring the USB drivers                  |     |
| Configuring ACE                              |     |
| Configuring the JTAG Connection              |     |
| JTAG Programmer Device Connection            |     |
| JTAG Scan Chain                              |     |
| Running the Snapshot Debugger                |     |
| Snapshot Design Flow                         |     |
| Accessing the Snapshot Debugger              |     |
| Open the ACE GUI and Select the Project      |     |
| Open the Snapshot Debugger                   |     |
| Configuring the Trigger Pattern              |     |
| Configuring the Trigger Mode                 |     |
| Configuring Trigger Patterns                 |     |
| Configuring the Monitor Signals              |     |
| Naming Captured Signal Data                  |     |
| Configuring Test Stimulus                    |     |

| UG070 |
|-------|
| 000/0 |

| Setting Stimuli Values Using the Table                                  |  |
|-------------------------------------------------------------------------|--|
| Setting Multiple Stimuli Values as a Bus                                |  |
| Configuring Advanced Options                                            |  |
| Pre-Store                                                               |  |
| Trigger Pattern Match Behavior                                          |  |
| User Clock Frequency                                                    |  |
| Configure Output File Locations                                         |  |
| Collecting Samples of the User Design                                   |  |
| Arming the Snapshot Debugger                                            |  |
| Using the Startup Trigger                                               |  |
| Viewing the Captured VCD Waveform                                       |  |
| Opening a VCD file                                                      |  |
| Viewing the Raw Text Content                                            |  |
| Viewing the Signal Data as Waveforms                                    |  |
| Saving/Loading Snapshot Configurations                                  |  |
| Snapshot in Batch Mode                                                  |  |
| Programming a Device using JTAG in the Download View                    |  |
| Selecting a Bitstream File                                              |  |
| Lab Mode                                                                |  |
| Selecting Bitstream Programming Options                                 |  |
| Downloading the Bitstream to the Target Device                          |  |
| Optimizing a Design                                                     |  |
| Attempting Likely Optimizations Using Option Sets                       |  |
| Selecting the Implementations to be Generated and Run in Parallel       |  |
| Generating Option Set Implementations and Starting Background Execution |  |
| Interpreting/Utilizing the Results                                      |  |
|                                                                         |  |

| LIG070 |  |
|--------|--|
| 000/0  |  |

| Placement Regions and Placement Region Constraints                   |     |
|----------------------------------------------------------------------|-----|
| Placement Region Preferences                                         |     |
| Creating a New Placement Region                                      |     |
| Resizing an Existing Placement Region                                |     |
| Moving an Existing Placement Region                                  |     |
| Assigning Placement Region Constraints                               |     |
| Listing all Objects Constrained to a Placement Region                |     |
| Removing a Placement Region Constraint from an Object                |     |
| Saving Placement Region Definitions and Placement Region Constraints |     |
| Deleting Placement Regions                                           |     |
| Running the HW Demo                                                  | 401 |
| Installing HW Demo Designs                                           |     |
| HW Demo Installation Paths                                           |     |
| Selecting The Target Device And Demo                                 | 402 |
| Loading The Demo JAM File                                            | 402 |
| Displaying Board Status                                              | 403 |
| Control of Running Demonstration Design                              | 403 |
| Using Incremental Compilation (Partitions)                           | 404 |
| Overview of Incremental Compilation and Partitions                   |     |
| Defining Partitions                                                  |     |
| Enabling Incremental Compilation                                     |     |
| Tracking Partition Status                                            |     |
| Forcing an Unchanged Partition to Recompile                          |     |
| Viewing Instances In Partitions                                      |     |
| Related Tcl Commands                                                 |     |
| Incremental Compile Tutorial                                         | 407 |

| Overview                                                            | 407 |
|---------------------------------------------------------------------|-----|
| Tutorial Files                                                      | 407 |
| Single-Process Incremental Compile Tutorial                         | 408 |
| Step 1: Obtaining the Files                                         | 409 |
| Step 2: Set up the Synthesis Project                                | 409 |
| Step 3: Compile the Design in Synplify Pro                          | 414 |
| Step 4: Review Synplify Results                                     | 417 |
| Step 5: Set up the ACE Project                                      | 421 |
| Step 6: Compile the Design in ACE                                   | 424 |
| Step 7: Review ACE Results                                          | 424 |
| Step 8: Change the RTL (rtl_V1)                                     | 430 |
| Step 9: Recompile the Design in Synplify Pro (rtl_V1)               | 430 |
| Step 10: Review Synplify Results (rtl_V1)                           | 430 |
| Step 11: Recompile the Design in ACE (rtl_V1)                       | 432 |
| Step 12: Review ACE Results (rtl_V1)                                | 433 |
| Step 13: Additional Incremental Iterations                          | 436 |
| Step 14: Review ACE Results (rtl_V2)                                | 437 |
| Step 15: Review ACE Results (rtl_V3)                                | 439 |
| Step 16: Review ACE Results (rtl_V4)                                | 441 |
| Multiprocess Incremental Compile Tutorial                           | 443 |
| Step 1: Compile the Design in Synplify Pro or Clear the ACE Project | 443 |
| Step 2: Create Multiprocess Implementations and Run ACE             | 443 |
| Step 3: Select the Implementation with Best Performance             | 445 |
| Step 4: Change the RTL and Recompile the Design in Synplify Pro     | 448 |
| Step 5: Recompile the Multiprocess Implementations in ACE           | 448 |
| Automatic Flop Pushing into I/O Pins                                | 452 |
| Background                                                          | 452 |

| Capabilities                                                | 453 |
|-------------------------------------------------------------|-----|
| ACE Implementation Options                                  |     |
| push_flops_into_pads                                        |     |
| pad_flop_pushing_clock_type                                 |     |
| ACE Attributes                                              | 455 |
| Examples                                                    | 456 |
| Timing Analysis Implications                                |     |
| Working with Virtual I/O                                    | 460 |
| Behavior                                                    |     |
| Implementation Options                                      |     |
| Port Attributes                                             |     |
| Runtime Messages                                            |     |
| Schematic View                                              |     |
| Input Netlist                                               |     |
| Output Netlist Styles                                       |     |
| Accessing Help                                              |     |
| Accessing Context-Sensitive Help                            |     |
| Navigating Help Topics                                      |     |
| Using the Help Window                                       |     |
| Using the Help View                                         |     |
| Searching Help                                              |     |
| Refining the Search Results                                 |     |
| Highlighting Search Terms                                   |     |
| Search Query Syntax                                         |     |
| Using the ACE SecureShare Tool to Create a Support Zip File | 471 |
| Importing and Exporting Preferences                         | 472 |

| Import Preferences                                                          |     |
|-----------------------------------------------------------------------------|-----|
| Export Preferences                                                          |     |
| Plotting SerDes Receiver Diagrams Using JTAG                                |     |
| Plotting a SerDes Diagram for a SerDes Lane                                 | 477 |
| Using Partial Reconfiguration                                               |     |
| Partial Reconfiguration Tutorial                                            | 479 |
| Partial Reconfiguration Flows                                               |     |
| Flow Diagrams                                                               |     |
| Design Details                                                              |     |
| PR Flow 1: Multi-Project PR Flow Using Partition Export/Import              |     |
| PR Flow 2: Multi-Project PR Flow Using Keep Out Regions                     |     |
| Updating ROM, BRAM, or LRAM Memory Initialization Contents in the Bitstream |     |
| Initialized using a mem_init file                                           | 545 |
| Initialized using initd* parameters                                         |     |
| Plugging in Custom IP Generator Tools                                       |     |
| File Location and Directory Organization                                    | 553 |
| Loading User-defined Directory Paths Using Environment Variables            |     |
| IP Generator Plugin Development                                             | 554 |
| Model Definition                                                            |     |
| View Definition                                                             |     |
| Control Definition                                                          |     |
| Opening Synplify in ACE                                                     | 575 |
| ACE-Driven Integrated Synthesis                                             | 576 |
| Synplify-Pro-Driven Integrated Synthesis                                    |     |
| Opening Project from ACE File Menu                                          | 577 |

| Opening Project from ACE Actions Menu |  |
|---------------------------------------|--|
| Chapter 5 : Tcl Command Reference     |  |
| SDC Commands                          |  |
| all_clocks                            |  |
| Description                           |  |
| Example                               |  |
| Also See                              |  |
| all_inputs                            |  |
| Description                           |  |
| Example                               |  |
| Also See                              |  |
| all_outputs                           |  |
| Description                           |  |
| Example                               |  |
| Also See                              |  |
| create_clock                          |  |
| Description                           |  |
| Example                               |  |
| Also See                              |  |
| create_generated_clock                |  |
| Description                           |  |
| Example                               |  |
| Also See                              |  |
| get_cells                             |  |
| Description                           |  |
| Example                               |  |
|                                       |  |

|      | Also See           | 585 |
|------|--------------------|-----|
| get  | _clocks            | 586 |
|      | Description        |     |
|      | Example            |     |
|      | Also See           | 586 |
| get  | _nets              | 587 |
|      | Description        | 587 |
|      | Example            | 587 |
|      | Also See           | 587 |
| get  | _pins              | 587 |
|      | Description        |     |
|      | Example            |     |
|      | Also See           |     |
| get  | _ports             | 588 |
|      | Description        |     |
|      | Example            |     |
|      | Also See           |     |
| set. | _clock_groups      | 589 |
|      | Description        |     |
|      | Example            |     |
|      | Also See           |     |
| set. | _clock_latency     | 591 |
|      | Description        |     |
|      | Example            |     |
|      | Also See           | 592 |
| set. | _clock_uncertainty | 592 |
|      | Description        | 592 |
|      |                    |     |

| Example              |     |
|----------------------|-----|
| Also See             |     |
| set_data_check       |     |
| Description          |     |
| Example              |     |
| Also See             |     |
| set_disable_timing   |     |
| Description          |     |
| Example              |     |
| Also See             |     |
| set_false_path       |     |
| Description          |     |
| Example              |     |
| Also See             |     |
| set_input_delay      |     |
| Description          |     |
| Example              |     |
| Also See             |     |
| set_input_transition |     |
| set_load             |     |
| set_max_delay        |     |
| set_min_delay        |     |
| set_multicycle_path  |     |
| Description          | 601 |
| Example              |     |
| Also See             |     |
| set_output_delay     |     |
|                      |     |

| Description                                                                                                                                                                                            |     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Example                                                                                                                                                                                                |     |
| Also See                                                                                                                                                                                               |     |
| Interactive Timing Commands                                                                                                                                                                            | 603 |
| check_setup                                                                                                                                                                                            |     |
| Example                                                                                                                                                                                                |     |
| prepare_sta                                                                                                                                                                                            |     |
| Example                                                                                                                                                                                                |     |
| report_checks                                                                                                                                                                                          |     |
| report_clock_properties                                                                                                                                                                                |     |
| Example                                                                                                                                                                                                |     |
| reset_sta                                                                                                                                                                                              |     |
| Example                                                                                                                                                                                                |     |
| ACE Tcl Commands                                                                                                                                                                                       | 610 |
|                                                                                                                                                                                                        |     |
| add_clock_preroute                                                                                                                                                                                     |     |
|                                                                                                                                                                                                        |     |
| add_clock_preroute                                                                                                                                                                                     | 610 |
| add_clock_prerouteadd_project_constraints                                                                                                                                                              |     |
| add_clock_preroute<br>add_project_constraints<br>Also See                                                                                                                                              |     |
| add_clock_preroute<br>add_project_constraints<br><i>Also See</i><br>add_project_ip                                                                                                                     |     |
| add_clock_preroute<br>add_project_constraints<br><i>Also See</i><br>add_project_ip<br>add_project_netlist                                                                                              |     |
| add_clock_preroute<br>add_project_constraints<br><i>Also See</i><br>add_project_ip<br>add_project_netlist<br>add_project_source_files                                                                  |     |
| add_clock_preroute<br>add_project_constraints<br><i>Also See</i><br>add_project_ip<br>add_project_netlist<br>add_project_source_files<br>add_region_find_insts                                         |     |
| add_clock_preroute<br>add_project_constraints<br><i>Also See</i><br>add_project_ip<br>add_project_netlist<br>add_project_source_files<br>add_region_find_insts<br>add_region_insts                     |     |
| add_clock_preroute<br>add_project_constraints<br><i>Also See</i><br>add_project_ip<br>add_project_netlist<br>add_project_source_files<br>add_region_find_insts<br>add_region_insts<br>apply_highlights |     |

| clear_arcs                  | 616 |
|-----------------------------|-----|
| clear_drawing               | 616 |
| clear_flow                  | 617 |
| clear_lines                 | 617 |
| clear_ovals                 | 617 |
| clear_polygons              | 617 |
| clear_rectangles            | 617 |
| clear_strings               | 618 |
| clock_info                  | 618 |
| clock_relation              | 619 |
| create_boundary_pins        | 620 |
| create_equivalent_regions   | 620 |
| create_flow_step            |     |
| create_impl                 | 622 |
| create_option_sets          | 622 |
| create_path                 | 623 |
| create_project              | 623 |
| create_region               | 624 |
| deselect                    | 625 |
| disable_flow_step           | 626 |
| disable_project_constraints | 626 |
| disable_project_source_file | 627 |
| display_file                | 627 |
| display_netlist             | 628 |
| display_properties          | 628 |
| draw_arc                    | 628 |

| draw_line                    |     |
|------------------------------|-----|
| draw_oval                    |     |
| draw_polygon                 |     |
| draw_rectangle               | 632 |
| draw_string                  | 633 |
| enable_flow_step             |     |
| enable_project_constraints   |     |
| enable_project_source_file   |     |
| export_all_partitions        |     |
| export_partition             |     |
| filter                       |     |
| find                         |     |
| generate_ioring_design_files |     |
| generate_ip_design_files     |     |
| generate_route_delay_table   |     |
| get_ace_cputime              |     |
| get_ace_current_memory_usage |     |
| get_ace_ext_dir              |     |
| get_ace_ext_lib              |     |
| get_ace_peak_memory_usage    |     |
| get_ace_version              |     |
| get_active_impl              |     |
| Example                      |     |
| Also See                     |     |
| get_active_project           |     |
| get_best_multiprocess_impl   |     |

| get_clock_region_bounds                  | 644   |
|------------------------------------------|-------|
| get_clock_regions                        | 644   |
| get_clock_type                           | 644   |
| get_compatible_ordering_codes            | 644   |
| get_compatible_placements                | . 645 |
| get_current_design                       | . 645 |
| get_current_partname                     | . 645 |
| get_efd_file_path                        | . 645 |
| get_enabled_constraints                  | . 646 |
| get_enabled_source_files                 | . 646 |
| get_fabricdb_path                        | 647   |
| get_file_line                            | 647   |
| get_flow_steps                           | 647   |
| get_impl_names                           | 647   |
| get_impl_option                          | . 648 |
| get_impl_option_is_supported             | . 648 |
| get_impl_option_is_supported_and_enabled | . 649 |
| get_inst_partition                       | . 649 |
| get_inst_region                          | . 650 |
| get_installation_directory               | . 650 |
| get_location                             | . 650 |
| get_noc_children                         | . 650 |
| get_noc_info                             | 651   |
| get_package_names                        | 651   |
| get_part_names                           | 651   |
| get_partition_changed                    | 652   |

| get_partition_force_changed                 | 652 |
|---------------------------------------------|-----|
| get_partition_info                          | 652 |
| get_partition_insts                         | 653 |
| get_partition_names                         | 653 |
| get_partition_timestamp                     | 653 |
| get_partition_type                          | 653 |
| get_path_ids                                | 654 |
| get_path_property                           | 654 |
| get_placement                               | 654 |
| get_project_constraint_files                | 655 |
| get_project_directory                       | 655 |
| get_project_ip_files                        | 655 |
| get_project_names                           | 655 |
| get_project_netlist_files                   |     |
| get_project_option                          |     |
| get_project_option_is_supported             |     |
| get_project_option_is_supported_and_enabled | 657 |
| get_project_output_directory                | 657 |
| get_project_source_files                    | 657 |
| get_properties                              |     |
| get_property                                |     |
| get_pvt_corners                             | 659 |
| get_region_bounds                           | 659 |
| get_region_insts                            |     |
| get_regions                                 |     |
| get_report_sweep_temperature_corners        |     |

| get_selection                |     |
|------------------------------|-----|
| get_synprj_from_netlist      |     |
| get_synprj_from_project      |     |
| get_techlib_name             |     |
| get_techlib_path             |     |
| get_techlibdb_path           |     |
| get_techlibt_name            |     |
| get_techlibt_path            | 663 |
| get_techlibx_name            |     |
| get_techlibx_path            |     |
| get_worst_path               |     |
| has_ace_ext_lib              |     |
| has_partitions               |     |
| highlight                    |     |
| ignore_cancel                |     |
| import_synplify_project_file |     |
| initialize_flow              |     |
| insert_delay                 |     |
| is_impl_option_enabled       |     |
| is_incremental_compile       |     |
| is_labmode                   |     |
| is_project_option_enabled    |     |
| is_timing_met                |     |
| load_flowscripts             |     |
| load_noc_info                |     |
| load_project                 |     |

| message                        |     |
|--------------------------------|-----|
| move_project_constraints       |     |
| move_project_netlists          | 670 |
| move_project_source_file       | 670 |
| move_relative_paths            |     |
| optimize_tile                  |     |
| redirect                       | 672 |
| refresh_drawing                | 672 |
| regenerate_all_ip_design_files | 672 |
| remap_partial_bitstream        | 672 |
| remove_clock_preroute          | 673 |
| remove_flow_step               | 674 |
| remove_impl                    | 674 |
| remove_path                    | 674 |
| remove_project                 | 674 |
| remove_project_constraints     | 675 |
| remove_project_constraints_pvt | 675 |
| remove_project_ip              | 675 |
| remove_project_netlist         | 676 |
| remove_project_source_files    | 676 |
| remove_region                  |     |
| remove_region_insts            |     |
| rename_impl                    | 678 |
| report_clock_regions           | 678 |
| report_clocks                  | 679 |
| report_coverage                | 679 |

| report_design_stats        |  |
|----------------------------|--|
| report_impl_options        |  |
| report_partitions          |  |
| report_performance         |  |
| report_pins                |  |
| report_placement           |  |
| report_power               |  |
| report_project_options     |  |
| report_routing             |  |
| report_utilization         |  |
| reset_impl_option          |  |
| reset_project_option       |  |
| restore_impl               |  |
| restore_project            |  |
| run                        |  |
| run_fanout_control         |  |
| run_final_drc_checks       |  |
| run_fpga_download          |  |
| run_generate_bitstream     |  |
| run_generate_final_reports |  |
| run_generate_fullchip_sim  |  |
| run_generate_netlist       |  |
| run_insert_holdbuffers     |  |
| run_multiprocess           |  |
| run_multiprocess_iterator  |  |
| run_place                  |  |

| set_equivalent_pins                                |     |
|----------------------------------------------------|-----|
| set_flyline_direction                              |     |
| set_impl_option                                    | 712 |
| set_max_flyline_fanout                             | 712 |
| set_partition_force_changed                        | 712 |
| set_partition_info                                 | 713 |
| set_placement                                      | 714 |
| set_project_constraints_pvt                        | 714 |
| set_project_option                                 | 715 |
| set_property                                       | 715 |
| set_region_bounds                                  |     |
| set_region_type                                    | 717 |
| set_units                                          | 717 |
| sleep                                              | 717 |
| source_encrypted                                   | 717 |
| source_secure                                      |     |
| trace_connections                                  |     |
| untar                                              |     |
| write_aeskey_efuse_bitstream                       |     |
| write_bitstream                                    | 720 |
| write_critical_paths_script                        | 721 |
| write_netlist                                      | 721 |
| write_partition_blackbox                           |     |
| write_partition_db                                 |     |
| write_tcl_history                                  |     |
| Tcl Commands for the IP Generator Plugin Framework | 723 |

| add_ip_binary_property    |  |
|---------------------------|--|
| Description               |  |
| Example                   |  |
| add_ip_bool_property      |  |
| Description               |  |
| Example                   |  |
| add_ip_enum_property      |  |
| Description               |  |
| Example                   |  |
| add_ip_file_path_property |  |
| Description               |  |
| Example                   |  |
| add_ip_float_property     |  |
| Description               |  |
| Example                   |  |
| add_ip_gui_control        |  |
| Description               |  |
| Example                   |  |
| add_ip_gui_group          |  |
| Description               |  |
| Example                   |  |
| add_ip_gui_page           |  |
| Description               |  |
| Example                   |  |
| add_ip_hex_property       |  |
| Description               |  |
| Example                   |  |
|                           |  |

| add_ip_include_path         | 731 |
|-----------------------------|-----|
| Description                 |     |
| Example                     |     |
| add_ip_int_property         | 732 |
| Description                 | 733 |
| Example                     | 733 |
| add_ip_label                | 733 |
| Description                 | 733 |
| Example                     | 733 |
| add_ip_output_file          |     |
| Description                 | 734 |
| Example                     | 734 |
| add_ip_output_file_group    |     |
| Description                 | 735 |
| Example                     | 735 |
| add_ip_port                 | 735 |
| Description                 |     |
| Example                     |     |
| add_ip_rule_message         | 736 |
| Description                 |     |
| Example                     |     |
| add_ip_signal_name_property |     |
| Description                 |     |
| Example                     |     |
| add_ip_string_property      | 737 |
| Description                 |     |
| Example                     |     |

| add_ip_to_gui              | 738 |
|----------------------------|-----|
| Description                |     |
| Example                    |     |
| create_ip                  |     |
| Description                |     |
| Example                    |     |
| get_ip_include_paths       |     |
| Description                |     |
| Example                    |     |
| get_ip_macro_name          | 740 |
| Description                |     |
| Example                    |     |
| get_ip_ports               | 740 |
| Description                |     |
| Example                    |     |
| get_ip_property_attributes |     |
| Description                |     |
| Example                    |     |
| get_ip_property_value      |     |
| Description                |     |
| Example                    |     |
| remove_ip_gui_control      |     |
| Description                |     |
| Example                    |     |
| remove_ip_gui_group        |     |
| Description                |     |
| Example                    |     |

| remove_ip_gui_page    |     |
|-----------------------|-----|
| Description           | 745 |
| Example               | 745 |
| remove_ip_label       | 745 |
| Description           |     |
| Example               |     |
| remove_ip_property    |     |
| Description           |     |
| Example               |     |
| send_ip_definitions   |     |
| Description           |     |
| Example               |     |
| send_ip_gui_update    |     |
| Description           |     |
| Example               |     |
| set_ip_category       |     |
| Description           |     |
| Example               |     |
| set_ip_description    |     |
| Description           |     |
| Example               |     |
| set_ip_macro_name     |     |
| Description           |     |
| Example               |     |
| set_ip_property_value |     |
| Description           |     |
| Example               |     |
|                       |     |

| set_ip_property_verilog_param_attributes |     |
|------------------------------------------|-----|
| Description                              |     |
| Example                                  |     |
| set_ip_resource_count                    | 750 |
| Description                              |     |
| Example                                  |     |
| set_ip_resource_types                    | 751 |
| Description                              |     |
| Example                                  |     |
| set_update_ip_configuration_callback     |     |
| Description                              | 752 |
| Example                                  | 752 |
| update_ip_binary_property                |     |
| Description                              |     |
| Example                                  |     |
| update_ip_bool_property                  |     |
| Description                              |     |
| Example                                  |     |
| update_ip_configuration                  | 756 |
| Description                              |     |
| Example                                  |     |
| update_ip_enum_property                  |     |
| Description                              |     |
| Example                                  |     |
| update_ip_file_path_property             | 758 |
| Description                              |     |
| Example                                  |     |

| update_ip_float_property                         | 758 |
|--------------------------------------------------|-----|
| Description                                      |     |
| Example                                          |     |
| update_ip_hex_property                           | 759 |
| Description                                      |     |
| Example                                          |     |
| update_ip_int_property                           | 759 |
| Description                                      |     |
| Example                                          |     |
| update_ip_label                                  |     |
| Description                                      |     |
| Example                                          |     |
| update_ip_signal_name_property                   |     |
| Description                                      |     |
| Example                                          |     |
| update_ip_string_property                        |     |
| Description                                      |     |
| Example                                          |     |
| Chapter 6 : Troubleshooting                      | 762 |
| ACE Exit Error Codes                             |     |
| Duplicate Names for Arrays                       |     |
| Clock Definitions/Constraints                    |     |
| Asynchronous Reset of I/O from the Core          |     |
| Multi-process Functionality License Requirements |     |
| Non-ASCII Characters in Path                     |     |

| Unable to Load Project: Project is Locked765                                                                                        |
|-------------------------------------------------------------------------------------------------------------------------------------|
| Changing ACE Font Sizes766                                                                                                          |
| Fonts in Views                                                                                                                      |
| Linux:                                                                                                                              |
| Windows:                                                                                                                            |
| Fonts in HTML Reports76                                                                                                             |
| Unable to Initialize Reserved Module Name List76                                                                                    |
| Startup Error — ACE is Unable to Connect on Port NNNN of Localhost                                                                  |
| To Determine the Root Cause769                                                                                                      |
| If it is a Firewall Problem                                                                                                         |
| If it is a Licensing Problem770                                                                                                     |
| If it is a Filesystem or Network Performance Problem77                                                                              |
| Unexpected ACE GUI problem: java.lang.NoClassDefFoundError: com/achronix/api/<br>APIPlugin                                          |
| If the problem persists after -clean, or if the command prompt is unfamiliar                                                        |
| Detailed instructions:77.                                                                                                           |
| Multiprocess Summary Report Shows "No Timing Results Found" for Successfully<br>Run Implementations with Existing Timing Reports773 |
| Windows: ACE Incorrectly Reports Read/Write File Permission Problems                                                                |
| Windows: ACE GUI Shown as "Not Responding"773                                                                                       |
| Windows: Garbage sometimes appears in the Floorplanner View during panning operations (and remains after panning is completed)      |
| Windows: ACE Startup Error Due to Missing DLL Component in Windows 10774                                                            |
| Windows: The icons and buttons in ACE are too small775                                                                              |
| Asking Windows to upscale images and fonts for all applications                                                                     |

| As     | sking just ACE to upscale images and fonts                                                                                                                             | 775 |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
|        | Asking Windows to alter the scaling settings for just ACE (which may make text and fonts blurn blocky)                                                                 |     |
|        | Enabling ACE's application framework's fractional scaling (fonts remain crisp, but icons may become blurry and ACE may experience instability with some video drivers) | 777 |
|        | Resource Limits: ACE Reports an OutOfMemory Error, But There is Plent<br>Memory Available                                                                              | -   |
|        | : In the TWM Window Manager, the First Time the ACE GUI is Started Afte<br>lation, the ACE Window is So Small Users Might Not See it                                   |     |
|        | : Odd Behavior When Using X DISPLAY Forwarding if the X Client and X Se<br>lore than One Major Revision Apart                                                          |     |
| Linux: | ACE Menus Do Not Show Icons Next to the Action Names                                                                                                                   | 779 |
| Linux: | ACE Ignores LD_LIBRARY_PATH                                                                                                                                            | 779 |
|        | ACE forces the use of the GDK X11 rendering engine even while running<br>Wayland                                                                                       | 779 |
| Linux: | Incompatible Default Web Browser                                                                                                                                       | 780 |
| So     | olution                                                                                                                                                                | 781 |
|        | Details                                                                                                                                                                | 781 |
| Ad     | ditional Information                                                                                                                                                   | 782 |
|        | RHEL/CentOS7                                                                                                                                                           | 782 |
|        | RHEL8                                                                                                                                                                  | 783 |
|        | WebKit and WebKitGTK Technical Details                                                                                                                                 | 783 |
|        | Other Linux Distros                                                                                                                                                    | 783 |
|        | ACE Requires an Unusually Large Amount of Virtual Memory (Due to<br>(it2)                                                                                              | 784 |
| Linux: | ACE forces the use of the Adwaita GTK+3 Theme; Can I Change This?                                                                                                      | 784 |
| Th     | nemes                                                                                                                                                                  | 784 |
|        | Changing the GTK+3 Theme                                                                                                                                               | 785 |

| Animations and Other Effects786                                                                                       |
|-----------------------------------------------------------------------------------------------------------------------|
| Linux: Views and Editors Detach when Dragged Instead of Docking in the<br>Workbench786                                |
| Linux: CDE: Dialogs and Wizards Sometimes Appear Behind the Main ACE Window,<br>Especially After Minimize/Maximize787 |
| Linux: "Failed to create the part's controls": Some Views and IP Editors may fail to initialize                       |
| Upgrading an ACE Installation788                                                                                      |
| On Windows788                                                                                                         |
| On Linux                                                                                                              |
| GUI Problems after Upgrading?789                                                                                      |
| Chapter 7 : Revision History for ACE790                                                                               |
| Revision History790                                                                                                   |

# Chapter 1: Preface

# Preface

### About This Guide

This guide is a reference manual for ACE, used for placing, routing, configuring, and debugging Achronix FPGAs. ACE works in conjunction with third-party synthesis and simulation tools to provide a complete design environment for Achronix FPGAs.

This guide consists of the following chapters:

- Getting Started (page 3) includes an Introduction to ACE and a quick Tutorial.
- **Concepts** (page 6) covers all the basic concepts of ACE, and can be considered a reference manual for the various GUI elements.
- Tasks (page 282) details how to complete various tasks within the GUI, plus provides the related TCL commands.
- TCL Command Reference (page 580) provides a complete TCL command reference, including syntax.
- Troubleshooting (page 762) shows a number of common problems and the recommended solutions.
- Revision History (page 790) lists the changes to each revision of this document

### **Related Documents**

The following documents, as well as the latest version of this document (UG070), are always available for download at https://www.achronix.com/support/docs.

- ACE Installation and Licensing Guide (UG002)
- JTAG Configuration User Guide (UG004)
- Snapshot User Guide (UG016)
- Synthesis User Guide (UG018)

The following supplemental document, typically included in the software release download files, should also be consulted for the very latest information:

• ACE (version) Release Notes

Further documents are available for each Speedster device on both https://www.achronix.com/support/docs and https://download.achronix.com (login required).

Also see the Getting Started section on https://support.achronix.com.

Please consult your Achronix FAE for a complete list of documentation relevant to your Achronix products.

UG070

# Conventions Used in this Guide

| ltem                                                           | Format                                                                  | Examples                                                                                      |
|----------------------------------------------------------------|-------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|
|                                                                |                                                                         | \$ Open<br>top_level_name.log                                                                 |
| Command-line entries                                           | Formatted with a bold fixed-width font, or in a special code block.     | Command-line code<br>example                                                                  |
|                                                                |                                                                         | \$ Open<br>top_level_name.log                                                                 |
| File names                                                     | Formatted with a fixed-width font.                                      | filename.ext                                                                                  |
| GUI buttons, menus, menu or list<br>choices, and radio buttons | Formatted with a variable-width bold font.                              | Select <b>File</b> → <b>Open</b> , select the desired file, then click <b>OK</b> to continue. |
| Variables                                                      | Formatted with italic emphasis and enclosed by the angle brackets "<>". | <design_dir> /output.log</design_dir>                                                         |
| RTL Names                                                      | Formatted with italic emphasis.                                         | read_clk                                                                                      |
| Window and dialog box headings and sub-headings                | Heading formatted in quotation marks.                                   | Under "Output Files", select                                                                  |
| Window and dialog box names                                    | Name uses initial caps.                                                 | From the Add Files dialog box,                                                                |

# Chapter 2 : Getting Started

# Introduction

The Achronix implementation flow is an end-to-end solution which provides an intuitive user interface, batch mode support, advanced debug capabilities, and a simple push-button set of high-level flow steps:

- IP Configuration and Generation
- · Simulation (uses standard 3rd party simulator tools)
- Synthesis (uses the industry standard Synopsys Synplify Pro)
- Placement
- Routing
- Timing Analysis
- Bitstream Generation
- FPGA Configuration
- On-chip Debugging

# ACE Quickstart Tutorial

Start by copying all the files from <ace\_install\_dir>/examples/quickstart/<device> into a new empty directory (<test\_dir>) in your file system. Use the <device> directory that matches the **Target Device** implementation option that you select in step 2. Before launching ACE, make sure you have also installed Synplify Pro and your Simulation tools, and configured the environment variables (such as \$ACX\_SYNPLIFY\_TOOL\_PATH and \$ACX\_<sim\_tool>\_TOOL\_PATH) by following the instructions in the ACE Installation and Licensing Guide (UG002), or Getting Started User Guide.

Now click the ( $^{\textcircled{P}}$ ) minimize icon in the upper right corner of the Welcome view to minimize these instructions. Follow these simple steps to complete your first design in ACE:

### 1. Create your Project

In the Projects View (page 120), click the ( 🎬 ) Create Project toolbar button. Follow these steps to create the project:

- 1. In the Create Project Dialog (page 174), enter (or browse to) the path to < test\_dir> in the Project Directory field.
- 2. Enter quickstart in the Project Name field and click OK.

You should now see your new project show up in the Projects view. See Creating Projects (page 293) or Working with Projects and Implementations (page 293) for more details.

# 2. Add your Design Files and Set Implementation Options

In the Projects view, click the "quickstart" project to select it. Follow these steps to add the design source files for Simulation, Synthesis, and Place and Route:

- 1. Click the ( 🖹 ) Add Source Files toolbar button and select Add RTL Files.
- 2. In the Add RTL Files dialog, browse to the <*test\_dir*>/src/rtl directory and select all of the files by holding down the **CTRL** key and clicking each file name.
- 3. Click the **Open** button to add the RTL files to your project.
- 4. Click the ( 🖹 ) Add Source Files toolbar button and select Add Synthesis Constraint Files.
- 5. In the Add Synthesis Constraint Files dialog, browse to the <*test\_dir*>/src/constraints directory and click the quickstart.sdc file to select it.
- 6. Click the **Open** button to add the Synthesis Constraint files to your project.
- 7. Click the ( 🖹 ) Add Source Files toolbar button and select Add Place and Route Constraint Files.
- 8. In the Add Place and Route Constraint Files dialog, browse to the < test\_dir>/src/constraints directory and select all of the files by holding down the **CTRL** key and clicking each file name.
- 9. Click the **Open** button to add the place and route constraint files to your project.
- 10. Click the ( 🖹 ) Add Source Files toolbar button and select Add Simulation Testbench Files.
- 11. In the Add Simulation Testbench Files dialog, browse to the <*test\_dir*>/src/tb directory and select all of the files by holding down the **CTRL** key and clicking each file name.
- 12. Click the **Open** button to add the simulation testbench files to your project.

In the Options View, follow these steps to configure your project options:

- 1. Expand the **Project Options** section and select the **Target Device** that matches the set of design files that you copied earlier.
- 2. In the **Project Options** section, scroll down and enter the following semicolon-separated list for the **HDL Include Path**:

<test\_dir>/src/rtl;<test\_dir>/src/tb

Note: The HDL Include Path applies to both Synthesis and Simulation.

- 3. Scroll down and expand the **Simulation** section of options.
- 4. Select the **Simulation Tool** you have installed from the drop-down list and enter tb\_quickstart for the **Testbench Top Module**.

You now have a project that is ready to run through the flow! See Adding Source Files (page 296) or Working with Projects and Implementations (page 293) for more details.

### 3. Run the Flow

- 1. In the Flow view, expand the tree to view the detailed flow steps.
- 2. Under RTL Simulation, click the checkbox next to Run RTL Simulation.
- 3. Click the ( 🍉 ) **Run Flow** toolbar button.

Textual output from the flow is shown in the Tcl Console view. When the flow is finished running, you can see the

completed flow steps in the Flow view updated with a green check mark ( $\checkmark$ ) to indicate success, and all newly generated reports are displayed in the editor area. See the Flow (page 235) concept or Running the Flow (page 305) for more details.

### 4. Analyze the Results

- 1. On the main toolbar, click the ( 💾 ) Floorplanner Perspective toolbar button.
- 2. Within this perspective, use the **Critical Paths View** (page 39) to analyze critical paths and highlight them in the **Floorplanner View** (page 45). Clicking the ( ) **Zoom To Path** toolbar button in the Critical Paths view, zooms the **Floorplanner View** (page 45) to the path currently selected in the Critical Paths view.
- 3. Use the Search View (page 133) and Selection View (page 137) to locate objects of interest.

Clicking the ( ) **Zoom To Selection** toolbar button in the Selection view zooms the Floorplanner view to the objects in the current selection set. See the Viewing the Floorplanner (page 338) and Analyzing Critical Paths (page 352) tasks in the User Guide for more details.

### Congratulations!!!

You have successfully completed a design in ACE!

# Chapter 3 : Concepts

# Workbench

The term "workbench" refers to the desktop development environment within ACE. The workbench aims to achieve seamless tool integration by providing a common platform for the creation, management, and navigation of project resources.

Each workbench window contains one or more **perspectives** (page 6). Perspectives contain **views** (page 16) and **editors** (page 9) and control what appears in certain menus and tool bars. More than one workbench window can exist on the desktop at any given time.

### Perspectives

There are many different kinds of information that must be viewed within ACE. Perspectives are used to filter the information into usable, logically consistent groupings. A perspective provides a set of functionality aimed at accomplishing a specific type of task or works with specific types of resources. A perspective defines the initial set and layout of views (page 16), editors (page 9), menus, and toolbars in the Workbench (page 6) window.

For example, the Projects perspective combines views (page 16) commonly used while managing project source files, while the Floorplanner perspective contains the views that are used while viewing chip layout and floorplanning information. Perspectives are frequently switched while working inside the Workbench (page 6).

#### (i) Note

Within the **Workbench** (page 6) window, all perspectives share the same set of **editors** (page 9). All editors are usable/visible from all perspectives. Likewise, each of the **views** (page 16) may optionally be used within any perspective, but they are most useful when grouped with the other views from their native perspective. One of the views, the **Tcl console view** (page 146), is a member of all the perspectives.

### **Projects Perspective**

The ( <sup>E</sup>) Projects perspective allows selecting an active project and implementation, managing the contents and configuration of the active project/implementation, running the flow (page 235), and viewing the reports generated by the flow.

By default, this perspective contains the **Projects view** (page 120), **Flow view** (page 55), **Options view** (page 100), **Tcl console view** (page 146), and the editor area, which can contain any ACE editor or report. The **Multiprocess view** (page 75) is also part of this perspective, but is hidden by default.

For more information, see Working with Projects (page 293), Running the Flow (page 305), and Using the Tcl Console (page 331).

UG070

## **Floorplanner Perspective**

The ( 💾 ) Floorplanner perspective allows viewing and editing the placement and routing of the active project/ implementation.

By default, this perspective contains the following:

- Floorplanner View (page 45)
- Search View (page 133)
- Selection View (page 137)
- Critical Paths View (page 39)
- Critical Path Diagram View (page 34)
- Netlist Browser View (page 81)
- Clock Domains View (page 21)
- Clock Regions View (page 25)
- Placement Regions View (page 114)
- Partitions View (page 111)
- Tcl Console View (page 146)

For more information on using the views in this perspective, see Viewing the Floorplanner (page 338), Pre-Placing a Design (page 345), and Analyzing Critical Paths (page 352).

#### Caution!

Unlike most other perspectives, the Floorplanner perspective hides the editor area. To view editors (page 9) and reports (page 244), a different perspective must be selected.

## **IP** Configuration Perspective

The (P) IP configuration perspective is used to create and edit IP configuration files (.acxip) through the various IP configuration editors.

By default, this perspective contains the following:

- Projects View (page 120)
- IP Libraries View (page 73)
- IP Diagram View (page 71)
- IP Problems View (page 73)
- Outline View (page 110)
- Tcl Console View (page 146)
- I/O Designer Toolkit Views (page 62)

The IP configuration perspective also contains the editor area, which can contain any ACE editor or report.

See Creating an IP Configuration (page 335) for more details.

## 2D NoC Performance Perspective

The (IIII) 2D NoC Performance perspective is used to visualize the throughput or congestion of the 2D NoC network by loading a simulation log file produced by the device simulation model (DSM).

By default, this perspective contains the following:

- NoC Performance View (page 89)
- NoC Time Slice View (page 97)

#### Caution!

Unlike most other perspectives, the 2D NoC performance perspective hides the editor area. To view editors (page 9) and reports (page 244), a different perspective must be selected.

### Programming and Debug Perspective

The (=) Programming and Debug perspective allows interaction with Achronix FPGAs via JTAG through a JTAG pod or embedded JTAG controller device. Downloading the device configuration and debugging is typically performed within this perspective.

By default, this perspective contains the following:

- Snapshot Debugger View (page 141)
- Download View (page 43)
- Register Browser View (page 131)
- Tcl Console View (page 146)

The Programming and Debug perspective also contains the editor area, which can contain any ACE editor or report.

For more information on using this perspective, see Running the Snapshot Debugger (page 363) and Programming a Device using JTAG in the Download View (page 389)

### HW Demo Perspective

The () HW Demo perspective allows observing various aspects of a particular device, by selecting one of the provided demonstration designs from a list. When the demonstration is loaded into the attached board, LED states and DIP switch states (from the board) are displayed and updated in real-time. Internal device state information such as the temperature of the FPGA and power consumption are also displayed.

By default, this perspective contains the following:

- Snapshot Debugger View (page 141)
- HW Demo View (page 60)
- Tcl Console View (page 146)

The HW Demo perspective also contains the editor area, which can contain any ACE editor or report.

For more information on using this perspective, see Running the HW Demo (page 401).

# Editors

Most **perspectives** (page 6) in the **workbench** (page 6) are comprised of an editor area and one or more **views** (page 16). Different editors are associated with different types of files. For example, when a file is opened by double-clicking in the **Projects view** (page 120), the associated editor opens in the Workbench. If there is no associated editor for a resource, the Workbench attempts to launch an external editor outside the Workbench. Any number of editors can be open at once, but only one can be active at a time. The main menu bar and toolbar for the Workbench window contain operations that are applicable to the active editor.

Tabs in the editor area indicate the names of resources that are currently open for editing (usually the filename, and the tab tooltip provides the full path to the file). An asterisk (\*) displayed in an editor tab indicates that an editor has unsaved changes. By default, editors are stacked in the editor area, but may be tiled (page 289) in order to view multiple editors simultaneously. The gray border at the left margin of the editor area may contain icons that flag errors, warnings, or problems detected by the system.

In ACE, the editor area is also used to view the **reports** (page 244) generated by ACE. By default, when ACE is running the **flow** (page 235) in single-process mode, ACE opens HTML versions of the reports in the **HTML report browser** (page 9) as soon as the report data is generated/updated. When ACE is in Multiprocess mode (via the **Multiprocess view** (page 75)), only the **Multiprocess summary report** (page 256) is automatically opened in the editor area — the other reports must be opened manually through the **Projects view** (page 120), or by following the Timing report hyperlinks for each **implementation** (page 231) found within the Multiprocess summary report.

ACE also provides a suite of IP Configuration editors, organized by fabric family/library, used to instantiate and configure the various IP surrounding the core fabric. See **Creating an IP Configuration** (page 335).

#### (i) Note

The IP libraries and IP types displayed within ACE are dynamic and change based on which technology libraries and devices are installed and licensed at each customer site. Therefore, the individual IP configuration editors are not documented in this guide, and are instead documented in separate dedicated Achronix documentation. An example would be the *Speedster7t Soft IP User Guide* (UG103).

### HTML Report Browser

When HTML versions of generated **reports** (page 244) are opened within ACE, they are displayed within the Editor area using the HTML Report browser. This is a very limited form of a web browser — it only allows hyperlink traversal, refresh, forward, and back operations. The buttons for refresh, back, and forward are not displayed within the browser itself, but are instead shown in the main (topmost) ACE button-bar.

#### (i) Note

The HTML Report Browser should not be used to browse the Internet — a dedicated web browser (i.e., Firefox) would be a much better choice, for both security and performance reasons.

| › 🖹 🖪 📽 📲 📮 🌾 🔿 📎              |                                  |                                                             |                                     |              |           |                  |         |           |          |   |
|--------------------------------|----------------------------------|-------------------------------------------------------------|-------------------------------------|--------------|-----------|------------------|---------|-----------|----------|---|
| 🗄 Options 🛛 🔖 Multiprocess 🗖 🗖 | 🗎 Utilizatio                     | on Repor                                                    |                                     | ] Timing Re  | eport - F | L 🛙              | »2      |           |          |   |
| Project: quickstart            |                                  | tical Hold (m<br>ock Frequenc                               |                                     | ng Paths     |           |                  |         |           |          | * |
| Implementation: impl_1         |                                  |                                                             | Cr                                  | itical Setup | (max) T   | iming P          | aths    |           |          |   |
| Design Preparation             |                                  |                                                             | Pa                                  | ith          |           |                  | De      | elay (ns) |          | Ξ |
| Advanced Design Preparation    | Path<br>Id                       | From                                                        | m To Clock / Required Arrival Slack |              |           |                  |         |           |          |   |
| Place and Route                | <u>s0</u>                        | <u>s0</u> ina[3] rega_nand_ret_3 clka 102.523 4.348 +98.175 |                                     |              |           |                  |         |           |          |   |
| Timing Analysis                |                                  |                                                             |                                     |              |           |                  |         |           |          |   |
| Bitstream Generation           | Critical Hold (min) Timing Paths |                                                             |                                     |              |           |                  |         |           |          |   |
| ► FPGA Download                | Path Delay (ns)                  |                                                             |                                     |              |           |                  |         |           |          |   |
|                                | Path<br>Id                       | From                                                        |                                     | То           |           | Clock /<br>Group | Require | d Arriv   | al Slack |   |
|                                | <u>h0</u>                        | regb_nand2                                                  | _ret_1                              | regb_nand    | 3_ret_1   | clka             | 1.382   | 1.656     | +0.274   |   |

Figure 1 • HTML Report Browser, Toolbar Buttons

#### Table 1 · HTML Report Browser Toolbar Buttons

| lcon           | Action  | Description                                                                                                                                                                |
|----------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ¢              | Back    | Returns to the last HTML location viewed.                                                                                                                                  |
| ⇔              | Forward | Returns to the HTML location viewed before the <b>Back</b> button was selected (the <b>Forward</b> button remains disabled until the <b>Back</b> button has been clicked). |
| ŵ <sup>®</sup> | Refresh | Refreshes the displayed HTML report to show the current contents of the report file on disk.                                                                               |

### Text Editor

Reports, source files, and scripts open in the text editor. The text editor supports typical editing functions, such as insert, delete, copy, cut, and paste.

| 📄 quickstart.vma 🛛 📄 quickstart_utiliz р |
|------------------------------------------|
| 1module quickstart (                     |
| 2 clka,                                  |
| 3 clkb,                                  |
| 4 ina,                                   |
| 5 inb1,                                  |
| 6 inb2,                                  |
| 7 z0                                     |
| 8);                                      |
| 9 input clka ;                           |
| 10 input clkb ;                          |
| 11input [3:0] ina ;                      |
| 12 input [3:0] inb1 ;                    |
| 13 input [3:0] inb2 ;                    |
| 14output zO ;                            |
| 15wire clka ;                            |
| 16wire clkb ;                            |
| 17wire zO ;                              |
| 18wire [3:0] ina_c;                      |
| 19wire [3:0] inb1_c;                     |
| 20wire [3:0] inb2_c;                     |
| <                                        |

Figure 2 • Text Editor Example

## VCD Waveform Editor

The VCD waveform editor does not allow editing a VCD file. It only allows viewing. But since it resides in the same location in the GUI as all the other editors (page 9), and it opens whenever a VCD file is selected, it can be thought of as an editor in read-only mode.

The waveform viewer allows examining VCD output in a familiar waveform visualization, displaying how signals change values over time. It is typically used to examine the VCD output that gets generated when running the Snapshot debugger (page 363) (see also: Snapshot Debugger View (page 141), Viewing the Captured VCD Waveform (page 377)).

As with similar waveform editors, the placement of a vertical line marker (pink by default, managed by a user preference) can be manipulated with the mouse in the graphical waveform area so that the value of all signals at the same instant of time can be seen. The value for individual signals at instants in time may be examined through tooltips, available over the waveform area.

Signals can also be re-ordered (individually moved vertically among peers in the table using buttons, or using dragand-drop) and individual signals can be hidden or shown. Buses are collapsed by default (individual bits of the bus are hidden), but may be expanded to show all the bits, or re-collapsed to just the bus as desired. There are also buttons available to expand all buses at once, and collapse all buses at once. If necessary, bit and bus signals (but not the individual bits of a bus) may be duplicated in the display so that they can be displayed adjacent to multiple peers for ease of value comparisons. It is, of course, possible to change the zoom level of the graphical waveform area if desired using buttons or the mouse wheel in the waveform area.

For each VCD file, the editor remembers signal name ordering, zoom level, and the sample offset. These settings are remembered between Snapshot captures within a single session, as well as between ACE sessions. A button is also provided to return the file to defaults for all of these values at any time.

#### Notes

- In addition to the graphical waveform view, the raw text content of the VCD file may be viewed. To do so, select the **File Preview** tab at the bottom-left of the VCD waveform editor. To see the graphical waveform representation again, select the **Waveform** tab, also at the bottom-left of the VCD waveform editor.
- None of the actions available in the VCD waveform editor change the content stored in the VCD file.



#### Figure 3 • VCD Waveform Editor Example

By default, the waveform area uses alternating foreground colors (black and blue by default) and background colors (light grey and white by default) for even and odd rows. When rows are selected in the signal name/value table, the corresponding rows in the waveform are highlighted with a specified selection foreground color (orange by default). Multi-bit bus values are also shown in hexadecimal in the waveform area when they fit in the available space. When the bus value is too wide for the available area, the value is not shown in the waveform bus row, though value edges are still visible. The available area may be made wider by zooming in, thus allowing larger bus values to be displayed (the marker can also be used to display the bus and bit value in the signal table Value column for a chosen point in time).

#### Table 2 · VCD Waveform Editor Options

| Option               | Description                                                                                                               |  |  |  |  |  |  |  |
|----------------------|---------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Signal Value Table   |                                                                                                                           |  |  |  |  |  |  |  |
| Name                 | The name of the signal as stored in the VCD file.                                                                         |  |  |  |  |  |  |  |
| Value                | The value of the signal at the indicated point in time of the marker.                                                     |  |  |  |  |  |  |  |
| Waveform Timing Info |                                                                                                                           |  |  |  |  |  |  |  |
| Left                 | The time in picoseconds (ps) or ticks (tk) indicated by the left edge of the viewable waveform area.                      |  |  |  |  |  |  |  |
| Right                | The time (in ps or tk) indicated by the right edge of the viewable waveform area.                                         |  |  |  |  |  |  |  |
| Marker               | The time (in ps or tk) indicated by the vertical marker line (pink by default) shown in the viewable waveform area.       |  |  |  |  |  |  |  |
| Cursor               | The time (in ps or tk) indicated by the current (or last relevant) mouse cursor position over the viewable waveform area. |  |  |  |  |  |  |  |

#### (i) Note

**Cursor Values** – when the mouse moves away from the waveform area, the last position over the waveform is retained by the **Cursor** value. This (ps or tk) value does not change until the mouse cursor is again over the waveform, even if the view is scrolled or the zoom factor is changed.

lcons are shown to the left of each signal name as an indicator whether the name corresponds to a individual bit signal, a bus, or a bit within a bus.

#### Table 3 • VCD Waveform Editor Icons

| lcon | Description |
|------|-------------|
| -    | Signal.     |
| I    | Bus.        |
| ŀ    | Bus bit.    |

There are a number of buttons available below the signal name/value table area to allow altering which signals/ buses are visible, and where they are displayed in relation to their peers. Signals and buses are allowed to be displayed more than once within the table, if desired.

| Action            | Button | Context<br>Menu | Description                                                                                                                                                                                                                                                                                                   |
|-------------------|--------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Move Up           | γ      |                 | Moves the currently-selected signals (or buses) one row higher in<br>the table and the waveform area. Signals may also be dragged<br>vertically to new locations with the mouse.                                                                                                                              |
| Move Down         | Y      |                 | Moves the currently-selected signals (or buses) one row lower in<br>the table and the waveform area. Signals may also be dragged<br>vertically to new locations with the mouse.                                                                                                                               |
| Add               | Y      |                 | Opens the Add Signals to Waveform Viewer Dialog (page 150), which<br>allows previously removed (hidden) signals to be displayed, and<br>allows already-visible signals to be added to the signal list<br>multiple times. (A signal could be duplicated and shown adjacent<br>to multiple associated signals.) |
| Remove            | Y      | Y               | Hides the currently-selected signal(s) (or bus(es), if any bus or any of its bus bits are selected), temporarily removing it/them from the table and the waveform area. The hidden signal/bus may be shown (added to the table and waveform) again via the <b>Add</b> button.                                 |
| Copy Signal Name  |        | Y               | When a single bus or signal is selected, this right-click context<br>menu choice allows copying the current name of the selected bus<br>or signal (this menu choice is not shown when multiple rows are<br>selected in the table).                                                                            |
| Copy Signal Value |        | Y               | When a single bus or signal is selected, this right-click context<br>menu choice allows copying the current value of the selected bus<br>or signal (this menu choice is not shown when multiple rows are<br>selected in the table).                                                                           |
| Expand Bus        |        | Y               | This option (only visible when a single bus is selected) expands<br>the bus to show all the bits making up the bus. The bus bits are<br>shown below the bus, always in descending index order.                                                                                                                |
| Collapse Bus      |        | Y               | This option (only visible when a single bus or single bus bit is selected) collapses the bus, hiding all the bits making up that bus.                                                                                                                                                                         |

#### Table 4 · Signal Value Table Granular Actions

There are also some supplemental buttons above the signal value table with a few additional actions, each of which impact the entire table contents at once.

#### Table 5 · Signal Value Table Bulk Actions

| lcon | Action             | Description                                                                                                                                                                                                                    |
|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Ŷ    | Reset Signal Table | Resets the signals table content and order to the state when<br>the file is first loaded. This is expected to generally match the<br>order of the monitored bits as found in the *.snapshot file,<br>with all buses collapsed. |
| Œ    | Expand All Buses   | Expands all buses so that all bits are visible.                                                                                                                                                                                |
| E    | Collapse All Buses | Collapses all buses so that zero bits are visible.                                                                                                                                                                             |

There are also a number of buttons that affect the waveform area in particular.

#### Table 6 • Waveform Buttons

| lcon    | Action                       | Description                                                                                                                                                                                                                                                                     |
|---------|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ¢)      | Move Marker to Previous Edge | Moves the vertical pink marker line in the waveform area to the previous edge for the signal/bus which is currently selected in the signal value table (has no effect when no signal is selected in the table).                                                                 |
| ¢       | Move Marker to Next Edge     | Moves the vertical pink marker line in the waveform area to the next edge for<br>the signal/bus which is currently selected in the signal value table (has no<br>effect when no signal is selected in the table).                                                               |
| ۲       | Zoom In                      | Increases the zoom factor in the waveform area, increasing the visible level<br>of detail. This is also possible using the mouse wheel when the mouse cursor<br>is over the waveform area.                                                                                      |
| e,      | Zoom Out                     | Decreases the zoom factor in the waveform area, decreasing the visible level<br>of detail. This is also possible using the mouse wheel when the mouse cursor<br>is over the waveform area.                                                                                      |
| Q       | Zoom to Marker Position      | Without changing the zoom factor, scrolls the waveform area horizontally to make the marker visible.                                                                                                                                                                            |
| or<br>T | Configure Colors             | Opens the Preferences (page 191) dialog, switches to the <b>General</b> $\rightarrow$<br><b>Appearance</b> $\rightarrow$ <b>Colors and Fonts</b> page, and scrolls to the <b>VCD Editor</b> section, allowing the colors and fonts used to be changed within the waveform area. |
|         | Show Ticks/Show Times        | Toggles the Waveform Timing info (left, right, marker, and cursor) between displaying values in ticks (tk) or picoseconds (ps).                                                                                                                                                 |

As is typical, the scrollbars around the waveform area can be used to move the waveform area vertically (to see other signals) or horizontally (to see the same signals at different points in time). In most cases in Linux, scrolling the mouse wheel specifically over the scrollbars also moves the scrollbar in the expected direction, though this function may not be possible with all themes, desktop environments, and/or window managers.

### **VCD Viewer Preferences**

The colors and fonts used within the VCD waveform viewer (and the font used within the Signal Value table) are managed by user-editable preferences. These preferences can easily be viewed and edited by selecting the ( $\ref{thm:selection}$ ) **Configure Colors...** button found to the upper-right of the waveform. These preferences allow selecting alternate waveform viewer color choices (for example, green-on-black colors similar to a more traditional oscilloscope). When fine-tuning colors, remember to use the **Apply** button near the bottom of the Colors and Fonts page in the Preference dialog so that choices can be tested immediately without closing the dialog, allowing immediate visual feedback and continued iteration (in most desktop configurations, the Preferences dialog can be moved and made taller/wider to ensure visibility of all preferences without scrolling).

The following figure shows an example where most of the default colors have been altered in favor of a light-on-dark color configuration.



Figure 4 • VCD Waveform Color and Font Preferences

## Views

Views support editors (page 9) and provide alternative presentations as well as ways to navigate the information in the workbench (page 6). For example, the Projects view (page 120) displays projects (page 224), implementations (page 231), and their related file-based resources.

All views have their own context menu showing ways to alter the location or presentation of the view. Simply rightclick the view tab to display the menu.

| 🍃 Netlist Browser | 1                    |          |     |    |    |   |  |  |
|-------------------|----------------------|----------|-----|----|----|---|--|--|
|                   | Close                |          |     |    |    |   |  |  |
| 2                 | Close <u>O</u> thers |          |     |    |    |   |  |  |
| Instance Na       | Clos                 | Do       | Со  |    |    |   |  |  |
| ✔and_b1           | Clos                 | e All    |     |    | a  | ~ |  |  |
| 🔒 CLKIPIN_clka    | 0.00                 | <u> </u> |     | CI | ka | ~ |  |  |
| √vina_int[0]      |                      |          | DFF | cl | ka | ~ |  |  |

Figure 5 • Example of View Right-Click Context Menu

Some views have their own toolbars. The actions represented by buttons on view toolbars only affect the items within that view.

Some views also have their own menus to affect the content of the view. These menus often contain the same actions as in the toolbar, potentially an additional link to the relevant page(s) in the preferences (page 191) which are specific to this view, as well as additional actions/toggles specific to the view which are used less frequently. When

such a menu is available, a ( 🕴 ) vertical ellipsis button appears at the far right of the view toolbar. To open the menu for a view, click the ellipsis button.

| 🕆 Netlist Browser ×   |     | Ŧ  |                | 2 -                   | F 13 💉 🥖       | 1           | 8 |   |
|-----------------------|-----|----|----------------|-----------------------|----------------|-------------|---|---|
| Instance Name         | Hig | Ce | (+             | Exp                   | and All Brand  | hes         |   |   |
| Y                     |     |    | E              | Coll                  | apse All Bran  | ches        |   |   |
| 🗉 🌐 internal_counter1 |     |    | 7¢             | Tog                   | gle Filter Rov | v Visibilit | у |   |
| 🗉 🌐 internal_counter2 |     |    | 72             | Sho                   | w Boundary I   | Pins        |   |   |
| 🗉 🌐 led_counter       |     |    | ~              | Sho                   | w Constants    |             |   |   |
| ✓ cnt1_countf_reg1    |     |    | ~              | Sho                   | w Duplicates   | /Clones     |   |   |
| ✓ cnt1_countf_reg2    |     |    | $\checkmark$   | Show Feedthrough LUTs |                |             |   |   |
| ✓ cnt2_countf_reg1    |     |    | ÷              | Sho                   | w Power and    | Grounds     |   |   |
| ✓ cnt2_countf_reg2    |     |    | <mark>م</mark> | Con                   | figure view    |             |   |   |
| ✓ pulse1              |     | l  | UT6            |                       | clk            | ~           |   |   |
| ✓ pulse1_reg1         |     |    | DFF            |                       | clk            | ~           |   |   |
| ✓ pulse1_reg2         |     |    | DFF            |                       | clk            | ~           |   |   |
| ✓ pulse2              |     | l  | LUT6           |                       | clk            | ~           |   | - |
| ✓ pulse2_reg1         |     |    | DFF            |                       | clk            | ~           |   |   |
| √ pulse2 rea2         |     |    | DFF            |                       | clk            | ~           |   | ~ |

Figure 6 • Example of View Toolbar Including Opened View Menu

Any view can be minimized by clicking the minimize button ( $\Box$ ), removing the view from the ACE application window and replacing the view with a pair of small icons along one of the edges of the application window.

Similarly, any view can be maximized to fill the entirety of the ACE application window by clicking the maximize button ( 🗖 ) found on the upper right of each view's tool bar. A view can be toggled between its maximized and

2

cmd>

| n        | 🗏 Tcl Console × |
|----------|-----------------|
| MINIMIZE |                 |
| MAXIMIZE |                 |
|          |                 |
|          |                 |
|          |                 |
|          |                 |
|          |                 |
|          |                 |
|          |                 |

restored positions by double-clicking on the view's tab. Double-click the tab to maximize the view, double-click again to restore the view.

#### Figure 7 • View Minimize and Maximize Buttons

A minimized or maximized view can be returned to its original docked location with the ACE application window by clicking the restore button ( 🗗 ).

| 🗏 Tcl Console × |        | ₽<br>† |
|-----------------|--------|--------|
|                 |        |        |
|                 | RESTOR | ١E     |
|                 |        |        |
|                 |        |        |
|                 |        |        |
|                 |        |        |
|                 |        |        |
|                 |        |        |
| cmd>            |        | 1      |
|                 | L      | -      |



A minimized view can be shown as a "fast view" by clicking the button with the view's icon on the edge of the ACE application window. A fast view shows the view as a resizable, fully interactive view that attaches to one edge of the ACE application window. The difference between a fast and a standard docked view is that as soon as the focus leaves a fast view (usually because the user has clicked inside of a different view), the fast view automatically minimizes itself again. This behavior allows fast access to infrequently used views while allowing those views to take up no screen real estate. Which edge of the application window a fast view is attached to can be changed by dragging the small dots visible near the minimized view's icon and restore buttons.



Figure 9 • Fast View Key

If a view that has been minimized is not visible, use **Show View** on the main application menu bar to make the view visible as a fast view, or use **Show View | Other...** on the main application menu bar to return the view to its original docked location with the ACE application window.

Views are grouped by shared context into perspectives (page 6). Within a perspective, a view might appear by itself, or stacked with other views in a tabbed notebook. The layout of a perspective can be changed by opening and closing views and by moving/docking them in different positions in the Workbench (page 6) window. See Working with Views and Editors (page 287) for more information.

The views contained by the Project perspective are:

- Projects View (page 120)
- Flow View (page 55)
- Options View (page 100)
- Multiprocess View (page 75)
- Tcl Console View (page 146)

The views within the Floorplanner perspective are:

- Search View (page 133)
- Selection View (page 137)
- Critical Paths View (page 39)
- Critical Path Diagram View (page 34)
- Floorplanner View (page 45)
- Clock Regions View (page 25)
- Clock Domains View (page 21)
- Clusters View (page 30)
- Placement Regions View (page 114)
- Partitions View (page 111)
- Netlist Browser View (page 81)
- Properties View (page 127)
- Tcl Console View (page 146)

The views contained within the IP Configuration perspective are as follows, with the subset specific to Speedster7t FPGAs (with I/O rings) also summarized at I/O Designer Toolkit Views (page 62):

- Projects View (page 120)
- Outline View (page 110)
- IP Libraries View (page 73)
- IP Diagram View (page 71)
- IP Problems View (page 73)
- I/O Utilization View (page 64)
- I/O Package Diagram View (page 65)
- I/O Pin Assignment View (page 66)
- I/O Core Pin Assignment View (page 66)
- I/O Layout Diagram View (page 68)
- Tcl Console View (page 146)

The views contained within the 2D NoC perspective are:

- NoC Performance View (page 89)
- NoC Time Slice View (page 97)

The views of the Programming and Debug perspective are:

- Snapshot Debugger View (page 141)
- Download View (page 43)
- Register Browser View (page 131)
- Tcl Console View (page 146)

The views of the HW Demo perspective are:

- HW Demo View (page 60)
- Snapshot Debugger View (page 141)
- Tcl Console View (page 146)

Finally, for ease of reference, a combined summary list of all available ACE views from all perspectives, sorted in alphabetical order:

- Clock Domains View (page 21)
- Clock Regions View (page 25)
- Clusters View (page 30)
- Critical Path Diagram View (page 34)
- Critical Paths View (page 39)
- Download View (page 43)
- Floorplanner View (page 45)
- Flow View (page 55)
- HW Demo View (page 60)
- I/O Designer Toolkit Views (page 62)

- I/O Core Pin Assignment View (page 66)
- I/O Layout Diagram View (page 68)
- I/O Package Diagram View (page 65)
- I/O Pin Assignment View (page 66)
- I/O Utilization View (page 64)
- IP Diagram View (page 71)
- IP Libraries View (page 73)
- IP Problems View (page 73)
- Multiprocess View (page 75)
- Netlist Browser View (page 81)
- NoC Performance View (page 89)
- NoC Time Slice View (page 97)
- Options View (page 100)
- Outline View (page 110)
- Partitions View (page 111)
- Placement Regions View (page 114)
- Projects View (page 120)
- Properties View (page 127)
- Register Browser View (page 131)
- Search View (page 133)
- Selection View (page 137)
- Snapshot Debugger View (page 141)
- Tcl Console View (page 146)

### **Clock Domains View**

The Clock Domains view provides a table listing all the clock domains found in the active design. Counts are also provided of the major logic types within each clock domain. Similar to the **Netlist Browser view** (page 81), filters are available for each column of the table, so that in cases where there are many clock domains in a design, the visible content of the table may be limited to just those clock domains meeting the chosen filter criteria. Filters are available for all columns of the table except the Highlight Color column.

By default, the Clock Domains view is included in the Floorplanner perspective (page 6). To add it to other perspectives, select **Window**  $\rightarrow$  **Show View...**  $\rightarrow$  **Other...**  $\rightarrow$  **Achronix**  $\rightarrow$  **Clock Domains**.

| 🍃 Netlist Browser 🔯 Clock Domains 🛛 |     |        |        | 12   | M 🍠 🛙 | ]   🔍  | A 🕂   | ~ - 8  |
|-------------------------------------|-----|--------|--------|------|-------|--------|-------|--------|
| Clock Domain Name                   | Hig | Flops  | LUTs   | ALUs | BRAMs | BMACCs | LRAMs | Others |
| Y                                   |     | Y      | Y      | Y    | Y     | Y      | Y     | Y      |
| 🔯 = const                           |     | 49     | 2726   | 9806 | 224   | 56     | 2870  | 40472  |
| 🔯 gclk                              |     | 265274 | 534304 | 9946 | 224   | 56     | 2870  | 54044  |
|                                     |     |        |        |      |       |        |       |        |
|                                     |     |        |        |      |       |        |       |        |

#### Figure 10 · Clock Domains View Example With Filter Row Visible

#### (i) Note

The various Achronix target devices contain different mixes of the possible resource types. Accordingly, the resource type columns in this view (e.g., flops, BRAMs, ALUs, etc.) are dynamic, and change to match the target device after the Prepare flow step has been run. The screenshots and example descriptions in this document section might not exactly reflect the current target device.

#### Table 7 • Clock Domains View Columns

| Column Name       | Description                                                                                                                                                                                                                                                                    |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Clock Domain Name | The name of the clock domain in the active design.                                                                                                                                                                                                                             |
| Highlight Color   | If all instances within the clock domain have the same highlight color, this<br>row shows a color square with that same highlight color. If even one<br>contained instance has a differing highlight color, or no highlight at all, then<br>the row displays no color square.  |
| Resource          | A different column is provided for each <i><resource></resource></i> type (Flops, LUTs, etc.) within the target device. Each table cell in that column shows the sum count of all contained <i><resource></resource></i> instances within the named clock domain for that row. |

A number of actions are available in the view via buttons at the top of the view and context menus (right-click) on the rows of the table.

#### Table 8 · Clock Domains View Actions

| lcon | Action                        | Toolbar Button | Context Menu | Description                                                                                                                      |
|------|-------------------------------|----------------|--------------|----------------------------------------------------------------------------------------------------------------------------------|
| ٠    | Add Instances to<br>Selection | Y              | Y            | Adds the instances within the clock<br>domain to the ACE selection set (as<br>shown in the <b>Selection view</b> (page<br>137)). |

| lcon     | Action                                         | Toolbar Button       | Context Menu | Description                                                                                                                                                                        |  |
|----------|------------------------------------------------|----------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|          | Choose Highlight Color                         | se Highlight Color Y |              | Determines which color is applied to<br>the objects chosen the next time<br>the Highlight action is selected for<br>this view.                                                     |  |
| <u>_</u> | Highlight                                      | Y                    | Y            | Applies the currently active<br>Highlight color to the instances<br>within the chosen clock domain (se<br>Highlighting Objects in the<br>Floorplanner View (page 342)).            |  |
| ×        | Un-Highlight                                   | Y                    | Y            | Clears the Highlight for the<br>instances within the chosen clock<br>domain.                                                                                                       |  |
| Q        | Zoom To                                        | Y                    | Y            | Zooms the Floorplanner view (page<br>45) to an area containing all of the<br>instances within the clock domain<br>currently chosen in the tree.                                    |  |
| ß        | Search for Instances                           | Y                    | Y            | Searches for instances belonging to<br>the chosen clock domain. A Tcl<br>find (page 638)<br>command is issued, and<br>the Search view (page 133) is<br>populated with the results. |  |
| 1        | Toggle Filter Row<br>Visibility <sup>(1)</sup> | Y                    |              | Shows or hides the filter row (of filter icons).                                                                                                                                   |  |

#### **Table Notes**

1. Toggle Filter Row Visibility does not alter whether filters are active, it only shows or hides the icons.

### **Organizing Table Data**

The following are ways to alter the presentation of the data in the Clock Domains table:

#### **Column Resizing**

The width of a column can be changed as follows:

- 1. place the mouse cursor over the boundary between columns (the mouse cursor changes to indicate resizing is possible).
- 2. Simply left-click and drag left or right to resize the column to the desired width, then release the mouse button.

#### **Column Reordering**

The order of the columns in the table can be changed as follows:

- 1. Left-click and hold any column name.
- 2. Drag left or right to move the column between any other pair of columns.
- 3. Release the left mouse button to insert the column header at the new location.

While dragging, the dragged column header appears alongside the mouse cursor, plus a thick column header separator showing where the column insertion occurs when the mouse is released.

#### Filtering

Most columns of the table may filter the displayed clock domains by value. When filtering by column value, only clock domains with column values matching the filter are retained. Non-matching values are excluded from the table.

- Columns containing text can be filtered by string value. Simple substring text matching (with optional wildcard) is used by default, but Regular Expression matching, also known as RegEx (see https://en.wikipedia.org/wiki/ Regular\_expression), is also available. The ACE GUI RegEx matching follows Java rules (see https:// docs.oracle.com/en/java/javase/11/docs/api/java.base/java/util/regex/Pattern.html), which are extremely similar to Perl rules.
- Columns with checkmarks can be filtered by boolean value.
- Columns containing numbers can be filtered by numerical value.
- Columns which may not be filtered (i.e., the **Overlay Color** column) lack a filter icon in the filter row.

#### To add a filter to a column:

- 1. The Filter row must first be visible. Select the (1) Toggle Filter Row Visibility action to show the row if necessary.
- 2. Click the ( abla) filter icon for the desired column, which causes a data-appropriate filter dialog to appear.
- 3. Fill in the desired filter values and click Apply to apply the filter to the rows in the table.

All values matching that filter are retained, and all other values are excluded. Additionally, the background color of the filtered column changes to a bright yellow to indicate the filter is active, and the filter icon at the head of the column also changes to the ( $\checkmark$ ) active filter icon.

To edit (or clear) an existing filter:

- 1. Click the ( $\Upsilon$ ) active filter icon, which causes the data-appropriate filter dialog to appear pre-populated with the current column filter setting.
- 2. Change the filter value and click **Apply** to edit the filter.
- 3. Click Cancel to leave the filter unchanged.
- 4. Click **Clear** to remove the filter from the column.

If the filter is cleared, the background color of the column returns to the default background color, and the filter icon also changes to the ( $\Upsilon$ ) inactive version.

### Drag-and-Drop

The Clock Domains view supports a limited set of drag-and-drop interactions with other views in the **Floorplanner perspective** (page 6). The view only acts as a drag-and-drop source. Items dropped on the Clock domains view are ignored.

Any row of the table may be dragged to the Tcl console view (page 146), and when dropped anywhere in the view, the clock domain name (with the appropriate object type prefix) is inserted at the beginning of the Tcl command-line.

Any clock domain in the table may be dragged to the Placement regions view (page 114) or the Floorplanner view (page

45) (when that view has the **Placement Regions Tool** active) to assign placement region constraints (page 398). Dragging a clock domain is the equivalent of dragging all individual instances which are members of that clock domain. Be aware that since placement regions may only encompass the fabric core and boundary region, but not the I/O ring, any dragged I/O instances are not assigned to placement regions.

# **Clock Regions View**

The Clock Regions view provides a tabular representation of the site type content of each of the **Clock regions** (page 262) in the currently selected Target Device, and allows toggling the visibility of the overlay within the **Floorplanner** view (page 45) for each Clock Region. The view table remains empty until the currently active Implementation has been prepared (i.e., the **Run Prepare** flow step has been completed).

By default, the Clock Regions view is included in the Floorplanner perspective (page 6). To add the view to the current perspective, select Window  $\rightarrow$  Show View  $\rightarrow$  Other...  $\rightarrow$  Achronix  $\rightarrow$  Clock Regions.

| E Clock Regions ∞ |                   |    |                  |       |       |       |       |       |       |
|-------------------|-------------------|----|------------------|-------|-------|-------|-------|-------|-------|
| Visibility        | Clock Region Name | Ov | Clock Pre-Routes | LUTs  | Flops | ALUs  | LRAMs | BRAMs | IPINs |
|                   | CLK_REGION_0_0    |    |                  | 43200 | 86400 | 10800 | 160   | 160   | 4892  |
|                   | CLK_REGION_0_1    |    | (clk_p: 2,4)     | 43200 | 86400 | 10800 | 160   | 160   | 1002  |
|                   | CLK_REGION_0_2    |    |                  | 43200 | 86400 | 10800 | 160   | 160   | 1008  |
|                   | CLK_REGION_0_3    |    |                  | 43200 | 86400 | 10800 | 160   | 160   | 1008  |
|                   | CLK_REGION_0_4    |    |                  | 43200 | 86400 | 10800 | 160   | 160   | 1008  |
|                   | CLK_REGION_0_5    |    | (clk_p: 1,3,5,7) | 43200 | 86400 | 10800 | 160   | 160   | 1008  |
|                   | CLK_REGION_0_6    |    | (clk_p: 1,3,5,7) | 43200 | 86400 | 10800 | 160   | 160   | 1008  |
|                   | CLK_REGION_0_7    |    | (clk_p: 1,3,5,7) | 43200 | 86400 | 10800 | 160   | 160   | 4928  |
|                   | CLK_REGION_1_0    |    |                  | 43200 | 86400 | 10800 | 160   | 160   | 4928  |
|                   | CLK_REGION_1_1    |    |                  | 43200 | 86400 | 10800 | 160   | 160   | 1008  |

#### Figure 11 • Clock Regions View Example

#### 👍 Caution!

Resource type columns, such as Flops, BRAMs, ALUs, etc. are dynamic and change to match the target device after running the Prepare flow step. The resource type columns shown in the screenshot are examples only, and do not match all target devices.

| Table 9 | Clock Regions | Table Columns |
|---------|---------------|---------------|
|---------|---------------|---------------|

| Column               | Editabl<br>e | Description                                                                                                                                                                                                                     |
|----------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Visibility           | Y            | When checked, the clock region overlay is painted in the <b>Floorplanner view</b> (page 45), using the translucent color shown in the <b>Overlay Color</b> column.                                                              |
| Name                 |              | The name of this clock region.                                                                                                                                                                                                  |
| Overlay Color        | Y            | The color used to paint the location of the clock region as an overlay in the Floorplanner view. Right-click any row, then choose <b>Change Overlay Color</b> to choose an alternate overlay paint color for that clock region. |
| Clock Pre-<br>Routes |              | If any clock pre-routes exist for a given partition, they are listed here.                                                                                                                                                      |
| Resource             |              | The number of <resource> sites (Flops, LUTs, etc.) contained in this clock region.</resource>                                                                                                                                   |

### Table 10Clock Regions View Actions

| lcon | Action                  | Toolbar<br>Button | Context<br>Menu | View<br>Menu | Description                                                                                                                                                                                                                                                                                                       |
|------|-------------------------|-------------------|-----------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Show / Hide overlay     |                   | Y               |              | Show or Hide the overlay for the<br>chosen clock region in the<br>Floorplanner view.                                                                                                                                                                                                                              |
|      | Change Overlay<br>Color |                   | Y               |              | Allows changing the translucent<br>overlay color which is used to paint<br>the chosen clock region in the<br>Floorplanner view (when the<br>visibility is enabled).                                                                                                                                               |
|      | Reset Overlay Color     |                   | Y               |              | Reset the chosen clock region<br>overlay color, allowing ACE to<br>automatically pick a new color. If<br>the overlay colors of two clock<br>regions are too similar for easy<br>discernment, this action pseudo-<br>randomly picks another color. Each<br>time this action is chosen, another<br>color is picked. |

| lcon | Action                          | Toolbar<br>Button | Context<br>Menu | View<br>Menu | Description                                                                                                                                            |
|------|---------------------------------|-------------------|-----------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Q    | Zoom To                         |                   | Y               |              | Pans and zooms the Floorplanner view to show the location of the selected clock region. <sup>(1)</sup>                                                 |
|      | Reset All Overlay<br>Colors     |                   |                 | Y            | Pseudo-randomly reassigns new overlay colors for all clock regions.                                                                                    |
| ₽.   | Configure Clock<br>Pre-Routes   |                   | Y               |              | Allows adding clock pre-route information for the selected partition(s).                                                                               |
| R    | Show/Hide All Clock<br>Regions  | Υ                 | Y               | Y            | Toggles the visibility checkboxes<br>for all clock domains in the table,<br>causing all to be alternately shown<br>or hidden in the Floorplanner view. |
| 12   | Toggle Filter Row<br>Visibility | Y                 | Y               | Y            | Shows or hides the filter row (of filter icons) at the top of the table.<br>(2)                                                                        |

#### **Table Notes**

- 1. If the clock region visibility column checkbox is disabled, the clock region overlay is not painted and thus is not visible.
- 2. This toggle does not alter whether filters are active, it only shows or hides the row of filter icons.

### Using the Table to Display Clock Regions in the Floorplanner View

Each clock region is automatically given a unique translucent overlay color to represent the clock region when painting the **Floorplanner view** (page 45). By default, no clock region overlays are painted in the Floorplanner view. Clock region overlays must be enabled if they are to be displayed. The overlay color may optionally be altered for each/all clock regions, but these color choices do not persist between ACE sessions.

#### (i) Note

While alternate overlay colors are allowed to be chosen for each clock region, these overlay colors are not saved between sessions. Each time a design is loaded, new overlay colors are automatically chosen for each clock region.

The following are ways to alter the presentation of Clock region data in the Floorplanner view (page 45):

#### Enable/Disable Painting of Individual Clock Regions Within the Target Device:

When the checkbox in the **Visibility** column for a clock region is selected, the area of the target device (in the Floorplanner view) representing that clock region is painted in the displayed translucent overlay color. When the checkbox is unchecked, the Floorplanner view is redrawn with the chosen clock region overlay no longer painted.

#### Enable/Disable Painting of all Clock Regions Within the Target Device:

When the Show/Hide All Clock Regions action is selected, the visibility of all clock regions are simultaneously either enabled or disabled, causing the Floorplanner view to be repainted appropriately.

#### Temporarily Alter the Overlay Rendering Color of Individual Clock Regions:

The overlay rendering color of each individual clock region may be chosen as follows:

- 1. Right-click the mouse pointer anywhere on the row of the desired clock region.
- 2. Select Choose Overlay Color from the popup context menu.
- 3. The Color Dialog may then be used to choose the desired color for the clock region.

#### Note

This is a temporary color change — colors are reverted to automatically chosen defaults if changes are made to the active design, the active implementation, the target device, or ACE is closed.

ACE automatically picks a different overlay color for an individual clock region if **Reset Overlay Color** is selected from the right-click popup content menu.

#### Temporarily Alter the Overlay Rendering Color for All Clock Regions:

ACE automatically picks different overlay colors for all clock regions if the **Reset All Overlay Colors** action is selected from the Clock regions view local pull-down menu.

### **Organizing Table Data**

The following are ways to alter the presentation of the data in the Clock regions table:

#### **Column Resizing**

The width of a column can be changed as follows:

- 1. Place the mouse cursor over the boundary between columns at this point the mouse cursor should change to indicate resizing is possible.
- 2. Simply left-click and drag left or right to resize the column to the desired width.
- 3. Release the mouse button.

#### **Column Reordering**

The order of the columns in the table can be changed as follows:

- 1. Left-click and hold on any column name
- 2. Drag left or right to move the column between any other pair of columns.

3. Release the left mouse button to insert the column header at the new location.

While dragging, the dragged column header is visible alongside the mouse cursor, and there is a thick column header separator showing where the column insertion occurs if the mouse is released at the present cursor location.

#### Filtering

Most columns of the table may filter the displayed clock regions by value. When filtering by column value, only clock regions with column values matching the filter are retained; non-matching values are excluded from the table.

- Columns containing text can be filtered by string value. Simple substring text matching (with optional wildcard) is used by default, but Regular Expression matching, also known as RegEx (see https://en.wikipedia.org/wiki/ Regular\_expression), is also available. The ACE GUI RegEx matching follows Java rules (see https:// docs.oracle.com/en/java/javase/11/docs/api/java.base/java/util/regex/Pattern.html), which are extremely similar to Perl rules.
- · Columns with checkmarks can be filtered by boolean value.
- · Columns containing numbers can be filtered by numerical value.
- Columns which may not be filtered (i.e., the **Overlay Color** column) lack a filter icon in the filter row.

To add a filter to a column:

- 1. The Filter row must first be visible. Select the (1) Toggle Filter Row Visibility action to show the row if necessary.
- 2. Click the ( $\Upsilon$ ) filter icon for the desired column, which causes a data-appropriate filter dialog to appear.
- 3. Fill in the desired filter values and click **Apply** to apply the filter to the rows in the table.

All values matching that filter are retained, and all other values are excluded. Additionally, the background color of the filtered column changes to a bright yellow to indicate the filter is active, and the filter icon at the head of the column also changes to the ( $\Upsilon$ ) active filter icon.

To edit (or clear) an existing filter:

- 1. Click the ( Y) active filter icon, which causes the data-appropriate filter dialog to appear pre-populated with the current column filter setting.
- 2. Change the filter value and click **Apply** to edit the filter.
- 3. Click **Cancel** to leave the filter unchanged.
- 4. Click **Clear** to remove the filter from the column.

If the filter is cleared, the background color of the column returns to the default background color, and the filter icon also changes to the ( $\Upsilon$ ) inactive version.

# Partial Reconfig Cluster Value

The partial reconfig cluster value display at the bottom of the view shows a value representing the set of all clock regions marked as "visible" in the view. Making more or fewer clock regions visible updates this value accordingly.

The Copy hex value to clipboard button copies the current value to the system clipboard.

The **Send Tcl command** button automatically issues an appropriate set\_impl\_option bitstream\_prc\_cluster\_map {partial\_reconfig\_value} command.

# **Clusters View**

The Clusters view allows the toggling the visibility of overlays within the **Floorplanner view** (page 45) for each logic cluster. The view table remains empty until the currently active Implementation has been prepared (i.e. the **Run Prepare** flow step has been completed).

By default, the Clusters view is included in the Floorplanner perspective (page 6). To add the view to the current perspective, select Window  $\rightarrow$  Show View  $\rightarrow$  Other...  $\rightarrow$  Achronix  $\rightarrow$  Clusters.

| /isibility   | Cluster Name      | Color | Clock Pre-Routes |  |
|--------------|-------------------|-------|------------------|--|
|              | LOGIC_CLUSTER_0_0 |       |                  |  |
| $\checkmark$ | LOGIC_CLUSTER_0_1 |       | (clk_p: 2,4)     |  |
|              | LOGIC_CLUSTER_0_2 |       |                  |  |
|              | LOGIC_CLUSTER_0_3 |       |                  |  |
|              | LOGIC_CLUSTER_0_4 |       |                  |  |
| $\checkmark$ | LOGIC_CLUSTER_0_5 |       | (clk_p: 1,3,5,7) |  |
| $\checkmark$ | LOGIC_CLUSTER_0_6 |       | (clk_p: 1,3,5,7) |  |
| $\checkmark$ | LOGIC_CLUSTER_0_7 |       | (clk_p: 1,3,5,7) |  |
|              | LOGIC_CLUSTER_1_0 |       |                  |  |
| $\checkmark$ | LOGIC_CLUSTER_1_1 |       | (clk_p: 2,4)     |  |
|              | LOGIC_CLUSTER_1_2 |       |                  |  |

Figure 12 • Clusters View Example

| Column               | Editabl<br>e | Description                                                                                                                                                                                                           |  |
|----------------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Visibility           | Y            | When checked, the logic cluster overlay is painted in the <b>Floorplanner view</b> (page 45), using the translucent color shown in the <b>Color</b> column.                                                           |  |
| Cluster Name         |              | The name of this cluster.                                                                                                                                                                                             |  |
| Color                | Y            | The color used to paint the location of the cluster as an overlay in the Floorplanner view. Right-click any row, then choose <b>Change Overlay Color</b> to choose an alternate overlay paint color for that cluster. |  |
| Clock Pre-<br>Routes |              | If any clock pre-routes exist for a given partition, they are listed here.                                                                                                                                            |  |

#### Table 11 · Clusters Table Columns

| lcon     | Action                          | Toolbar<br>Button | Context<br>Menu | View<br>Menu | Description                                                                                                                                                                                                                                                                                        |
|----------|---------------------------------|-------------------|-----------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | Show / Hide overlay             |                   | Y               |              | Show or Hide the overlay for the chosen cluster in the Floorplanner view.                                                                                                                                                                                                                          |
|          | Change Overlay<br>Color         |                   | Y               |              | Allows changing the translucent<br>overlay color which is used to paint<br>the chosen cluster in the<br>Floorplanner View (when the<br>visibility is enabled).                                                                                                                                     |
|          | Reset Overlay Color             |                   | Y               |              | Reset the chosen cluster overlay<br>color, allowing ACE to<br>automatically pick a new color. If<br>the overlay colors of two clusters<br>are too similar for easy<br>discernment, another color is<br>pseudo-randomly selected. Each<br>time this action is chosen, another<br>color is selected. |
| Q        | Zoom To                         |                   | Y               |              | Pans and zooms the Floorplanner view to show the location of the selected cluster. <sup>(1)</sup>                                                                                                                                                                                                  |
|          | Reset All Overlay<br>Colors     |                   |                 | Y            | Pseudo-randomly reassigns new overlay colors for all clusters.                                                                                                                                                                                                                                     |
| ٠.       | Configure Clock<br>Pre-Routes   |                   | Y               |              | Allows adding clock pre-route information for the selected partition(s).                                                                                                                                                                                                                           |
| <b>N</b> | Show/Hide All<br>Custers        | Υ                 | Y               | Y            | Shows or hides the checkboxes in the Floorplanner view for all logic clusters in the table.                                                                                                                                                                                                        |
| <b>R</b> | Toggle Filter Row<br>Visibility | Υ                 | Y               | Y            | Shows or hides the filter icons in the filter row at the top of the table. <sup>(2)</sup>                                                                                                                                                                                                          |



# Using the Table to Display Clusters in the Floorplanner View

Each cluster is automatically given a unique translucent overlay color to represent the cluster when painting the **Floorplanner view** (page 45). By default, no cluster overlays are painted in the Floorplanner view. The cluster overlays must be enabled to be displayed. The overlay color for each/all clusters may optionally be altered, but these color choices are not persisted between ACE sessions.

(i) While choosing alternate overlay colors is allowed for each cluster, these overlay colors are not saved between sessions. Each time a design is loaded, new overlay colors are automatically chosen for each cluster.

The following are ways to alter the presentation of Cluster data in the Floorplanner view (page 45):

#### Enable/Disable Painting of Individual Clusters Within the Target Device:

When the checkbox in the **Visibility** column for a cluster is checked, the area of the target device (in the Floorplanner view) representing that cluster is painted in the displayed translucent overlay color. When unchecked, the Floorplanner view is redrawn with the chosen cluster overlay no longer painted.

#### Enable/Disable Painting of All Clusters Within the Target Device:

When the Show/Hide All Clusters action is chosen, the visibility of all clusters are simultaneously either enabled or disabled, causing the Floorplanner view to be repainted appropriately.

#### Temporarily Alter the Overlay Rendering Color of Individual Clusters:

The overlay rendering color of each individual cluster may be chosen as follows:

- 1. Right-click the mouse pointer anywhere on the row of the desired cluster.
- 2. Select Choose Overlay Color from the popup context menu.
- 3. The Color Dialog can then be used to choose the desired color for the cluster.

#### (i) Note

This is a temporary color change — colors are reverted to automatically chosen defaults if changes are made to the active design, the active implementation, the target device, or ACE is closed.

ACE automatically picks a different overlay color for an individual cluster if **Reset Overlay Color** is chosen from the right-click popup content menu.

#### Temporarily Alter the Overlay Rendering Color for All Clusters:

ACE automatically picks different overlay colors for all clusters if the **Reset All Overlay Colors** action is chosen from the clusters View local pull-down menu.

# **Organizing Table Data**

The following are ways to alter the presentation of the data in the clusters table:

#### **Column Resizing**

The width of a column can be changed as follows:

- 1. Place the mouse cursor over the boundary between columns.
- 2. At this point, the mouse cursor should change to indicate resizing is possible.
- 3. Simply left-click and drag left or right to resize the column to the desired width.
- 4. Release the mouse button.

#### **Column Reordering**

The order of the columns in the table can be changed as follows:

- 1. Left-click and hold on any column name.
- 2. Drag left or right to move the column between any other pair of columns.
- 3. Release the left mouse button to insert the column header at the new location.

While dragging, the dragged column header is visible alongside the mouse cursor and there is a thick column header separator showing where the column insertion is to occur if the mouse is released at the present cursor location.

#### Filtering

Most columns of the table may filter the displayed clusters by value. When filtering by column value, only clusters with column values matching the filter are retained. Non-matching values are excluded from the table.

- Columns containing text can be filtered by string value. Simple substring text matching (with optional wildcard) is used by default, but Regular Expression matching, also known as RegEx (see https://en.wikipedia.org/wiki/ Regular\_expression), is also available. The ACE GUI RegEx matching follows Java rules (see https:// docs.oracle.com/en/java/javase/11/docs/api/java.base/java/util/regex/Pattern.html), which are extremely similar to Perl rules.
- Columns with checkmarks can be filtered by boolean value.
- Columns containing numbers can be filtered by numerical value.
- Columns which may not be filtered (i.e., the **Overlay Color** column) lack a filter icon in the filter row.

To add a filter to a column:

- 1. The Filter row must first be visible. Select the (View) Toggle Filter Row Visibility action to show the row if necessary.
- 2. Click the ( $\Psi$ ) filter icon for the desired column, which causes a data-appropriate filter dialog to appear.
- 3. Fill in the desired filter values and click **Apply** to apply the filter to the rows in the table.

All values matching that filter are retained, and all other values are excluded. Additionally, the background color of the filtered column changes to a bright yellow to indicate the filter is active, and the filter icon at the head of the column also changes to the ( $\checkmark$ ) active filter icon.

To edit (or clear) an existing filter:

- 1. Click the ( Y) active filter icon, which causes the data-appropriate filter dialog to appear pre-populated with the current column filter setting.
- 2. Change the filter value and click **Apply** to edit the filter.
- 3. Click Cancel to leave the filter unchanged.
- 4. Click **Clear** to remove the filter from the column.

If the filter is cleared, the background color of the column returns to the default background color, and the filter icon also changes to the ( $\Upsilon$ ) inactive version.

# Partial Reconfig Cluster Value

The partial reconfig cluster value display at the bottom of the view shows a value representing the set of all clusters marked as "visible" in the view. Making more or fewer clusters visible updates this value accordingly.

The Copy hex value to clipboard button copies the current value to the system clipboard.

The **Send Tcl command** button automatically issues an appropriate set\_impl\_option bitstream\_prc\_cluster\_map {partial\_reconfig\_value} command.

# Critical Path Diagram View

The Critical Path Diagram view provides a graphical representation of a single critical path. Selecting a row in the associated **Critical Paths view** (page 39) table updates the diagram in the Critical Path Diagram view so that it contains a graphical representation of the selected critical path. The graphical representations consist of circular nodes (representing instances) connected by arrows (representing one or more nets). Similar to the **Floorplanner view** (page 45), the Critical Path Diagram view contains a fly-out palette of display options on the right of the diagram (collapsed/hidden by default), and a collection of buttons at the top. The colors used in the Critical Path Diagram view are configured via the **Critical Path Diagram view Preference page** (page 196). For details on usage of the diagram view, please see **Using Critical Path Diagrams** (page 355) and **Analyzing Critical Paths** (page 352).

By default, the Critical Path Diagram view is included in the Floorplanner perspective (page 6). To add it to the current perspective, select Window  $\rightarrow$  Show View  $\rightarrow$  Other...  $\rightarrow$  Critical Path Diagram.



#### Table 13 · Critical Path Diagram View Example, Including Expanded Fly-Out Palette

When no critical path is selected in the Critical Paths view (page 39), the diagram displays this warning:

| 👫 Critical Path Diagram 🛛 | 🔊 😵 (                                                                          | ୍   €୍ | Q       |  |
|---------------------------|--------------------------------------------------------------------------------|--------|---------|--|
|                           | Please select a single path (row) in the Critical Paths View to show a diagram |        | <u></u> |  |
| <                         |                                                                                |        | >       |  |

Figure 13 • No Critical Path Selected Warning, Including Collapsed Palette

| lcon | Action         | Description                                                                                                                                                                                                                                                                                                                        |
|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| L3   | Selection tool | Controls the behavior of the mouse while in the Critical Path<br>Diagram view. The selection tool creates a selection rectangle<br>when dragging with the left mouse button. Any objects in the<br>selection rectangle are either added to or removed from the<br>current ACE selection set, as configured in the fly-out palette. |
| ••   | Movement tool  | Controls the behavior of the mouse while in the Critical Path<br>Diagram view. The movement tool pans the view when dragging<br>with the left mouse button.                                                                                                                                                                        |

| lcon | Action    | Description                                                                                                                                                                                                                                                                                                                              |
|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Q    | Zoom tool | Controls the behavior of the mouse while in the Critical Path<br>Diagram view. The zoom tool creates a zoom-in rectangle when<br>the left mouse button is pressed and held, then dragged to the<br>lower-right. The zoom tool creates a zoom-out line when the left<br>mouse button is pressed and held, then dragged to the upper-left. |
| ۹    | Zoom in   | Increases the current zoom level in the Critical Path Diagram view by 200%.                                                                                                                                                                                                                                                              |
| Q    | Zoom out  | Decreases the current zoom level in the Critical Path Diagram view by 200%.                                                                                                                                                                                                                                                              |

Right-clicking on an instance or net within the diagram also displays a context menu of additional actions.

## Table 15 Critical Path Diagram View Context Menu Actions

| lcon | Action                         | Description                                                                                                                                                                                         |
|------|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ÷    | Add to Selection               | The instance or net under the mouse is added to the ACE selection set (and painted in the selection color).                                                                                         |
|      | Remove from Selection          | The instance or net under the mouse is removed from the ACE selection set if currently selected (and thus no longer is painted the selection color).                                                |
| 1    | Highlight                      | Sets the highlight color for the instance or net under the mouse to the currently-chosen view highlight color.                                                                                      |
|      | Choose highlight color         | Determines which color is applied to instances/nets the next time the highlight action is selected for this view.                                                                                   |
| ×    | Un-Highlight                   | Turns off the highlight color for the instance or net under the mouse.                                                                                                                              |
| Q    | Zoom To                        | Pans and zooms the Floorplanner view (not this view) to the<br>closest zoom that still displays (centered) the entire<br>instance or net currently under the mouse in the Critical<br>Path diagram. |
|      | Show in Netlist <sup>(1)</sup> | Attempts to open a text editor to the file and line number relevant to the instance or net under the mouse.                                                                                         |
|      | Fix Placement of Instance      | Causes the placement state of the instance under the mouse cursor to change from unfixed (or soft) to fixed.                                                                                        |

| lcon | Action                         | Description                                                                                                                                                                                                               |
|------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Unfix Placement of Instance    | Causes the placement state of the instance under the mouse cursor to change from fixed to unfixed (or soft).                                                                                                              |
|      | Unplace Instance               | Causes the placed instance under the mouse cursor to be unplaced, vacating the site.                                                                                                                                      |
|      | Unplace All Selected Instances | Causes all instances currently in the ACE Selection set (as<br>listed in the <b>Selection view</b> (page 137)) to be unplaced at once<br>(this is much more efficient than unplacing multiple<br>instances individually). |

#### **Table Notes**

1. This Early Access functionality might not always open the text editor to the expected location.

# **Fly-Out Palette**

As with many other ACE diagram views, the Critical Path Diagram view includes a supplementary fly-out palette of additional settings which affect the interactions with the diagram, as well as the appearance of the diagram. The following options are available in the fly-out palette in the Critical Path Diagram view.

#### Selection

The ( 🗟 ) Selection Options control the selection of objects in the Critical Path Diagram view.

#### Table 16• Selection Options

| Option   | Default  | Description                                                                                                                                                         |
|----------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Select   | Enabled  | This radio button controls the action applied to objects in the selection region. This setting causes the objects to be added to the current ACE selection set.     |
| Deselect | Disabled | This radio button controls the action applied to objects in the selection region. This setting causes the objects to be removed from the current ACE selection set. |

For more details about viewing and managing the ACE Selection set, see Selection view (page 137).

#### Label

The ( ) Label options control the text labels on graph nodes and arrows (instances and net abstractions) in the Critical Path Diagram view.

#### (i) Note

These labels are only displayed when there is enough room to print them on screen. It might be necessary to **Zoom In** to provide sufficient area for all the desired text to be displayed.

#### Table 17 • Label Options

| Option         | Description                                                |
|----------------|------------------------------------------------------------|
| Instance Names | Displays the instance name each graph node represents.     |
| Instance Types | Displays the instance type (cell) for each graph node.     |
| Net Names      | Displays the net name represented by each arrow.           |
| Delays         | Displays the delay (in ps) to traverse each node or arrow. |
| Fanouts        | Displays the fanout of the net represented by the arrow.   |

## Tool Tip Text

The (🖙) Tooltip options control the tooltip content while hovering over graph nodes and arrows in the Critical Path Diagram view.

#### Table 18 • Tooltip Options

| Option         | Description                                                |
|----------------|------------------------------------------------------------|
| None           | No tooltips are displayed for nodes or arrows.             |
| Instance Names | Displays the instance name each graph node represents.     |
| Instance Types | Displays the instance type (cell) for each graph node.     |
| Net Names      | Displays the net name represented by each arrow.           |
| Pin Names      | Displays source and sink pin names for nets.               |
| Delays         | Displays the delay (in ps) to traverse each node or arrow. |
| Fanouts        | Displays the fanout of the net represented by the arrow.   |

# **Critical Paths View**

The Critical Paths view provides a table of critical paths resulting from running timing analysis (the view contains no data unless or until one of the **Run ... Timing Analysis** flow steps is completed). This view (in cooperation with the **Critical Path Diagram view** (page 34)) displays critical path details, manages selection of objects on critical paths, and highlights critical paths in the **Floorplanner view** (page 45).

#### (i) Note

The Critical Paths view is populated with the results from timing analysis, and thus remains empty unless or until one of the **Run ... Timing Analysis** flow steps is executed (timing analysis data is not stored within the \*.acxdb files, thus timing analysis must be re-run every time the Critical Paths view is used).

Clicking a row in the table enables toolbar buttons for analyzing the associated critical path, and causes the display of a graphical diagram of the associated critical path in the **Critical Path Diagram view** (page 34). Clicking a column header sorts the table according to the data in that column.

By default, the Critical Paths view is included in the **Floorplanner perspective** (page 6). To add it to the current perspective, select **Window**  $\rightarrow$  **Show View...**  $\rightarrow$  **Critical Paths**.

#### Table 19 · Critical Path View Actions

| lcon             | Action             | Description                                                                                                                                   |
|------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 9+0              | Select path        | Adds the selected critical path in the table to the current ACE selection set.                                                                |
| ***              | Select pins        | Adds pins on the selected critical path in the table to the current ACE selection set.                                                        |
| ••               | Select instances   | Adds instances on the selected critical path in the table to the current ACE selection set.                                                   |
| 0[ <sup>10</sup> | Select nets        | Adds nets on the selected critical path in the table to the current ACE selection set.                                                        |
| Q                | Zoom to path       | Zooms the Floorplanner view to a region containing the selected critical path in the table.                                                   |
|                  | Print Path Details | Produces a detailed report of the selected critical path in the table to the text output in the Tcl Console view.                             |
| Ð                | Save Script File   | Displays the Save Script File dialog which allows saving a Tcl script of find commands for use in the schematic viewer of the synthesis tool. |

The view is primarily made up of a tree table, with each branch of the tree representing a separate clock domain. The most critical path of each clock domain is the branch node, with all other paths from that clock domain acting as leaves for that branch. Setup violations are considered "worse" than hold violations, thus any setup violation takes precedence over hold violations as the branch node, regardless of relative slack values.

There are 'Left-align' and 'Right-align' buttons on the tool bar above the table that can be used to adjust the display of the 'Source' and 'Destination' columns.

| Highlight | Clock Domain | Path  | Slack   | Туре            | Source                        | Destination                   |
|-----------|--------------|-------|---------|-----------------|-------------------------------|-------------------------------|
|           | clk          | sc_s0 | 124.000 | Setup Check Met | internal_counter2.count_4_:q  | internal_counter2.count_10_:d |
|           | clk          | sc_s1 | 124.000 | Setup Check Met | internal_counter2.count_4_:q  | internal_counter2.count_11_:d |
|           | clk          | sc_s2 | 124.000 | Setup Check Met | internal_counter2.count_4_:q  | internal_counter2.count_9_:d  |
|           | clk          | sc_s3 | 124.000 | Setup Check Met | internal_counter2.count_4_:q  | internal_counter2.count_8_:d  |
|           | clk          | sc_s4 | 124.000 | Setup Check Met | internal_counter1.count_1_:q  | internal_counter1.count_12_:d |
|           | clk          | sc_s5 | 124.000 | Setup Check Met | internal_counter1.count_1_:q  | internal_counter1.count_11_:d |
|           | clk          | sc_s6 | 124.000 | Setup Check Met | internal_counter1.count_1_:q  | internal_counter1.count_10_:d |
|           | clk          | sc_s7 | 124.000 | Setup Check Met | internal_counter1.count_1_:q  | internal_counter1.count_9_:d  |
|           | clk          | sc_s8 | 124.000 | Setup Check Met | internal_counter1.count_1_:q  | internal_counter1.count_8_:d  |
|           | clk          | sc_s9 | 124.000 | Setup Check Met | internal_counter2.count_4_:q  | internal_counter2.count_7_:d  |
|           | clk          | fc_h0 | 0.020   | Hold Check Met  | pulse1_reg1:q                 | pulse1_reg2:d                 |
|           | clk          | fc_h1 | 0.129   | Hold Check Met  | cnt2_countf_reg1:q            | pulse2_reg1:d                 |
|           | clk          | fc_h2 | 0.133   | Hold Check Met  | led_counter.count_0_:q        | led_counter.count_0_:d        |
|           | clk          | fc_h3 | 0.146   | Hold Check Met  | internal_counter1.count_12_:q | cnt1_countf_reg1:d            |
|           | clk          | fc_h4 | 0.159   | Hold Check Met  | cnt1_countf_reg2:q            | pulse1_reg1:d                 |
|           | clk          | fc_h5 | 0.159   | Hold Check Met  | pulse1_reg2:q                 | internal_counter2.count_0_:ce |
|           | clk          | fc_h6 | 0.159   | Hold Check Met  | pulse1_reg2:q                 | internal_counter2.count_5_:ce |
|           | clk          | fc_h7 | 0.160   | Hold Check Met  | led_counter.count_1_:q        | led_counter.count_1_:d        |
|           | clk          | fc_h8 | 0.160   | Hold Check Met  | pulse1_reg2:q                 | internal_counter2.count_7_:ce |
|           | clk          | fc_h9 | 0.160   | Hold Check Met  | pulse1_reg2:q                 | internal_counter2.count_3_:ce |
|           | clk          | sc_h6 | 0.233   | Hold Check Met  | internal_counter1.count_2_:q  | internal_counter1.count_2_:d  |
|           | clk          | sc_h7 | 0.234   | Hold Check Met  | internal_counter1.count_2_:q  | internal_counter1.count_3_:d  |
|           | clk          | sc_h8 | 0.235   | Hold Check Met  | cnt2_countf_reg1:q            | cnt2_countf_reg2:d            |
|           | clk          | sc_h9 | 0.237   | Hold Check Met  | pulse2_reg1:q                 | pulse2_reg2:d                 |

Figure 14 · Critical Path View Example: Left-align

| 🗝 Critical Pa | ths X        |       |         |                 | E I                           | Den 🐉 📽 📲 🔍 📑 8 🗖             |
|---------------|--------------|-------|---------|-----------------|-------------------------------|-------------------------------|
| Highlight     | Clock Domain | Path  | Slack   | Туре            | Source                        | Destination                   |
| / 🗆 🗖 👘       | clk          | sc_s0 | 124.000 | Setup Check Met | internal_counter2.count_4_:q  | internal_counter2.count_10_:d |
|               | clk          | sc_s1 | 124.000 | Setup Check Met | internal_counter2.count_4_:q  | internal_counter2.count_11_:d |
|               | clk          | sc_s2 | 124.000 | Setup Check Met | internal_counter2.count_4_:q  | internal_counter2.count_9_:d  |
|               | clk          | sc_s3 | 124.000 | Setup Check Met | internal_counter2.count_4_:q  | internal_counter2.count_8_:d  |
|               | clk          | sc_s4 | 124.000 | Setup Check Met | internal_counter1.count_1_:q  | internal_counter1.count_12_:d |
|               | clk          | sc_s5 | 124.000 | Setup Check Met | internal_counter1.count_1_:q  | internal_counter1.count_11_:d |
|               | clk          | sc_s6 | 124.000 | Setup Check Met | internal_counter1.count_1_:q  | internal_counter1.count_10_:d |
|               | clk          | sc_s7 | 124.000 | Setup Check Met | internal_counter1.count_1_:q  | internal_counter1.count_9_:d  |
|               | clk          | sc_s8 | 124.000 | Setup Check Met | internal_counter1.count_1_:q  | internal_counter1.count_8_:d  |
|               | clk          | sc_s9 | 124.000 | Setup Check Met | internal_counter2.count_4_:q  | internal_counter2.count_7_:d  |
|               | clk          | fc_h0 | 0.020   | Hold Check Met  | pulse1_reg1:q                 | pulse1_reg2:d                 |
|               | clk          | fc_h1 | 0.129   | Hold Check Met  | cnt2_countf_reg1:q            | pulse2_reg1:d                 |
|               | clk          | fc_h2 | 0.133   | Hold Check Met  | led_counter.count_0_:q        | led_counter.count_0_:d        |
|               | clk          | fc_h3 | 0.146   | Hold Check Met  | internal_counter1.count_12_:q | cnt1_countf_reg1:d            |
|               | clk          | fc_h4 | 0.159   | Hold Check Met  | cnt1_countf_reg2:q            | pulse1_reg1:d                 |
|               | clk          | fc_h5 | 0.159   | Hold Check Met  | pulse1_reg2:q                 | internal_counter2.count_0_:ce |
|               | clk          | fc_h6 | 0.159   | Hold Check Met  | pulse1_reg2:q                 | internal_counter2.count_5_:ce |
|               | clk          | fc_h7 | 0.160   | Hold Check Met  | led_counter.count_1_:q        | led_counter.count_1_:d        |
|               | clk          | fc_h8 | 0.160   | Hold Check Met  | pulse1_reg2:q                 | internal_counter2.count_7_:ce |
|               | clk          | fc_h9 | 0.160   | Hold Check Met  | pulse1_reg2:q                 | internal_counter2.count_3_:ce |
|               | clk          | sc_h6 | 0.233   | Hold Check Met  | internal_counter1.count_2_:q  | internal_counter1.count_2_:d  |
|               | clk          | sc_h7 | 0.234   | Hold Check Met  | internal_counter1.count_2_:q  | internal_counter1.count_3_:d  |
|               | clk          | sc_h8 | 0.235   | Hold Check Met  | cnt2_countf_reg1:q            | cnt2_countf_reg2:d            |
|               | clk          | sc_h9 | 0.237   | Hold Check Met  | pulse2_reg1:q                 | pulse2_reg2:d                 |

#### Figure 15 • Critical Path View Example: Right-align

Entries in the table are always grouped by clock domain, with individual paths sorted within a clock domain. The clock domains themselves are (by default) sorted from most critical to least critical.

The default sort order, from most critical to least critical, of the critical paths is as follows:

- 1. Setup violations, from the most negative slack value to zero.
- 2. Hold violations, from the most negative slack value to zero.
- 3. Setup met, from zero to the most positive slack.
- 4. Hold met, from zero to the most positive slack.

#### Table 20 Critical Path View Table Columns

| Column    | Description                                                                                                                                                                  |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Highlight | Allows highlighting the path in the Floorplanner view, using the checkbox.<br>Also allows configuring the highlight color of the path by clicking the color<br>selector box. |

| Column       | Description                                                         |
|--------------|---------------------------------------------------------------------|
| Clock Domain | Displays the clock domain name of the path.                         |
| Path         | Displays the unique path ID (used in the Timing report (page 245)). |
| Slack        | Displays the slack for the path in ns.                              |
| Туре         | Displays the path type.                                             |
| Source       | Displays the source instance of the path.                           |
| Destination  | Displays the destination instance of the path.                      |

By default, the highlight colors for the Setup violation and Hold violation path types ranges from red (the worst slack values) through orange to yellow (any violation slack values close to zero). The default highlight color of Slack Met and Hold Met path types is always green, and does not vary by reported slack value.

The view local pull-down menu (found to the right of the view toolbar buttons) contains some additional controls for the view: four filters to control which types of paths are displayed in the table, as well as shortcuts to run the four stages of timing analysis. As mentioned previously, the most critical path within each clock domain is always displayed, regardless of the type filter settings. (Every clock domain is always represented in the tree table by at least one row of data.)

#### Table 21 · Critical Paths View Drop-down Menu Actions

| Action                         | Description                                                                                                                                                                                            |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Show Clock Paths               | If checked, highlighted critical paths in the Floorplanner view show<br>the clock routing segments as part of the critical path. If unchecked,<br>only the data portion of the critical path is shown. |
| Show Setup Violations          | If checked, Setup violation leaf nodes are shown in the treetable. If unchecked, these leaf nodes are hidden.                                                                                          |
| Show Hold Violations           | If checked, Hold violation leaf nodes are shown in the treetable. If unchecked, these leaf nodes are hidden.                                                                                           |
| Show Setup Met                 | If checked, Setup Met leaf nodes are shown in the treetable. If unchecked, these leaf nodes are hidden.                                                                                                |
| Show Hold Met                  | If checked, Hold Met leaf nodes are shown in the treetable. If unchecked, these leaf nodes are hidden.                                                                                                 |
| Run Prepared Timing Analysis   | If selected, runs the Prepared Timing Analysis flow step.                                                                                                                                              |
| Run Post-Place Timing Analysis | If selected, runs the Post-Place Timing Analysis flow step.                                                                                                                                            |

| Action                         | Description                                                 |
|--------------------------------|-------------------------------------------------------------|
| Run Post-Route Timing Analysis | If selected, runs the Post-Route Timing Analysis flow step. |
| Run Final Timing Analysis      | If selected, runs the Final Timing Analysis flow step.      |

# Download View

The Download view provides a graphical interface for choosing and downloading (via JTAG) a bitstream \*.hex file to an Achronix FPGA or eFPGA connected to the workstation using USB via a Bitporter2 pod or FTDI FT2232H or FT4232H device. Bitstream \*.hex files are generated by ACE during the **Generate Bitstream flow step** (page 235).

By default, the Download view is included in the **Programming and Debug perspective** (page 6). To access the Download view if it is not visible in the current perspective, select **Window**  $\rightarrow$  **Show View...**  $\rightarrow$  **Others**  $\rightarrow$  **Download View**.

When the Download view opens, the windows might need to be resized for optimal viewing.

#### 👍 Caution!

#### The JTAG connection must be configured before using the Download view!

- ACE interacts with the FPGA or eFPGA using the JTAG interface through a USB Bitporter2 pod or FTDI FT2232H device. This JTAG interface must be properly configured in ACE before using the Download view. The configuration is managed using the Configure JTAG Connection preference page (page 193), which is easily accessible by clicking the (<sup>1</sup>/<sub>1</sub>) Configure JTAG Interface button in the Download view. See Configuring the JTAG Connection (page 359) for more details. The (<sup>1</sup>) Download Bitstream button and the (<sup>1</sup>/<sub>1</sub>) Configure JTAG Interface button each also provide a summary of the current JTAG configuration settings (for pod name and scan chain) in their tooltips for ease of reference.
- While using the Download view, it is strongly recommended that the **Tcl Console view** (page 146) be kept visible to display any status or error messages reported during the JTAG interactions. The Tcl Console view and Download view are both visible by default in the Programming and Debug perspective.

In addition to allowing the choice of a bitstream file and performing actual downloads, this view also allows toggling of some programming options, and some related utility interactions with JTAG-connected devices.

For all buttons and checkboxes, tooltips provide a more verbose description of each, if the summary statement is insufficient. The ( ) **Download Bitstream** button and the ( ) **Configure JTAG Interface** button each also provide

a summary of the current JTAG configuration settings (for pod name and scan chain) in their tooltips for ease of reference.

See also:

- Programming a Device using JTAG in the Download View (page 389)
- Configuration User Guide (UG004)
- Device family-specific user guide (i.e., Speedster7t Configuration User Guide (UG094))

After downloading the bitstream, the JTAG connection status is retained, meaning that if the JTAG connection is open prior to programming, it stays open, and if the JTAG connection is closed prior to programming, it closes the connection when programming completes.

| 🅸 Snapshot Debugger 🗟 Download 🗙 📴 Register Browser                                    | ▶ 🖞 🖇 🗖 🗖 |  |  |
|----------------------------------------------------------------------------------------|-----------|--|--|
| JTAG Programming                                                                       |           |  |  |
| Select the programming options and bitstream file (*.hex) to be used.                  |           |  |  |
| JTAG Programming Options                                                               |           |  |  |
| Perform an FCU reset to clear the (e)FPGA config memory.                               |           |  |  |
| C:\Achronix\quickstart_packager_AC7t1500\ace\impl_1\pnr\output\quickstart.hex          | Browse ✔  |  |  |
| Download Bitstream                                                                     |           |  |  |
| Suggested Bitstream Files                                                              |           |  |  |
| ✓ From active implementation                                                           |           |  |  |
| C:\Achronix\quickstart_packager_AC7t1500\ace\impl_1\pnr\output\quickstart.hex          |           |  |  |
| ✓ Recently used                                                                        |           |  |  |
| C:\Achronix\quickstart packager AC7t1500\ace\impl 1\pnr\output\quickstart.hex          |           |  |  |
| <u>C:\Achronix\quickstart_packager_AC7t800\ace\impl_1\pnr\output\quickstart.hex</u>    |           |  |  |
| JTAG Utilities                                                                         |           |  |  |
| Miscellaneous utilities to ease JTAG interactions.                                     |           |  |  |
| Report a list of all available USB-connected JTAG devices by ID: Get Connected Devices |           |  |  |

## Figure 16 • Download View Example

#### Table 22 · Download View Options

| Option                                                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| JTAG Programming Options                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Perform an FCU reset to clear<br>the (e)FPGA config memory. | When checked, performs a soft reset and clears all device configuration<br>memory before beginning programming. This reset is typically only<br>disabled for multi-stage programming (after stage 0 programming has<br>completed, before programming later stages begins), or for "partial<br>reconfig" when partial bitstreams are in use (see the chapter titled<br>Partial Reconfiguration in the <i>Speedster7t Configuration User Guide</i><br>(UG094) for more details). |
| Browse                                                      | Allows choosing any <b>*</b> . hex bitstream file from the file system using a graphical file system browser.                                                                                                                                                                                                                                                                                                                                                                  |

| Option                                                               | Description                                                                                                                                                                                                              |
|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Download Bitstream.                                                  | Clicking this button performs the actual download by calling the appropriate Tcl commands in the jtag:: namespace. See also: <i>Speedster7t Configuration User Guide</i> (UG094).                                        |
| Suggested Bitstream Files                                            |                                                                                                                                                                                                                          |
| From active implementation.                                          | A list of all <b>*</b> .hex bitstream files (shown as hyperlinks) found in the output directory of the current <b>Active Implementation</b> (page 231). Select any of these hyperlinks to choose that file for download. |
| Recently used.                                                       | A list of the most recently used <b>*</b> . hex bitstream files (shown as hyperlinks). Select any of these hyperlinks to choose that file for download.                                                                  |
| JTAG Utilities                                                       |                                                                                                                                                                                                                          |
| Report a list of all available USB-<br>connected JTAG devices by ID. | Press the button to run a Tcl command<br>(jtag::get_connected_devices) to report a list of all connected<br>JTAG devices in the Tcl Console view.                                                                        |

# Floorplanner View

The Floorplanner view provides a graphical view of the physical layout of the device. This view allows visualizing the device, place and route data, critical paths, and the current selection set. The view allows zooming out to see a general overview of the user design mapped onto the device, or zooming in to see specific details.

Clicking the tall narrow arrow button on the far right of the Floorplanner view shows or hides the **fly-out palette** (page 49) of display options.

By default, the Floorplanner view is included in the Floorplanner perspective (page 6). To add it to the current perspective, select Window  $\rightarrow$  Show View  $\rightarrow$  Other...  $\rightarrow$  Floorplanner.

See also:

- Viewing the Floorplanner (page 338)
- Pre-placing a design (page 345)
- Floorplanner View Colors and Layers Preference Page (page 198)
- Floorplanner View Optimizations Preference Page (page 203).



Figure 17 • Floorplanner View Example, Including Expanded Fly-Out Palette

| lcon | Action                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ಛೆಂ  | Panning tool.          | Controls the behavior of the mouse while in the Floorplanner view. The<br>panning tool allows panning of the view when the left mouse button is<br>pressed and held.<br>Holding SPACE temporarily switches to the Panning tool.<br>Releasing SPACE switches back to the previously selected tool.<br>Tapping ALT cycles to the next tool.                                                                                                            |
|      | Placement Region tool. | Controls the behavior of the mouse while in the Floorplanner view. Allows the manipulation of placement regions and placement region constraints (page 394). When the Placement Region tool is active, the mouse may be used to create new placement regions (page 395), move (page 397) or resize (page 397) existing placement regions, and/or assign objects to placement region constraints (page 398).<br>Pressing ALT cycles to the next tool. |

| lcon    | Action                          | Description                                                                                                                                                                                                                                                                                                                                                               |
|---------|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| \$      | Selection tool.                 | Controls the behavior of the mouse while in the Floorplanner view. The<br>selection tool creates a selection rectangle when the left mouse button is<br>pressed and held. Any objects in the selection rectangle are applied with the<br>current selection action, as configured in the fly-out palette.<br>Pressing ALT cycles to the next tool.                         |
| Sp.     | Placement tool.                 | Controls the behavior of the mouse while in the Floorplanner view. The<br>placement tool allows drag-and-drop placement of instances when the left<br>mouse button is pressed and held.<br>Pressing ALT cycles to the next tool.                                                                                                                                          |
| Q       | Zoom tool.                      | Controls the behavior of the mouse while in the Floorplanner view. The zoom<br>tool creates a zoom-in rectangle when the left mouse button is pressed and<br>held, then dragged to the lower-right. The zoom tool creates a zoom-out line<br>when the left mouse button is pressed and held, then dragged to the upper-<br>left.<br>Pressing ALT cycles to the next tool. |
| ۲       | Zoom in.                        | Increases the current zoom level in the Floorplanner view by 200%.                                                                                                                                                                                                                                                                                                        |
| Q       | Zoom out.                       | Decreases the current zoom level in the Floorplanner view by 200%.                                                                                                                                                                                                                                                                                                        |
| <b></b> | Toggle drag-scrolling.          | Toggles drag-scrolling on and off. When drag-scrolling is enabled, dragging<br>an instance into a defined margin around the edges of the view causes the<br>view to automatically scroll in that direction. See the task Floorplanner<br>Panning (page 339) for complete details.<br>Pressing "Q" toggles this setting.                                                   |
| -28     | Save pre-placement constraints. | Opens the Save Placement dialog $_{\rm (page 185)}$ allowing the current placement to be saved to a pre-placement constraints ( . pdc) file.                                                                                                                                                                                                                              |

An instance or net within the Floorplanner may also be right-clicked to display a context menu of additional actions.

## Table 24 · Floorplanner View Context Menu Actions

| lcon | Action                 | Description                                                                                                                                           |
|------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| ÷    | Add to selection.      | The instance or net under the cursor is added to the ACE selection set (and is painted in the selection color).                                       |
|      | Remove from selection. | The instance or net under the cursor is removed from the ACE selection set if currently selected (and thus is no longer painted the selection color). |
| 1    | Highlight.             | Sets the highlight color for the instance or net under the cursor to the currently-chosen Floorplanner view highlight color.                          |

| lcon | Action                          | Description                                                                                                                                                                                                               |
|------|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Choose highlight color.         | Determines which color is applied to instances or nets the next time the Highlight action is selected for this view.                                                                                                      |
| ×    | Remove highlight.               | Turns off the highlight color for the instance or net under the cursor.                                                                                                                                                   |
| Q    | Zoom to.                        | Pans and zooms the Floorplanner view to the closest magnification that displays the entire centered instance or net under the cursor.                                                                                     |
|      | Show in netlist. <sup>(1)</sup> | Attempts to open a text editor to the file and line number relevant to the instance or net under the cursor.                                                                                                              |
|      | Fix instance placement.         | Causes the placement state of the instance under the cursor to change from unfixed (or soft) to fixed.                                                                                                                    |
|      | Unfix instance placement.       | Causes the placement state of the instance under the cursor to change from fixed to unfixed (or soft).                                                                                                                    |
|      | Unplace instance.               | Causes the placed instance under the cursor to be unplaced, vacating the site.                                                                                                                                            |
|      | Unplace all selected instances. | Causes all Instances currently in the ACE selection set (as<br>listed in the <b>Selection view</b> (page 137)) to be unplaced at<br>once (this is much more efficient than unplacing multiple<br>instances individually). |

#### **Table Notes**

1. "Show in Netlist" is early access functionality and might not always open the text editor to the expected location.

# Panning and Zooming

The Floorplanner view allows zooming in and out, to see more or less details respectively. There are several ways to change the zoom level:

- 1. Use the mouse scroll wheel.
- 2. Use the ( ) Zoom In and ( ) Zoom Out buttons in the toolbar.
- 3. Use keyboard shortcuts.

See the task Zooming the Floorplanner In and Out (page 338) for complete details.

Most of the other views within the Floorplanner perspective also include context-sensitive actions to **Zoom To** chosen individual objects or groups of objects — these actions cause the Floorplanner to center the chosen object(s)

in the Floorplanner, and to change the zoom level so that the chosen object(s) are as large/detailed as possible without overflowing the visible area.

When zoomed in, the FPGA requires more area than can easily fit in the view, making it necessary to pan the view around to see the different areas of the FPGA. Panning is most frequently performed using the arrow keys on the keyboard, mouse interactions with the scrollbars, the Panning Tool, or drag-scrolling during drag-and-drop interactions. See the Floorplanner Panning (page 339) task for complete details.

#### (i) Note

When painting objects in the Floorplanner when the view is zoomed out, some objects become too small to be rendered with any detail. These objects are painted, at a minimum, as a single pixel of the appropriate color.

Empty sites (those without a placed instance) are a special case. Unless selected, sites that are too small are not painted at all, even if layer settings would otherwise allow them to be visible. Selected sites are always painted, with a minimum size of a single pixel.

When a single pixel represents multiple objects, as happens when zoomed all the way out, ACE paints only the most critical or most important object state at that pixel location, so the single pixel is the most critical or most important color. The relative priorities of the states are described in **Instance States** (page 262).

## **Fly-Out Palette**

The following options are available in the fly-out palette in the Floorplanner view:

#### Layers

The ( = ) Layer Options control several layers of visible data in the Floorplanner view, allowing filtering the view so it contains a desired subset of all the available information.

#### Table 25 · Layer Options

| Option                                    | Default  | Description                                                                                       |
|-------------------------------------------|----------|---------------------------------------------------------------------------------------------------|
| Instances                                 | Enabled  | Shows all placed instances.                                                                       |
| Selected Instance Flylines <sup>(1)</sup> | Disabled | Shows flylines representing the net connections of selected instances (in the ACE selection set). |
| Clock Nets                                | Enabled  | Shows all clock nets.                                                                             |
| Non-clock Nets                            | Enabled  | Shows all non-clock nets.                                                                         |
| Routing Status                            |          |                                                                                                   |

| Option                          | Default  | Description                                                                                                                                                                                                                                                                                                                                                                     |
|---------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Open Connections <sup>(2)</sup> | Disabled | Toggles the display of open portions of a net. Open<br>connections are displayed in the same color as the routed<br>portion of a net, but with a dotted line instead of a solid<br>line. Open connections are a subset of a normal net, and<br>are thus also managed by the layer options for <b>Non-clock</b><br><b>Routes, Clock Routes</b> , and <b>Route Drawing Mode</b> . |
| Open Pins                       | Disabled | Toggles the display of squares highlighting the pins (red<br>by default) at the endpoints of open connections.                                                                                                                                                                                                                                                                  |
| Overflows                       | Disabled | Toggles the display of diamonds highlighting pins (orange<br>by default) where route overflows occur (this is very rare).                                                                                                                                                                                                                                                       |
| Pins                            | Disabled | Shows all pins on each site.                                                                                                                                                                                                                                                                                                                                                    |
| Sites                           | Enabled  | Shows all the sites on the device.                                                                                                                                                                                                                                                                                                                                              |

#### **Table Notes**

- 1. The displayed flylines are filtered by the **Non-clock Routes** and **Clock Routes** layer checkboxes. If only **Clock Routes** is checked, then only the flylines for clock nets of the selected instance(s) are displayed.
- 2. **Caution:** Dotted lines, as used for open connections, are much slower to render than solid lines. Thus, it is recommended that open connections remain disabled unless they are specifically needed for debugging purposes.

#### (i) Note

#### **Open Connections and Open Pins**

When displaying an open connection for a placed instance, if the specific source and/or sink pins are not yet known (or not yet specified by the router), the connection is rendered to/from the center of the placed instance instead of to/from a specific pin. Likewise, when specific pins are not known, the **Open Pins** squares (red by default) are rendered in the center of the placed instance instead of on a specific pin (open connections and open pins are not, of course, rendered for unplaced instances).

Be aware that in a placed design that has not yet been routed, all nets are considered open connections.

Enabling **Open Pins** can make it much easier to find unrouted portions of a mostly routed design when zoomed out. But be aware this might be overwhelming on a large design that has been placed but not yet routed.

Every unrouted net is considered open. Thus, in an unrouted design, every endpoint of every net displays an open pin square, merging into a single large mass of color when zoomed out.

#### 🕑 Tip

#### **Objects in the ACE Selection Set Are Always Visible**

By default, any/all objects in the current ACE selection set (as shown in the **Selection view** (page 137)) are always visible in the Floorplanner, regardless of the chosen "Layers" filter settings. This means even if the **Instances** layer is disabled, any Instances in the current ACE selection set are still painted in the selected instances color (by default, bright green). Details of this behavior can be configured on the **Floorplanner** view colors and layers preference page (page 198).

In addition to the layers listed in the table, there are several other types of information displayed in the Floorplanner — enabling and disabling the display of these other types of information is controlled from other views. For example, the visibility of individual clock regions is controlled from the Clock Regions view (page 25); the visibility of individual Placement regions is controlled from the Placement Regions view (page 114); and the visibility of individual critical paths is controlled from the Critical Paths view (page 39).

#### Highlighting

Special colored highlighting of objects in the Floorplanner is possible via Tcl (see the **highlight** (page 665) Tcl command) and/or may be triggered via associated highlighting actions in most of the other views in the Floorplanner perspective. Highlighted objects are only visible in the Floorplanner if the appropriate layer is enabled, and the highlight color is only used if the object is not currently a member of the ACE selection set.

By default, the selection color takes precedence over the highlight color, which in turn takes precedence over the default color of the object. Further information about precedence of these states for instances can be found under Instance states (page 262), and can be partially reconfigured in the Floorplanner view colors and layers preference page (page 198). Additional information regarding highlighting can be found at Highlighting Objects in the Floorplanner View (page 342).

#### Selection

The ( 🗟 ) Selection Options control the selection of objects with the mouse in the Floorplanner view. Selected objects are added to the ACE selection set, and displayed appropriately in the Selection view (page 137).

| Option    | Default  | Description                                                                                                                           |
|-----------|----------|---------------------------------------------------------------------------------------------------------------------------------------|
| Instances | Enabled  | Enables visible instances to be selected. If not checked, instances in the selection region are not added to the ACE selection set.   |
| Nets      | Enabled  | Enables visible nets to be selected. If not checked, nets in the selection region are not added to the ACE selection set.             |
| Pins      | Disabled | Enables visible user design pins to be selected. If not checked, pins in the selection region are not added to the ACE selection set. |

#### Table 26• Selection Options

| Option           | Default  | Description                                                                                                                                                   |
|------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Paths            | Disabled | Enables visible paths to be selected. If not checked, paths in the selection region are not added to the ACE selection set.                                   |
| Sites            | Disabled | Enables visible sites to be selected. If not checked, sites in the selection region are not added to the ACE selection set.                                   |
| Action           |          |                                                                                                                                                               |
| Select           | Enabled  | Controls the action applied to objects in the selection region. Causes the objects to be added to the current ACE selection set.                              |
| Deselect         | Disabled | Controls the action applied to objects in the selection<br>region. Causes the objects to be removed from the current<br>ACE selection set.                    |
| Remove Placement | Disabled | Controls the action applied to enabled objects in the selection region. Causes the placed instances to be unplaced.                                           |
| Fix Placement    | Disabled | Controls the action applied to enabled objects in the selection region. Causes the soft-placed instances to attempt to have fixed placement at the same site. |
| Un-fix Placement | Disabled | Controls the action applied to enabled objects in the selection region. Causes any fixed-placed instances to change to soft placement at the same site.       |

#### (i) Note

If **Instances** is checked under **Selection** but not under **Layers**, it is not possible to perform selection actions upon instances in the Floorplanner view using the mouse. For example, selection actions may be performed on only clock routes or only non-clock routes as desired, by simply setting the **Layers** filters appropriately.

## Placement

The ( 👆 ) Placement Options control the drag-and-drop placement behavior in the Floorplanner view.

#### Table 27 • Placement Options

| Option          | Default  | Description                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Group Placement | Disabled | [Expert Functionality] Controls whether single instances or<br>groups of instances are placed with the drag-and-drop action of<br>the Placement tool. Requires a group of instances to be in the<br>ACE Selection Set prior to initiating drag and drop. The Group<br>Placement option only succeeds in very specific circumstances,<br>thus this setting should only be enabled by expert users who<br>understand the caveats. |
| Fixed Placement | Enabled  | Controls whether the drag-and-drop placement of an instance<br>should be considered fixed or soft. Fixed placements are not<br>changed by the placer. Soft placements are taken as a<br>placement hint and might be changed by the placer.                                                                                                                                                                                      |

#### 👍 Caution

When pre-placing objects (for a pre-placement constraints .pdc file), **Fixed Placement** should always be enabled.

## Tool Tip Text

The (🖙) Tooltip options control the tooltip content while hovering over visible objects in the Floorplanner view.

#### Table 28Tooltip Options

| Option         | Default  | Description                                                                                                             |
|----------------|----------|-------------------------------------------------------------------------------------------------------------------------|
| Allow Tooltips | Enabled  | Allows enabling/disabling Tooltip support for the Floorplanner without needing to toggle all the individual checkboxes. |
| Instance Names | Enabled  | Includes the names of all placed instances under the current mouse position in the tooltip text.                        |
| Port Names     | Enabled  | Includes the RTL port names of placed instances under the current mouse position in the tooltip text.                   |
| Net Names      | Enabled  | Includes all net names under the current mouse position in the tooltip text.                                            |
| Pin Names      | Disabled | Includes all user design pin names under the current mouse position in the tooltip text.                                |

| Option                             | Default  | Description                                                                                                     |
|------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------|
| Site Names                         | Enabled  | Includes all leaf site names under the current mouse position in the tooltip text.                              |
| Site Types                         | Enabled  | Includes the site cell type of each leaf site under the current mouse position in the tooltip text.             |
| Site Pin Names                     | Disabled | Includes all site pin names under the current mouse position in the tooltip text.                               |
| Device Port Names                  | Enabled  | Includes the top-level port names of the target device<br>under the current mouse position in the tooltip text. |
| Subtile Coordinates <sup>(1)</sup> | Enabled  | Includes the subtile coordinates under the current mouse position in the tooltip text.                          |
| Partition Names                    | Enabled  | Includes all partition names under the current mouse position in the tooltip text.                              |
| Clusters                           | Enabled  | Includes the name of the cluster under the current mouse position in the tooltip text.                          |

#### **Table Notes**

1. Subtile Coordinates may be used with placement region commands on the Tcl command line.

#### (i) Note

#### **Tooltips Are Filtered by Layers Visibility**

If **Instance Names** is checked under "Tool Tip Text" but **Instances** is not checked under "Layers", it is not possible to see instance names in the tooltips.

#### Label

The ( 🗐 ) Label options control the text labels on objects in the Floorplanner view.

#### Table 29 · Label Options

| Option         | Default  | Description                                      |
|----------------|----------|--------------------------------------------------|
| None           | Enabled  | Disables the label display.                      |
| Instance Names | Disabled | Displays the instance names on placed instances. |

| Option            | Default  | Description                                                                       |
|-------------------|----------|-----------------------------------------------------------------------------------|
| Port Names        | Disabled | Displays the RTL port names on placed instances.                                  |
| Site Names        | Disabled | Displays the full site names on each leaf site.                                   |
| Site Types        | Disabled | Displays the site cell type on each leaf site.                                    |
| Device Port Names | Disabled | Displays the top-level port names of the target device connected to the I/O site. |

# Flow View

The Flow view provides a hierarchical view of Flow steps (page 235) that can be performed on the Active Project and Implementation (page 231). From here, flow steps can be run and flow status (page 243) viewed. Flow steps are not able to run unless an active implementation is selected in the Projects view (page 120). When running flow steps, the implementation options (page 100) of the active implementation are used to govern the behavior of the flow. Be aware that altering the value of an implementation option clears the flow state of all downstream flow steps, changing them from the Complete state back to Incomplete.

By default, the Flow view is included in the **Projects perspective** (page 6). To add it to the current perspective, click **Window**  $\rightarrow$  **Show View**  $\rightarrow$  **Other...**  $\rightarrow$  **Achronix**  $\rightarrow$  **Flow**.

For more details, see the Flow concept (page 235) and the tasks for Running the Flow (page 305).



Figure 18 • Flow View Example

| Table 30 • Flow View Icons | Table 3 | ) · Flow | View | lcons |
|----------------------------|---------|----------|------|-------|
|----------------------------|---------|----------|------|-------|

| State      | Flow Category | Flow Step |
|------------|---------------|-----------|
| Incomplete | θ             | <b>A</b>  |
| Running    | O             | O         |
| Complete   | θ             | ~         |
| Disabled   | θ             | ۸         |
| Warning    | 1             | <u>^</u>  |
| Error      | ×             | ×         |

### (i) Note

If the (1) icon appears on a Flow category or Flow step, this typically means ACE has detected changes to project source files, where the current source files on disk no longer match the design currently in memory. See **Detecting Changes to Project Source Files** (page 323).

#### Table 31 • Flow View Actions

| lcon     | Action                                      | Toolbar Button | Context Menu | Description                                                                                                                                                                                                                                                                                                     |
|----------|---------------------------------------------|----------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | Run Flow                                    | Y              |              | Runs all the enabled flow steps sequentially from the beginning of the flow.                                                                                                                                                                                                                                    |
|          | Resume Flow                                 | Y              |              | Resumes running the flow from the last completed<br>flow step. If no flow steps have been attempted<br>yet, this action behaves identically to <b>Run Flow</b> .                                                                                                                                                |
| -        | Show Multiprocess View                      | Y              |              | Launches the Multiprocess View (page 75), which allows managing multiple runs of the flow in parallel.                                                                                                                                                                                                          |
|          | Stop flow <sup>(1)</sup>                    | Y              | Y            | Stops the execution of any flow steps after the currently running flow step. Also attempts to interrupt the currently running flow step if possible.                                                                                                                                                            |
| Þ.       | Run Selected Flow Step <sup>(2)</sup>       |                | Y            | Runs the selected flow step, also running any<br>required preceding flow steps that have not yet<br>run. Preceding flow steps that are enabled but not<br>required are skipped.                                                                                                                                 |
| <b>N</b> | Re-Run Flow                                 |                | Y            | Runs all the enabled flow steps sequentially from the beginning of the flow. Behavior is now identical to <b>Run Flow</b> .                                                                                                                                                                                     |
|          | Re-Run Flow with -ic<br>init <sup>(3)</sup> |                | Y            | Behaves identically to <b>Re-Run Flow</b> , unless<br>Incremental Compilation is enabled. If Incremental<br>Compilation is enabled, this additionally forces a<br>full recompile of all partitions; any prior partition<br>state is ignored (and overwritten).                                                  |
|          | Clear Flow <sup>(4)</sup>                   |                | Y            | Issues a clear_flow (page 617) TCL command. All flow<br>categories and flow steps with the state of<br>Complete or Error are reset to the state of<br>Incomplete. Additionally, the state of the current<br>active project and implementation are cleared, as<br>if they had not yet been run through the flow. |
| ۵.       | Create Flow Step <sup>(5)</sup>             |                | Y            | Displays an interactive dialog for creating a user-<br>defined flow step (the dialog includes a prompt for<br>which a single Tcl command should be invoked for<br>this step) at the selected location within the flow.                                                                                          |

| lcon | Action           | Toolbar Button | Context Menu | Description                                                                                                                                                                             |
|------|------------------|----------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4.   | Remove Flow Step |                | Y            | Removes a selected user-defined flow step. Only<br>steps the user has created with <b>Create Flow Step</b><br>may be removed; this action cannot be used to<br>remove "reserved" steps. |

#### Table Notes

- 1. Some flow steps, such as FPGA Download, are currently unable to be interrupted while running.
- 2. Double-clicking a flow step is equivalent to this action.
- 3. Caution: This action is only relevant when using Incremental Compilation (Partitions) (page 404). If Incremental Compilation is disabled, this action behaves identically to Re-Run Flow.
- 4. Clear Flow does not remove any prior saved state from the hard drive. Any prior saved state may subsequently be (re-)loaded, including any partition state for incremental compilation.
- 5. Caution: Creation of user-defined flow steps is only recommended for advanced users.

#### ▲ Warning!

#### **Current Flow Mode Setting Impacts Which Flow Steps Are Executed**

The implementation option for Flow Mode (page 243) affects which flow steps are executed during the **Run** Flow, **Resume Flow**, **Re-Run Flow**, and **Re-Run Flow** using -ic init actions (or related Tcl commands).

If warnings or errors are encountered while a flow step is running, they appear in the Flow view next to the name of the flow step where they occurred.

The colors used for the warning and error text are the same as those used to display warnings and errors in the Tcl Console view (page 146). They can be adjusted through the Colors and Fonts link on the Tcl Console Preference Page (page 219).

| Not Flow X                               |    |  | 000 |  |
|------------------------------------------|----|--|-----|--|
| 👻 🔳 🚺 IP Configuration                   |    |  |     |  |
| 🗆 🔺 Generate All IP Design Files         |    |  |     |  |
| 👻 🔳 🚱 RTL Simulation                     |    |  |     |  |
| 🗹 🖋 Run RTL Simulation                   |    |  |     |  |
| 👻 🔳 🗐 Synthesis                          |    |  |     |  |
| 🗹 🖋 Run Synthesis                        |    |  |     |  |
| 🛛 🔺 Run Gate-level Netlist Simulation    |    |  |     |  |
| 👻 🔳 💢 Place and Route                    |    |  |     |  |
| 🔳 💢 Run Prepare [1 warnings, 4 errors]   |    |  |     |  |
| 🔳 🔺 Run Place                            |    |  |     |  |
| 🛛 🔺 Run Post-Placement Timing Analysis   |    |  |     |  |
| 🔳 🔺 Run Route                            |    |  |     |  |
| 🗹 🔺 Run Post-Route Timing Analysis       |    |  |     |  |
| 🗆 🔺 Generate Post-Route Simulation Netli | st |  |     |  |
| 🔲 🔺 Run Post-Route Netlist Simulation    |    |  |     |  |
| 👻 🔳 💽 Design Completion                  |    |  |     |  |
| 🔳 🔺 Post-Process Design                  |    |  |     |  |
| 🔳 🔺 Run Final DRC Checks                 |    |  |     |  |
| 🗹 🔺 Run Sign-off Timing Analysis         |    |  |     |  |
| 🗹 🔺 Generate Final Reports               |    |  |     |  |
| 🗆 🔺 Generate Final Simulation Netlist    |    |  |     |  |
| 🔲 🔺 Run Final Netlist Simulation         |    |  |     |  |
| 👻 🔳 💿 FPGA Programming                   |    |  |     |  |
| 🗹 🔺 Generate Bitstream                   |    |  |     |  |
| 🗆 🔺 FPGA Download                        |    |  |     |  |
|                                          |    |  |     |  |

Figure 19 • Flow View Warnings and Errors Example

Clicking the colored "warning" or "error" text brings up a dialog listing all problems.

Clicking any of the problems in the list opens the corresponding log file in an editor, scrolled to the location of the problem in question.

| Problems and Warnings - Run Prepare                                                                  |              | ×   |
|------------------------------------------------------------------------------------------------------|--------------|-----|
| Click on a problem or warning to view it in the log file.                                            |              |     |
| Click on OK or hit the ESCAPE key to dismiss.                                                        |              |     |
| No synth device found!                                                                               |              |     |
| Netlist synthesized with Synplify-Pro version 2016.3. ACE does not support Synplify-Pro versions old | er than 2021 | .3. |
| C:/code/quickstart_broken_on_purpose/quickstart.vma(44): port inb1 is not defined                    |              |     |
| C:/code/quickstart_broken_on_purpose/quickstart.vma(210): net inb1[1] not found in cell quickstart   |              |     |
| C:/code/quickstart_broken_on_purpose/quickstart.vma(216): net inb1[0] not found in cell quickstart   |              |     |
| C:/code/quickstart_broken_on_purpose/quickstart.vma(270): net inb1[3] not found in cell quickstart   |              |     |
| C:/code/quickstart_broken_on_purpose/quickstart.vma(276): net inb1[2] not found in cell quickstart   |              |     |
| Design Preparation failed                                                                            |              |     |
|                                                                                                      |              |     |
|                                                                                                      | OK           | :   |

Figure 20 • Warning and Error List Dialog Example

# HW Demo View

#### 🔒 Warning!

 $\cdot$  The JTAG connection must be configured before using the HW Demos.

ACE interacts with the FPGA using the JTAG interface through a Bitporter pod or FTDI FT2232H device. This JTAG interface must be properly configured in ACE before using the HW Demo functionality. The configuration is managed using the **Configure JTAG Connection Preference Page** (page 193). See **Configuring the JTAG Connection** (page 359) for more details.

# The DCC connection must be configured before using the HW Demos. ACE interacts with the HW Demo designs (and reference designs) using the DCC interface to the FPGA through a USB cable (not the Bitporter). This interface must be properly configured in ACE before using the HW Demo functionality. The configuration is managed using the Configure DCC Connection Preference Page (page 192). See Configuring the DCC Connection (page 357) for more details.

The HW Demo view provides a graphical interface for demonstrating particular aspects of a user selected device, using provided sample designs. These sample designs are typically provided as self-documenting overlays for the standard ACE installation.

By default, the HW Demo view is included in the HW Demo Perspective (page 6). To access the HW Demo view from any other perspective, select Window  $\rightarrow$  Show View  $\rightarrow$  Other...  $\rightarrow$  Achronix  $\rightarrow$  HW Demo.

Before any demo overlays are installed, there are no demo designs available. In that case, the view will display minimal information:

| 🖶 HW Demo 🛛    |                                                                         | ° 🗆     |
|----------------|-------------------------------------------------------------------------|---------|
|                | on and Download<br>ionstration design and download it to the chip.      | *<br>11 |
| Target Device: | No Demos Designs Installed 📼                                            |         |
| Demo Design:   | No Demo Designs Installed 🛛 👻                                           |         |
| Download       | Bitstream File: N/A Created: N/A                                        |         |
| 🝷 Demo Control | and Status - Not Available                                              |         |
|                | ill include custom controls and status for the once demos are installed |         |
|                |                                                                         | · ·     |

Figure 21 • HW Demo View with No Demo Designs Example

After demos are installed as ACE overlays, from this view the status of various board components can be observed updating in real-time as the demonstration design is running on the connected board. For example, in a basic fabric demonstration, when an associated DIP switch is changed, it is reflected in the view display; likewise when an LED on the board changes state (on/off) it is reflected in the view. Individual memory locations may be read and examined, and new values may be entered and "pushed" out to the target device.

Most hardware demos (including reference designs) are designed to show the features of the various hard IP blocks integrated into the target Achronix FPGA. Each demo or reference design installation package comes with associated documentation specific to the design.

Talk to your Achronix Marketing contact or FAE to request access to the demos appropriate to your development board.

See also: Running the HW Demo (page 401).

#### Table 32 • HW Demo View Toolbar Buttons

| lcon       | Action                   | Description                                                                                     |
|------------|--------------------------|-------------------------------------------------------------------------------------------------|
| 4>         | Configure DCC Interface  | Opens the preferences dialog to the <b>Configure</b> DCC Connection Preference Page (page 192). |
| <b>₽</b> 0 | Configure JTAG Interface | Opens the preferences dialog to the Configure JTAG Connection Preference Page (page 193).       |

#### Table 33 • HW Demo View Options

| Option                      | Description |
|-----------------------------|-------------|
| Demo Selection and Download |             |

| Option                  | Description                                                                                                                                                                                                                                                                                  |  |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Target Device           | List of FPGA devices that have demonstration designs.                                                                                                                                                                                                                                        |  |
| Demo Design             | ist of demonstration designs for the currently selected device.                                                                                                                                                                                                                              |  |
| Download                | oads the currently selected demonstration design into the attached board.                                                                                                                                                                                                                    |  |
| Board Status            |                                                                                                                                                                                                                                                                                              |  |
| LED State               | Visually represents relevant LEDs from the attached board. When an LED changes state on the board, it is reflected in the view LED display. Clicking an individual LED in the view causes the corresponding LED on the attached board to toggle its state.                                   |  |
| DIP Switch State        | Visually represents the eight DIP switches from the attached board. When a switch changes state on the board, it is reflected in the DIP switch display. Clicking an individual switch in the view does <i>not</i> cause the corresponding switch on the attached board to toggle its state. |  |
| Device State            | Displays DCC connection status and demo version number.                                                                                                                                                                                                                                      |  |
| Demo Control and Status |                                                                                                                                                                                                                                                                                              |  |

Each specific demonstration design has a simple user interface that is presented in the bottom section of the view. An example interface might provide a facility for reading and writing values to user specified addresses.

#### (i) Note

The Board Status section might not be present in all HW Demo (and reference) designs.

# I/O Designer Toolkit Views

The I/O Designer Toolkit views provide a set of fully-integrated I/O ring design tools. With these tools it is possible to:

- · Combine I/O ring IP configuration (.acxip) files into a complete I/O ring design
- View and update dynamic I/O ring resource utilization
- · View and update (using drag and drop) dynamic I/O ring floorplan layout
- View dynamic I/O ring package ball layout and pin assignment report
- Automatically complete the following in real time:
  - Full I/O ring final DRC
  - Full I/O ring timing closure
  - Full I/O ring place and route

- · Generate complete package ball pin assignment, power, and utilization reports
- Generate a full I/O ring simulation model that is 100% correctly configured, and has wrappers tailored specifically to the user design
- · Generate pin placements PDC, Verilog wrappers, and port lists for the core user design
- Generate the full I/O ring bitstream
- Quickly and easily combine existing I/O ring IP configuration (.acxip) files from an existing ACE project into new ACE projects to create multiple designs

#### Caution!

The I/O Designer views and features are only applicable to specific Achronix Speedster7t FPGAs, such as the Speedster7t AC7t1500.

## I/O Designer Toolkit Views

The views in the I/O Designer Toolkit are:

- I/O Utilization View (page 64)
- I/O Package Diagram View (page 65)
- I/O Pin Assignment View (page 66)
- I/O Core Pin Assignment View (page 66)
- I/O Layout Diagram View (page 68)

# I/O Ring Design File Generation

Clicking the ( Ring Design Files toolbar button opens the Generate I/O Ring Design Files Dialog (page 175), which allows selection of the output directory for all the customized I/O ring design files, including:

- · Complete package ball pin assignment, power, and utilization reports
- · Pin placements PDC, Verilog wrappers, and port lists for the core user design
- The full I/O ring bitstream, which is automatically combined with the core user design bitstream in ACE at the end of the normal place-and-route flow for the core user design
- · Customized I/O ring simulation files, including Verilog wrappers for the top-level and I/O ring configuration data

#### (i) Note

#### **Batch Mode Support**

I/O ring design files may also be generated in batch mode for a given ACE project by calling the generate\_ioring\_design\_files (page 641) Tcl command. This command loads up all the I/O ring IP configuration (.acxip) files from an existing ACE project, and performs full design rule checks prior to generating the output files. I/O ring IP configuration files can also be edited in a text editor to support batch mode configuration prior to calling the generate\_ioring\_design\_files Tcl command.

#### Table 34 · I/O Designer Toolbar Buttons

| lcon | Description                                                                                                                                                     |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Opens the Generate I/O Ring Design Files Dialog (page 175), which allows selecting the directory into which the customized I/O ring design files are generated. |

See also Creating an IP Configuration (page 335) and Adding Source Files (page 296).

# I/O Utilization View

The I/O Utilization view provides a combined utilization summary of the active ACE project I/O ring IP configuration (.acxip) files, including shared resources such as clocks. Each resource type is summarized in a table inside an expandable section. These tables can be used for navigating between various IP configuration files in the project. Configuration errors are also summarized in the Status column for each row. Right-clicking a row brings up a context menu of actions that can be performed on the IP in that row. Double-clicking the table row opens the source IP configuration file for the data in that row.

| Clocks 3/    | 32           |           |                 |               |                            |             |           |                |    |
|--------------|--------------|-----------|-----------------|---------------|----------------------------|-------------|-----------|----------------|----|
| PLLs 3/12    |              |           |                 |               |                            |             |           |                |    |
| Status       | PLL Name     | Placement | Input Clock     | Input Clo     | Input Clock Fr Output 0 Cl |             | lock      | Output 0 Clock | Ou |
| <b>~</b>     | PLL_FLAMES   | PLL_NE_0  | CLK_OVECHKIN    | 100.0 MI      | 100.0 MHz PLL_FLAME        |             | S_clkout0 | 200.0 MHz      | N/ |
| <b>v</b>     | PLL_JETS     | PLL_SE_0  | PLL_FLAMES_clko | out0 200.0 MI | z PLL_JETS_c               |             | kout0     | 1000.0 MHz     | N/ |
| <b>V</b>     | PLL_OILERS   | PLL_NW_0  | PLL_FLAMES_clko | out0 200.0 MI | Ηz                         | PLL_OILERS  | _clkout0  | 1000.0 MHz     | N/ |
| SerDes 1     | 5/32         |           |                 |               |                            |             |           |                |    |
| PCI Expre    | ss 1/2       |           |                 |               |                            |             |           |                |    |
| Status       | Name         | Placement | PCle Version    | Number of La. | . Оре                      | rating Mode | Device ID | Rev ID         |    |
| <b>V</b>     | PCIE_SHARKS  | PCIE_1    | Gen 5           | 8             | Dual-Mode                  |             | ABCD      | 01             |    |
|              | 4/2          |           |                 |               |                            |             |           |                |    |
| Ethernet     |              |           |                 |               |                            |             |           |                |    |
|              |              |           |                 |               | -                          | -           |           |                |    |
| Status       | Name         | Placement | Memory Device   | Mode          |                            | a Rate      |           |                |    |
| <b>V</b>     | GDDR_BEARS   | GDDR6_1   | MT61K256M3      | x16           | 12                         |             |           |                |    |
| <b>V</b>     | GDDR_LIONS   | GDDR6_2   | MT61K256M3      | x16           | 16                         |             |           |                |    |
| $\checkmark$ | GDDR_PACKERS | GDDR6_3   | MT61K256M3      | x16           | 12                         |             |           |                |    |
| <b>V</b>     | GDDR_VIKINGS | GDDR6_0   | MT61K256M3      | x16           | 14                         |             |           |                |    |
|              |              |           |                 |               |                            |             |           |                |    |

Figure 22 • I/O Designer View (Utilization Tab)

| Table 35 | <ul> <li>I/O Designer</li> </ul> | View Actions |
|----------|----------------------------------|--------------|
|----------|----------------------------------|--------------|

| lcon | Action                 | Description                                                                              |
|------|------------------------|------------------------------------------------------------------------------------------|
| Þ    | Open IP                | Opens the selected IP file in an editor within ACE.                                      |
| -    | Clone IP               | Creates a duplicate of the selected IP and adds it to the project.                       |
| *    | Rename IP              | Renames the selected IP.                                                                 |
| ж    | Remove IP from project | Allows removal of the selected IP project. See also remove_project_ip (page 675).        |
|      | Show in file manager   | Opens the operating system default file manager to the directory containing the IP file. |

# I/O Package Diagram View

The I/O Package Diagram view shows a live diagram of the target package balls and all I/O ring user design top-level pin ball assignments. Click and drag to pan the diagram and use the mouse wheel to zoom in and out. Package balls with yellow fill indicate placed user design pins on those package balls. Tooltip text provides extra information about each package ball location.



Figure 23 • I/O Package Diagram View

## I/O Pin Assignment View

The I/O Pin Assignment view shows a live table of I/O ring user design top-level pin assignment information, including user design port name, I/O bank, package ball, top-level device port name, and pad/macro site name (for debugging in the full-chip simulation hierarchy). Columns can be sorted by left-clicking on the column headers. Columns can be filtered using the **Toggle Filter Row Visibility** button.

| Jsed | Port Name                          | Remapped Name | Direction | Bank            | Ball         | Device Port                | Pad/Macro Site                                     | Site Polarity | Clock Canable Site | Recet Canable Site | Data Capable Site | Used as Clock | Used as Reset |
|------|------------------------------------|---------------|-----------|-----------------|--------------|----------------------------|----------------------------------------------------|---------------|--------------------|--------------------|-------------------|---------------|---------------|
| V    | BACKSTROM pad n                    | Remapped Name | IN        | BANK GPIO SO BY | BL8          | GPIO SO BYTEO BIT 5        | u_gpio_phy_h_36_top_s0.u                           | N             | V                  | N                  | N                 | V             | N             |
| ~    | BACKSTROM_pad_n<br>BACKSTROM pad_p |               | IN        | BANK GPIO S0 BY | BK9          | GPIO_S0_BYTE0_BIT_5        | u_gpio_phy_h_36_top_s0.u                           | P             | v                  | N                  | N                 | v             | N             |
| ~    | CLK_OVECHKIN_pad_n                 |               | IN        | BANK CLKIO NE   | N17          | CLKIO NE REFIO N 0         | u_glb_clk_rst_gen_top_ne.u                         | N             | v                  | v                  | N                 | v v           | N             |
| ~    | CLK OVECHKIN pad p                 |               | IN        | BANK CLKIO NE   | N16          | CLKIO NE REFIO P 0         | u glb clk rst gen top ne.u                         | D             | v                  | v                  | N                 | v             | N             |
| ~    | DATA HOLTBY_pad_n                  |               | IN        | BANK GPIO NO B  | AH17         | GPIO_N0_BYTE1_BIT_3        | u gpio phy v 36 top n0.u                           | N             | N                  | N                  | v                 | N             | N             |
| ~    | DATA_HOLTBY_pad_p                  |               | IN        | BANK_GPIO_N0_B  | AG16         | GPIO_N0_BYTE1_BIT_2        | u_gpio_phy_v_36_top_n0.u                           | P             | N                  | N                  | v                 | N             | N             |
| ~    | DDR4 BRUINS a17                    |               | INOUT     | BANK DDR4 S0    | BB25         | DDR4 S0 A17                | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | v                 | N             | N             |
| ~    | DDR4_BRUINS_a[0]                   |               | INOUT     | BANK DDR4_S0    | BB25<br>BJ27 | DDR4_S0_A17<br>DDR4_S0_A_0 | u_ddr4_sdram_sys_top_s0<br>u ddr4 sdram svs top s0 |               | N                  | N                  | Y V               | N             | N             |
| ~    |                                    |               |           |                 |              |                            |                                                    |               |                    | N                  | Y Y               | N             | N             |
|      | DDR4_BRUINS_a[10]                  |               | INOUT     | BANK_DDR4_S0    | BJ28         | DDR4_S0_A_10               | u_ddr4_sdram_sys_top_s0                            |               | N                  |                    | Y                 |               |               |
| ~    | DDR4_BRUINS_a[11]                  |               | INOUT     | BANK_DDR4_S0    | BK25         | DDR4_S0_A_11               | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  |                   | N             | N             |
| ~    | DDR4_BRUINS_a[12]                  |               | INOUT     | BANK_DDR4_S0    | BE25         | DDR4_S0_A_12               | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Y                 | N             | N             |
| ~    | DDR4_BRUINS_a[13]                  |               | INOUT     | BANK_DDR4_S0    | BH30         | DDR4_S0_A_13               | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Y                 | N             | N             |
| ~    | DDR4_BRUINS_a[1]                   |               | INOUT     | BANK_DDR4_S0    | BE27         | DDR4_S0_A_1                | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Y                 | N             | N             |
| ~    | DDR4_BRUINS_a[2]                   |               | INOUT     | BANK_DDR4_S0    | BH26         | DDR4_S0_A_2                | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Y                 | N             | N             |
| ~    | DDR4_BRUINS_a[3]                   |               | INOUT     | BANK_DDR4_S0    | BF26         | DDR4_S0_A_3                | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Y                 | N             | N             |
| ~    | DDR4_BRUINS_a[4]                   |               | INOUT     | BANK_DDR4_S0    | BK26         | DDR4_S0_A_4                | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Y                 | N             | N             |
| ~    | DDR4_BRUINS_a[5]                   |               | INOUT     | BANK_DDR4_S0    | BJ26         | DDR4_S0_A_5                | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Y                 | N             | N             |
| ~    | DDR4_BRUINS_a[6]                   |               | INOUT     | BANK_DDR4_S0    | BE26         | DDR4_S0_A_6                | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Y                 | N             | N             |
| ~    | DDR4_BRUINS_a[7]                   |               | INOUT     | BANK_DDR4_S0    | BL25         | DDR4_S0_A_7                | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Y                 | N             | N             |
| ~    | DDR4_BRUINS_a[8]                   |               | INOUT     | BANK_DDR4_S0    | BG25         | DDR4_S0_A_8                | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Y                 | N             | N             |
| ~    | DDR4_BRUINS_a[9]                   |               | INOUT     | BANK_DDR4_S0    | BF25         | DDR4_S0_A_9                | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Y                 | N             | N             |
| ~    | DDR4_BRUINS_act_n                  |               | INOUT     | BANK_DDR4_S0    | BL24         | DDR4_S0_ACT_N              | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Y                 | N             | N             |
| ~    | DDR4_BRUINS_ba[0]                  |               | INOUT     | BANK_DDR4_S0    | BK28         | DDR4_S0_BA_0               | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Y                 | N             | N             |
| ~    | DDR4_BRUINS_ba[1]                  |               | INOUT     | BANK_DDR4_S0    | BF28         | DDR4_S0_BA_1               | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Y                 | N             | N             |
| ~    | DDR4_BRUINS_bg[0]                  |               | INOUT     | BANK_DDR4_S0    | BG24         | DDR4_S0_BG_0               | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Y                 | N             | N             |
| ~    | DDR4_BRUINS_bg[1]                  |               | INOUT     | BANK_DDR4_S0    | BF24         | DDR4_S0_BG_1               | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Y                 | N             | N             |
| ~    | DDR4_BRUINS_bp_alert_n             |               | INOUT     | BANK_DDR4_S0    | BJ25         | DDR4_S0_BP_ALERT_N         | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Y                 | N             | N             |
| ~    | DDR4_BRUINS_bp_memreset_I          |               | OUT       | BANK_DDR4_S0    | BH24         | DDR4_S0_BP_MEMRESET_L      | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Y                 | N             | N             |
| ~    | DDR4_BRUINS_cas_n                  |               | INOUT     | BANK_DDR4_S0    | BL29         | DDR4_S0_CAS_N              | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Y                 | N             | N             |
| ~    | DDR4_BRUINS_cid[0]                 |               | INOUT     | BANK_DDR4_S0    | BJ30         | DDR4_S0_CID_0              | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Y                 | N             | N             |
| ~    | DDR4 BRUINS cid[1]                 |               | INOUT     | BANK DDR4 S0    | BF30         | DDR4 S0 CID 1              | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Ŷ                 | N             | N             |
| ~    | DDR4 BRUINS cid[2]                 |               | INOUT     | BANK DDR4 S0    | BC28         | DDR4 S0 CID 2              | u_ddr4_sdram_sys_top_s0                            |               | N                  | N                  | Y                 | N             | N             |
| ~    | DDR4 BRUINS ck n[0]                |               | INOUT     | BANK DDR4 S0    | BH27         | DDR4 S0 CK N 0             | u_ddr4_sdram_sys_top_s0                            | N             | × ×                | N                  | N                 | Y             | N             |

### Figure 24 • I/O Pin Assignment View

### Table 36 • I/O Pin Assignment View Buttons

| lcon        | Description                                                                         |
|-------------|-------------------------------------------------------------------------------------|
| <i>á</i>    | Generate I/O Ring Design Files.                                                     |
| <b>I</b> ØJ | Clear Sorting.                                                                      |
| <b>W</b>    | Toggle Filter Row Visibility.                                                       |
| 2           | Remap Port/Signal Name (available in <b>Remapped Name</b> column right-click menu). |

## I/O Core Pin Assignment View

The I/O Core Pin Assignment view shows a live table of I/O ring user design top-level core pin assignment information, including user design signal name, direction, data type, group, and core pin name. Columns can be sorted by left-clicking the column headers. Columns can be filtered using the **Toggle Filter Row Visibility** button.

| Signal Name               | Remapped Name | Direction | Data Type | Group                   | Core Pin Name           |   |
|---------------------------|---------------|-----------|-----------|-------------------------|-------------------------|---|
| BACKSTROM                 |               | IN        | Clock     | GPIO                    | i_user_10_00_mt_00[2]   |   |
| DATA_HOLTBY               |               | IN        | Data      | GPIO                    | i_user_11_09_lut_15[4]  |   |
| ETH_WILD_m0_ff_clk_divby2 |               | IN        | Clock     | Clocks and Resets       | i_user_02_09_mt_00[0]   |   |
| ETH_WILD_m0_pause_on      |               | IN        | Data      | 400G MAC 0 Flow Control | i_user_02_09_lut_14[27] |   |
| ETH_WILD_m0_pause_on      |               | IN        | Data      | 400G MAC 0 Flow Control | i_user_02_09_lut_14[25] |   |
| ETH_WILD_m0_pause_on      |               | IN        | Data      | 400G MAC 0 Flow Control | i_user_02_09_lut_15[1]  |   |
| ETH_WILD_m0_pause_on      |               | IN        | Data      | 400G MAC 0 Flow Control | i_user_02_09_lut_15[0]  |   |
| ETH_WILD_m0_pause_on      |               | IN        | Data      | 400G MAC 0 Flow Control | i_user_02_09_lut_14[24] |   |
| ETH_WILD_m0_pause_on      |               | IN        | Data      | 400G MAC 0 Flow Control | i_user_02_09_lut_15[4]  |   |
| ETH_WILD_m0_pause_on      |               | IN        | Data      | 400G MAC 0 Flow Control | i_user_02_09_lut_15[2]  | 1 |
| ETH_WILD_m0_pause_on      |               | IN        | Data      | 400G MAC 0 Flow Control | i_user_02_09_lut_15[5]  | 1 |
| TH_WILD_m0_rx_buffer0_at  |               | IN        | Data      | Buffer Levels           | i_user_02_09_lut_19[26] |   |
| TH_WILD_m0_rx_buffer0_at  |               | IN        | Data      | Buffer Levels           | i_user_02_09_lut_19[25] |   |
| TH_WILD_m0_rx_buffer0_at  |               | IN        | Data      | Buffer Levels           | i_user_02_09_lut_19[24] |   |
| TH_WILD_m0_rx_buffer0_at  |               | IN        | Data      | Buffer Levels           | i_user_02_09_lut_19[23] |   |
| TH_WILD_m0_rx_buffer1_at  |               | IN        | Data      | Buffer Levels           | i_user_02_09_lut_19[20] |   |
| TH_WILD_m0_rx_buffer1_at  |               | IN        | Data      | Buffer Levels           | i_user_02_09_lut_19[19] |   |
| TH_WILD_m0_rx_buffer1_at  |               | IN        | Data      | Buffer Levels           | i_user_02_09_lut_19[21] |   |
| TH_WILD_m0_rx_buffer1_at  |               | IN        | Data      | Buffer Levels           | i_user_02_09_lut_19[18] |   |
| TH_WILD_m0_rx_buffer2_at  |               | IN        | Data      | Buffer Levels           | i_user_02_09_lut_19[3]  |   |
| TH_WILD_m0_rx_buffer2_at  |               | IN        | Data      | Buffer Levels           | i_user_02_09_lut_19[4]  |   |
| TH_WILD_m0_rx_buffer2_at  |               | IN        | Data      | Buffer Levels           | i_user_02_09_lut_19[5]  |   |
| TH_WILD_m0_rx_buffer2_at  |               | IN        | Data      | Buffer Levels           | i_user_02_09_lut_19[6]  |   |
| TH_WILD_m0_rx_buffer3_at  |               | IN        | Data      | Buffer Levels           | i_user_02_09_lut_18[26] |   |
| TH_WILD_m0_rx_buffer3_at  |               | IN        | Data      | Buffer Levels           | i_user_02_09_lut_18[27] |   |
| TH_WILD_m0_rx_buffer3_at  |               | IN        | Data      | Buffer Levels           | i_user_02_09_lut_19[0]  |   |
| TH_WILD_m0_rx_buffer3_at  |               | IN        | Data      | Buffer Levels           | i_user_02_09_lut_19[1]  | - |
| TH_WILD_m0_tx_buffer0_at  |               | IN        | Data      | Buffer Levels           | i_user_02_09_lut_19[13] | - |
| TH_WILD_m0_tx_buffer0_at  |               | IN        | Data      | Buffer Levels           | i_user_02_09_lut_19[14] | - |
| TH_WILD_m0_tx_buffer0_at  |               | IN        | Data      | Buffer Levels           | i_user_02_09_lut_19[15] | - |
| TH_WILD_m0_tx_buffer0_at  |               | IN        | Data      | Buffer Levels           | i_user_02_09_lut_19[16] | 1 |
| TH_WILD_m0_tx_buffer1_at  |               | IN        | Data      | Buffer Levels           | i_user_02_09_lut_19[11] | - |

## Figure 25 • I/O Core Pin Assignment View

### Table 37 • I/O Core Pin Assignment View Buttons

| lcon     | Description                                                                         |
|----------|-------------------------------------------------------------------------------------|
| ¢        | Generate I/O Ring Design Files.                                                     |
| ø        | Clear Sorting.                                                                      |
| V2       | Toggle Filter Row Visibility.                                                       |
| <u>P</u> | Remap Port/Signal Name (available in <b>Remapped Name</b> column right-click menu). |

## I/O Layout Diagram View

The I/O Layout Diagram view shows an interactive floorplan of the target device. Empty IP Sites are shown in white. Sites with legally-placed IP are shown in green. Sites with IP placement overlap violations are shown in red.

IP can be moved from one site to another by dragging and dropping. IP can be cloned onto another compatible site by holding down the CTRL key while dragging and dropping. Double-clicking a placed IP opens an editor for that IP. Double-clicking an empty site opens the "Create new IP" dialog, preselecting the appropriate type of IP for that site, and placing the new IP at that site when the dialog is completed.

Changes to placement in the diagram result in updates to the source IP configuration (.acxip) files. Tooltip text provides extra information about each IP site. Right-clicking a site brings up a context menu of actions that can be performed on that site, or the IP placed on that site.



Figure 26 • I/O Designer View (Layout Tab)

### Table 38 • I/O Designer View Actions

| lcon | Action  | Description                                         |
|------|---------|-----------------------------------------------------|
| ß    | Open IP | Opens the selected IP file in an editor within ACE. |

| lcon | Action                              | Description                                                                                 |
|------|-------------------------------------|---------------------------------------------------------------------------------------------|
| ŵ    | Create new IP here                  | Creates a new IP at the chosen site.                                                        |
| -    | Clone IP                            | Creates a duplicate of the selected IP and adds it to the project.                          |
| *    | Rename IP                           | Renames the selected IP.                                                                    |
|      | Add IP to another project           | Adds the selected IP to another project in the ACE workspace.                               |
|      | Add copies of IP to another project | Adds a copy of the selected IP to another project in the ACE workspace.                     |
| ж    | Remove IP from project              | Allows removal of the selected IP project. See also <pre>remove_project_ip</pre> (page 675) |

By default, if one or more IP editors are currently open, the diagram is configured to display a yellow highlight indicating the currently active IP editor.



Figure 27 • I/O Layout Diagram View Currently Active Highlight Example

The I/O Designer page in the Preferences dialog box can be used to enable/disable the active editor highlight in the I/O Layout Diagram, and to configure how often acxip files are polled for external content changes.

| <ul> <li>Preferences</li> </ul>                                   | — D X                                                   |
|-------------------------------------------------------------------|---------------------------------------------------------|
| type filter text                                                  | I/O Designer                                            |
| Configure DCC Connection<br>Configure JTAG Connection             | See ' <u>Colors and Fonts</u> ' to configure the font.  |
| Critical Path Diagram View<br>Floorplanner View Colors and Layers | Show active editor highlight in I/O Layout Diagram view |
| Floorplanner View Optimizations <ul> <li>General</li> </ul>       | External file poll interval (secs) 5                    |
| Help<br>I/O Designer                                              |                                                         |
| > Java<br>Multiprocess                                            |                                                         |
| Netlist Browser<br>NoC Performance                                |                                                         |
| Placement Regions<br>Project Management                           |                                                         |
| Tcl Console View                                                  |                                                         |
| User Advanced Preferences                                         | Restore Defaults Apply                                  |
|                                                                   | Restore <u>D</u> efaults <u>A</u> pply                  |
|                                                                   | Apply and Close Cancel                                  |

### Figure 28 • I/O Designer Preference Page Example

There are also preferences available to manage the font and colors used within the I/O Layout Diagram.

| Preferences                                                                                                                                                                                                                                                                    | —                                                                                     | o x                                                                                                                    |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|
| type filter text                                                                                                                                                                                                                                                               | Colors and Fonts                                                                      | <b>↓ ·</b> ⇒ %                                                                                                         |
| Configure DCC Connection<br>Configure JTAG Connection<br>Critical Path Diagram View<br>Floorplanner View Colors and Layers<br>Floorplanner View Optimizations<br>General<br>Appearance<br>Colors and Fonts<br>Editors<br>Link Handlers<br>Quick Search<br>Help<br>I/O Designer | Colors and Eonts (font, size, type, ? = any character, * = any s'<br>type filter text | tring) :<br><u>E</u> dit<br><u>U</u> se System Font<br><u>R</u> eset<br>Ed <u>i</u> t Default<br><u>G</u> o to Default |
| <ul> <li>Java</li> <li>Multiprocess</li> <li>Netlist Browser</li> <li>NoC Performance</li> <li>Placement Regions</li> <li>Project Management</li> <li>Tcl Console View</li> <li>User Advanced Preferences</li> </ul>                                                           | Descriptio <u>n</u> : Previe <u>w</u> : No preview available. Restore Defaults        | Expand All                                                                                                             |
|                                                                                                                                                                                                                                                                                | Apply and Close                                                                       | Cancel                                                                                                                 |

Figure 29 • I/O Designer Color and Font Preferences Example

# IP Diagram View

The IP Diagram view provides a graphical visualization of the configuration of the IP currently being edited. As different IP configurations are selected via their editor, the IP Diagram view contents change to reflect the selected IP configuration.

Some IP supports multiple pages of diagrams (e.g., a logic block diagram page and a placement diagram page). In these cases, there are multiple labeled tabs at the bottom of the IP Diagram view to allow switching diagram pages. The following is an example of an IP diagram showing a din input and dout output indicating configuration errors:



### Figure 30 • Example IP Diagram Indicating Configuration Errors

When a supported IP Configuration editor is selected, the IP Diagram view shows a dynamic block diagram of the selected IP. Displayed labels change, and logic blocks may appear and disappear depending upon the configuration options currently selected in the IP editor. Tool tips are available on all text displayed in the IP Diagram. Text representing configuration options with warnings or errors are displayed with appropriate colors to indicate the condition.

By default, in the diagram, warnings have a yellow background and errors have a red background, though all colors and fonts used within the diagram may be overridden from the IP Diagram Color and Font Preferences Section (page

208), easily accessible from the ( <sup>\$</sup>) **Configure Colors and Fonts...** view menu item, found under the ( <sup>\$</sup>) vertical ellipsis menu button in the upper-right of the view.

Clicking any text label in the IP Diagram immediately turns the IP editor to the associated page, scrolls the associated option into view and gives it focus, so that the related configuration options may be edited.

#### See also: Creating an IP Configuration (page 335)

#### (i) Note

If the selected editor is not an IP Configuration editor, or if the selected IP does not support a diagrammatic visualization, the IP Diagram view displays a notice that there is no diagram available for the selected editor as shown in the following example.

| ្រុំ IP Diagram | ×                    |  |
|-----------------|----------------------|--|
|                 | No diagram available |  |

Figure 31 • Example IP Diagram View With Notice of No Available Diagram

# **IP** Libraries View

The IP Libraries view provides an alternate method for creating IP configuration .acxip files versus using the main menu, **File**  $\rightarrow$  **New**  $\rightarrow$  **IP Configuration...** The available IP listed varies depending on the current target device chosen for the active project or implementation. For example, targeted Speedster7t FPGAs have I/O ring IP choices displayed in their library tree, while Speedcore eFPGAs do not. Expanding a device family name (IP library) displays a list of available IP types for that family. Double-clicking the IP type or clicking the **Create New IP Configuration** button, opens the **new IP Configuration dialog** (page 180) to begin IP creation/configuration.



Figure 32 • IP Libraries View Example

#### (i) Note

The displayed IP libraries and IP types are dynamic; these change based on which technology libraries and devices are installed and licensed, and on which **Target Device** was chosen for the **active project and implementation** (page 231) when **configuring project and implementation options** (page 303). The screenshots and example descriptions in this section do not necessarily reflect the IP types of the actual target devices currently in use on the site.

### Table 39 • IP Libraries Toolbar Buttons

| lcon | Description                                                                                            |
|------|--------------------------------------------------------------------------------------------------------|
| 605  | Opens the <b>new IP configuration dialog</b> (page 180) to allow creating a new IP configuration file. |

See also: Creating an IP Configuration (page 335).

# **IP Problems View**

The IP Problems view displays all warnings and errors for all of the currently open IP Configuration editors.

The top half of the view displays a sorted tree table of all errors in order by IP configuration .acxip file, then all warnings in order by file. When an IP problem is selected in this tree table, further details about the problem are displayed under the tree table in the bottom half of the view.

Double-clicking an error or warning opens the relevant IP Configuration editor to the appropriate page. See also **Creating an IP Configuration** (page 335).

#### (i) Note

Unlike other IP-related views, this view shows information for all open IP Configuration editors, not just the top/active editor.

| Summary      |                                      | File                   | Property         |
|--------------|--------------------------------------|------------------------|------------------|
| ⊿ 🔕 Errors ( | 2)                                   |                        |                  |
| 😣 Ille       | gal Property Value: wrrst_input_mode | new_fifo1.acxip        | wrrst_input_mode |
| 😣 Ou         | t of Range Property Value: depth     | new_lram1.acxip        | depth            |
| 🔺 💧 Warnir   | igs (1)                              |                        |                  |
| 🎄 Inv        | alid File Name: mem_init_file        | new_rom1.acxip         | mem_init_file    |
| rror: Out of | Range Property Value: depth          |                        |                  |
| ile: C:/Use  | ers/Example/Documents/acx/hs1.1/quic | kstart/new_lram1.acxip |                  |
| roperty: dep | th                                   |                        |                  |

#### Figure 33 • IP Problems View Example

#### Table 40 • IP Problems View Icons

| lcon | Description |
|------|-------------|
| ٨    | Warning     |
| 8    | Error       |

### Table 41 · IP Problems View Table Columns

| Column Name | Description                                                                                    |
|-------------|------------------------------------------------------------------------------------------------|
| Summary     | A brief summary statement of the IP configuration problem.                                     |
| File        | The name of the IP Configuration file in an open IP Configuration editor containing the error. |

| Column Name | Description                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Property    | The property which is part of the IP Configuration problem. Individual properties are usually similar to the field names shown in the IP Configuration editor. The raw properties and their values can be viewed in the editor by selecting the <b>File Preview</b> tab at the bottom of each editor. The <b>Configuration</b> tab shows a more user-friendly representation of the same data. |

# **Multiprocess View**

Similar to the Tcl command, run\_multiprocess (page 693), the ( ) Multiprocess view allows running multiple flows in parallel (page 307) and attempting likely optimizations using option sets (page 392).

The Multiprocess view provides a means to select multiple **Implementations** (page 231) within a single **project** (page 224) for flow execution. Depending upon how this view is configured, the selected implementations may be queued for sequential flow execution, run all at the same time in parallel, or a combination of these in a configurable number of parallel sequential queues. The selected implementations may be executed in the background of the workstation running ACE, or optionally may be sent to an external cloud, grid or batch job system for execution.

The Multiprocess view may also help to explore the solution space provided by various ACE optimizations. The Multiprocess view can optionally generate new implementations derived from the current active project and implementation (page 231), where each newly generated implementation applies an overlay of likely implementation option (page 0) optimizations over the active implementation options. These collections of potentially optimized implementation options are termed "option sets (page 0)".

By default, the Multiprocess view is a part of the **Projects perspective** (page 6). To make the Multiprocess view visible from within any perspective, select **Window**  $\rightarrow$  **Show View**  $\rightarrow$  **Other...**  $\rightarrow$  **Achronix**  $\rightarrow$  **Multiprocess**.

This view is broken up into several sections:

- Execution Queue Management
- Multiprocess Flow Management
- Select Implementations
- Multiprocess Run Logs

Each section includes a brief descriptive paragraph describing its purpose. Each section may be collapsed and expanded by clicking the section title. Collapsing or expanding any section causes the other sections to be resized to fit the available data and view area.

For more detailed information on how to use this view, please see Running Multiple Flows in Parallel (page 307) and Attempting Likely Optimizations Using Option Sets (page 392).

| Options 🐚 Multiprocess 🖾                                                                                                                         |                                                                                                       |                                                                                                                                                                                                                                                                                                                          |
|--------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                  |                                                                                                       | · · · · · ·                                                                                                                                                                                                                                                                                                              |
| Execution Queue Management                                                                                                                       |                                                                                                       |                                                                                                                                                                                                                                                                                                                          |
| Configure the number of ACE project implet<br>background, or submitted to an external clo                                                        |                                                                                                       | imultaneously, and whether they are executed locally in the<br>tem.                                                                                                                                                                                                                                                      |
| Enable Job Submission System (configu                                                                                                            | red in Preferences)                                                                                   |                                                                                                                                                                                                                                                                                                                          |
| Parallel job count: 3 (valid range: 1-4                                                                                                          | )                                                                                                     |                                                                                                                                                                                                                                                                                                                          |
| Multiprocess Flow Management                                                                                                                     |                                                                                                       |                                                                                                                                                                                                                                                                                                                          |
|                                                                                                                                                  |                                                                                                       | multiprocess implementations should follow. Then, in the tations should run. (This provides a means of stopping the                                                                                                                                                                                                      |
| Stop Flow After: Run Post-Route Timing Ar                                                                                                        | nalysis 🗸 🗸                                                                                           |                                                                                                                                                                                                                                                                                                                          |
| Select Implementations                                                                                                                           |                                                                                                       |                                                                                                                                                                                                                                                                                                                          |
| created if they don't already exist, or will ove<br>button is pressed, the selected implementati<br>enabled, the user can optionally choose to c | erwrite existing implen<br>ions will run using the<br>opy the Incremental C<br>g the flow. This allow | queued for execution. (Option Set Implementations will be<br>nentations with the same name.) When the "Start Selected"<br>current Flow configuration. When Incremental Compile is<br>Compile DB file from the template (active) implementation t<br>s you to lock down the best results from a previous run and<br>npls. |
| Existing Implementations                                                                                                                         |                                                                                                       |                                                                                                                                                                                                                                                                                                                          |
| Generate Implementations from Option                                                                                                             | Sets Refresh Optio                                                                                    | n Sets                                                                                                                                                                                                                                                                                                                   |
| Seed Sweep of prime numbers 5                                                                                                                    |                                                                                                       |                                                                                                                                                                                                                                                                                                                          |
|                                                                                                                                                  |                                                                                                       |                                                                                                                                                                                                                                                                                                                          |
| Copy Incremental Flow DB From Templa                                                                                                             | ite impi                                                                                              |                                                                                                                                                                                                                                                                                                                          |
| Implementation                                                                                                                                   | Execution State                                                                                       | Description                                                                                                                                                                                                                                                                                                              |
| 🗹 🛄 impl_1                                                                                                                                       | 🜔 Running (0%)                                                                                        | The template implementation itself.                                                                                                                                                                                                                                                                                      |
| 🗹 🛄 impl_1_acx_all_opt                                                                                                                           | 😢 Error                                                                                               | This option set sets the pnr seed to 34, and evaluates mux                                                                                                                                                                                                                                                               |
| ✓ ↓ impl_1_acx_cls_pro_ext                                                                                                                       | Complete                                                                                              | This option enables fanout-based transformations, and Po                                                                                                                                                                                                                                                                 |
| impl_1_acx_cls_pro_seed                                                                                                                          | Zzz In Queue                                                                                          | This option set enables pre-placement netlist resynthesis,                                                                                                                                                                                                                                                               |
| ✓ ↓ impl_1_acx_cls_util                                                                                                                          | Stopped                                                                                               | This option set relaxes fanout-based optimization, enables                                                                                                                                                                                                                                                               |
| impl_1_acx_fan_pro_seed                                                                                                                          |                                                                                                       | This option set sets the pnr seed to 82, reduces fanout lim                                                                                                                                                                                                                                                              |
| 🔲 💭 impl_1_acx_fan_seed_util_bigblock                                                                                                            |                                                                                                       | This option enhances cloning, sets the pnr seed to seed 5                                                                                                                                                                                                                                                                |
| <                                                                                                                                                |                                                                                                       | >                                                                                                                                                                                                                                                                                                                        |
| Select All Deselect All                                                                                                                          | tart Selected 📃 St                                                                                    | op Stop All                                                                                                                                                                                                                                                                                                              |
| Multiprocess Run Logs                                                                                                                            | plamontation pro                                                                                      | re will be displayed here                                                                                                                                                                                                                                                                                                |
| The logged output from all the executed imp<br>() (0%)impl_1 & v impl_1_acx_cls_1                                                                |                                                                                                       | pl_1_acx_all_o Zzz impl_1_acx_cls_pro_s <sup>*</sup> 1                                                                                                                                                                                                                                                                   |
| (c) Copyright 2006-2019 Achronix Semic                                                                                                           | onductor Corp. All ri                                                                                 |                                                                                                                                                                                                                                                                                                                          |
| III all messages logged in file C\code\proi                                                                                                      | ects\quickstart_AC16t                                                                                 | SC01HI01C\impl_1\log/multiprocess.log, created at 12:0                                                                                                                                                                                                                                                                   |
| INFO: License ace-v1.0 on server cad12.ach<br>INFO: ====================================                                                         |                                                                                                       |                                                                                                                                                                                                                                                                                                                          |
| INFO: License ace-v1.0 on server cad12.ach                                                                                                       |                                                                                                       |                                                                                                                                                                                                                                                                                                                          |
| INFO: License ace-v1.0 on server cad12.ach<br>INFO: ====================================                                                         |                                                                                                       |                                                                                                                                                                                                                                                                                                                          |
| INFO: License ace-v1.0 on server cad12.ach<br>INFO: ====================================                                                         | )(0+0) Twck 12/+0 Mp                                                                                  |                                                                                                                                                                                                                                                                                                                          |
| INFO: License ace-v1.0 on server cad12.acf<br>INFO: ====================================                                                         | )(0+0) Twck 12/+0 Mp                                                                                  |                                                                                                                                                                                                                                                                                                                          |

Figure 34 • Multiprocess View Example

### Table 42 · Multiprocess View Toolbar Buttons

| lcon     | Action                              | Description                                                                                                                                                                                |
|----------|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| •        | Start Background Queue Execution    | Starts execution of all implementations selected in<br>the <b>Select Implementations</b> table in the number of<br>parallel processes specified by <b>Parallel Queue</b><br><b>Count</b> . |
| <b>.</b> | Stop All Background Queue Execution | Stops or cancels execution of all currently running or queued implementations.                                                                                                             |
|          | Open Multiprocess Report            | Opens the <b>Multiprocess Summary report</b> (page 256) for the selected project.                                                                                                          |

### **Execution Queue Management**

This section configures the number of background processes allowed to run in parallel, and how/where they are executed.

#### Table 43 · Execution Queue Management Controls

| Name                                 | Description                                                                                                                                                                                                                                                                     |
|--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Parallel Job Count                   | Sets the number of implementations allowed to execute in parallel.<br>Defaults to <b>2</b> . When in background mode, the maximum allowed<br>value is the number of available processor cores detected. When in<br>Job Submission System mode, the maximum allowed value is 99. |
| Enable Job Submission System Support | When unchecked, background processes run locally on the<br>workstation currently running the ACE GUI. When checked, ACE<br>uses the cloud/grid/batch job submission system as configured in<br>the preferences.                                                                 |
| (configured in Preferences)          | When selected, brings up the <b>Multiprocess: Configure Custom Job</b><br><b>Submission Tool preference page</b> (page 209) to fully configure which<br>cloud/grid/batch job submission system is used.                                                                         |

When the **Parallel Job Count** is set to the minimum value of **1**, all selected implementations are executed sequentially, one at a time. A value of **2** causes all selected implementations to be queued, and then the first two queued implementations are allowed to execute at the same time. As soon as an implementation completes its flow execution, the next queued implementation starts flow execution and the **Multiprocess Summary Report** (page 256) is updated with information gathered from the just-completed implementation.

By default, ACE executes implementations in parallel by starting a background process on the host workstation for each implementation (termed "background mode"). In this case, the effectiveness of parallel implementation

execution is naturally limited by the resources of the host workstation (i.e., the number of processor cores and the physical RAM).

Alternately, ACE may execute the implementations in processes distributed among multiple hosts via an external job submission system, which theoretically allows for far greater parallel compute resources. The job submissions are performed through a user-configured command line executable. This executable is configured via the **Multiprocess: Configure Custom Job Submission Tool preference page** (page 209), reached easily by following the *<configured in Preferences* > hyperlink.

See Running Multiple Flows in Parallel (page 307) for important details regarding parallel implementation execution, configuration, and external job submission tool support.

## **Multiprocess Flow Management**

This section allows altering how far the flow is executed for the multiprocess implementations.

| Table 44 | • Multi | process | Flow | Manag | gement | Controls |
|----------|---------|---------|------|-------|--------|----------|
|----------|---------|---------|------|-------|--------|----------|

| Name                           | Description                                                                                                                                                                                                                                                                                                                                   |
|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Stop Flow After <sup>(1)</sup> | Allows overriding standard flow behavior and stopping the flow early — the flow step selected becomes the final flow step executed by all multiprocess implementations. Useful when steps late in the flow are known to fail with reported errors, but it is still desired to run multiple implementations through earlier parts of the flow. |

#### **Table Notes**

1. The flow step chosen here is always enabled when the multiprocess run executes, regardless of whether it was enabled before the multiprocess run is launched.

See Running Multiple Flows in Parallel (page 307) for further details regarding multiprocess flow configuration.

### Select Implementations

This section allows:

- Selecting which implementations to execute (implementations derived from **option sets** (page 0) are created if selected).
- Starting or stopping the execution of all selected implementations.
- Providing simple execution state feedback.

See Running Multiple Flows in Parallel (page 307) for further details regarding selecting the implementations to be run in parallel, starting/stopping/cancelling parallel execution, etc.

See Attempting Likely Optimizations Using Option Sets (page 392) for explanations of how to use option sets to achieve better QoR.

### Table 45 · Select Implementations Controls

| Name                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Existing Implementations                     | Updates the contents of the implementation table to show all existing implementations for the current <b>active project</b> (page 231).                                                                                                                                                                                                                                                                                                                                                |
| Generate Implementations from Option<br>Sets | Updates the contents of the implementation table to show the current active implementation (page 231) and a number of to-be-generated implementations, one per option set (page 0). The use of this radio button selection is covered in more detail in Attempting Likely Optimizations Using Option Sets (page 392). If the implementation table does not show any implementations besides the active implementation while in this mode, click the <b>Refresh Option Sets</b> button. |
| Refresh Option Sets <sup>(1)</sup>           | Causes ACE to analyze the current <b>active project and</b><br><b>implementation</b> (page 231) to (re-)generate customized option sets<br>most likely to improve QoR. The implementation table is then updated<br>with a list of to-be-generated implementations.                                                                                                                                                                                                                     |
| Seed Sweep of prime numbers                  | Updates the contents of the implementation table to show a number<br>of to-be-generated implementations. Each of these implementations<br>is identical to the currently active implementation, with the<br>implementation option "seed" being automatically set to the next<br>consecutive prime number. The <b>seedcount</b> text field beside this radio<br>button can be used to choose how many such implementations<br>should be created.                                         |
| Implementation Table                         | A table containing implementation names along with their selection<br>state and execution state. The implementations listed vary based<br>upon the <b>active project and implementation</b> (page 231), in combination<br>with the state of the radio buttons.                                                                                                                                                                                                                         |
| ☑ Select All                                 | Selects all implementations in the implementation table.                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Deselect All                                 | Deselects all implementations listed in the implementation table.                                                                                                                                                                                                                                                                                                                                                                                                                      |
| start Selected                               | Queues all implementations selected in the implementation table and begins executing in the configured number of parallel processes.                                                                                                                                                                                                                                                                                                                                                   |
| 🖶 Stop All                                   | If clicked, all currently queued implementations are removed from the queue(s) and all currently executing implementations are killed. The <b>Multiprocess Summary Report</b> (page 256) is updated with any and all captured information.                                                                                                                                                                                                                                             |

| Name        | Description                                                                                                                                      |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Table Notes |                                                                                                                                                  |
|             | cking the ( ) Start Selected button whenever the active project or<br>htly, as well as the first time <b>Generate Implementations</b> from a new |

All the controls in this section center around what is in the table. The radio buttons change which implementations are listed in the table, and the push-buttons under the table change the selection state of the listed implementations, or alter the execution state of the implementations which is the purpose of the entire view.

The table contents are kept in sync with the current active project and implementation (page 231). Changing active projects (which implicitly changes active implementations) updates the implementation table contents according to the current radio button selection.

The following table describes the columns in the implementation table.

#### Table 46 · Implementation Table Columns

| Column Name     | Description                                                                                                                                                                                                                                                                                                      |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Implementation  | Contains the implementation name, along with a checkbox indicating implementation selection, and an icon representing the implementation.                                                                                                                                                                        |
| Execution State | Contains the execution state of the implementation.                                                                                                                                                                                                                                                              |
| Description     | Blank when <b>Existing Implementations</b> is selected. When <b>Generate</b><br><b>Implementations from Option Sets</b> is selected, contains a description of<br>the option set (page 0) which is used as the overlay on the active<br><b>implementation</b> (page 231) when generating the new implementation. |

#### 🕑 Tip

If the implementation table is not large enough (or is too large) for the full implementation list, click the section title and simply collapse and/or expand one of the other sections in this view. This causes the table to resize to exactly fit the entire current implementation list.

### Implementation Execution States

There are a number of possible execution states, as listed in the second column, for the implementations in the table corresponding to the lifetime of a Multiprocess view background process. The icons from these states are also used on the tabs within the Multiprocess Run Logs section.

| lcon     | Execution State | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | (blank)         | Implementation has not been selected for execution.                                                                                                                                                                                                                                                                                                                                                                                                                    |
|          | Selected        | Implementation is currently selected for execution, and execution has not been started.                                                                                                                                                                                                                                                                                                                                                                                |
| Zzz      | In Queue        | Execution of the selected implementations has been started, this implementation was selected for execution and is currently waiting in the queue for execution.                                                                                                                                                                                                                                                                                                        |
| Z22      | Scheduled       | Execution of the selected implementations has been started, this implementation was selected for execution, is at the head of the queue and is being prepared for execution. This state typically only lasts for a fraction of a second.                                                                                                                                                                                                                               |
| 0        | Running         | Implementation was selected for execution, and is currently executing. Log messages should be visible in the tabbed logging area.                                                                                                                                                                                                                                                                                                                                      |
| ~        | Complete        | Implementation was (and still is) selected for execution, and its last execution was completed without flow errors, but does not mean that the design met timing. Log messages should be visible in the tabbed logging area. Summary information should be visible in the Multiprocess Summary Report (page 256).                                                                                                                                                      |
| <b>-</b> | Stopped         | Implementation was (and still is) selected for execution, but its last execution was stopped or possibly canceled before it even started. If its execution had started, log messages should be visible in the tabbed logging area. If post-route timing analysis or sign-off timing analysis were completed for this implementation, the timing results should be visible in the Multiprocess Summary Report (page 256).                                               |
| 8        | Error           | Implementation was (and still is) selected for execution, but its last execution exited<br>with reported errors. A tooltip for the error icon provides a summary of the detected<br>error messages. Detailed log messages should be visible in the tabbed logging area. If<br>post-route timing analysis or sign-off timing analysis were completed for this<br>implementation, the timing results should be visible in the Multiprocess Summary<br>Report (page 256). |

### Table 47 • Implementation Execution States and Icons

## **Multiprocess Run Logs**

This section shows the logs for each selected implementation as they execute. A separate tab is provided for each individual implementation. The log info is updated live as background processes execute. Depending upon configuration, external cloud/grid/batch jobs may have their log info updated live, or it may not be updated until the job is completed. The displayed log info mirrors the information captured in the log file for each implementation.

Each tab includes the name of the implementation and the execution state, which updates live. If an implementation enters the error state, the tooltip for the tab title is updated to include a summary of the captured error messages. Error details are visible in the log shown in the tab, as well as within the log files (page 233) for each implementation.

# Netlist Browser View

The Netlist Browser view provides a graphical, tree-based visualization of the user design hierarchy, as found in the netlist. The displayed netlist includes the results of any transformation, legalization, etc. that have happened through the current stage in the Flow.

For large designs, there are a tremendous number of objects in the netlist. To simplify the view, the Netlist Browser provides a number of ways to filter the flood of data down to just the most useful information (there are no filters active by default).

Each instance node in the tree includes the instance name and the cell type. Macros include the macro name, and the counts of the various major logic types contained within that macro. Be aware that these logic type counts are not affected by the filters. The numbers shown always represent the unfiltered total counts. Clock domain names and Partitions names also are listed when appropriate.

By default, the Netlist Browser view is included in the Floorplanner perspective (page 6). To add the Netlist Browser view to other perspectives, select Window  $\rightarrow$  Show View...  $\rightarrow$  Other...  $\rightarrow$  Achronix  $\rightarrow$  Netlist Browser.

As can be seen in the second column of the following example, three instances have been highlighted:

- inb1\_ibuf[3].x\_ipad\_i\_io\_buffin cyan
- All members of the z0\_obuf. \* macro hierarchy in pink
- inb1\_int\_z[2] in dark blue

| 🏗 Netlist Browser 🛛 🧯 | S CIOCK | Domains   |           |          |        |           |       |      |      |       | <u>72   X</u> | <u></u> |        | _ |
|-----------------------|---------|-----------|-----------|----------|--------|-----------|-------|------|------|-------|---------------|---------|--------|---|
| Instance Name         | Hig     | Cell Type | Clock Dom | Core     | IORing | Partition | Flops | LUTs | ALUs | BRAMs | BMACCs        | LRAMs   | Others | - |
| Y                     |         | Y         | Y         | Y        | Y      | Y         | Y     | Y    | Y    | Y     | Y             | Y       | Y      |   |
| 🗉 🕀 inb1_ibuf[2]      |         |           |           |          | ~      |           | 0     | 0    | 0    | 0     | 0             | 0       | 3      |   |
| = 🕀 inb1_ibuf[3]      |         |           |           |          | ~      |           | 0     | 0    | 0    | 0     | 0             | 0       | 3      |   |
| 🖻 🕀 x_ipad            |         |           |           |          | ~      |           | 0     | 0    | 0    | 0     | 0             | 0       | 3      |   |
| 🛱 i_io_buff           |         | io_buffer |           |          | ~      |           | 0     | 0    | 0    | 0     | 0             | 0       | 1      |   |
| 🗉 🜐 z0_obuf           |         |           | clka      |          | ~      |           | 0     | 0    | 0    | 0     | 0             | 0       | 3      |   |
| ✓ inb1_int_Z[0]       |         | DFF       | clka      | ~        |        |           | 1     | 0    | 0    | 0     | 0             | 0       | 0      | - |
| ✓ inb1_int_Z[1]       |         | DFF       | clka      | ~        |        |           | 1     | 0    | 0    | 0     | 0             | 0       | 0      |   |
| ✓ inb1_int_Z[2]       |         | DFF       | clka      | ~        |        |           | 1     | 0    | 0    | 0     | 0             | 0       | 0      |   |
| ✓ inb1_int_Z[3]       |         | DFF       | clka      | ~        |        |           | 1     | 0    | 0    | 0     | 0             | 0       | 0      |   |
| ✓ reg_and_b1_RNO      |         | LUT4      | clka      | <b>~</b> |        |           |       | 1    |      | 0     |               |         |        |   |
| ✓ reg_and_b1_Z        |         | DFFR      | clka      | ~        |        |           | 1     | 0    | 0    | 0     | 0             | 0       | 0      |   |
| A PNO                 |         | 11174     | elles     | .1       |        |           | 0     | 1    | 0    | 0     | 0             | 0       | 0      |   |

#### Figure 35 • Netlist Browser Example

### (i) Note

- The small colored square in the toolbar shows the active highlighting color. If highlighting is applied to a macro then all "child" instances within are also set to the current highlight color.
- Resource type columns, such as Flops, BRAMs, ALUs, etc. are dynamic and change to match the target device after running the Prepare flow step. The example images and descriptions in this section do not reflect the resource types of actual devices.

| Column Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Instance Name   | The name of the instances in the netlist. Instances within a macro are<br>grouped together as leaves under the macro branch. Additionally, an icon is<br>used to indicate the placement state of the instance. The possible icons are<br>shown in the following table.                                                                                                                                                                     |
| Highlight Color | <ul> <li>For instances, shows a color square to indicate the instance highlight color, if any.</li> <li>For macros, if all contained instances have the same highlight color, the macro shows a color square for that same highlight color. If even one contained instance has a different highlight color, or no highlight at all, the macro displays no color square. This value does not change for macros during filtering.</li> </ul> |
| Cell Type       | <ul> <li>For instances, shows the cell type of the instance.</li> <li>For macros, this column is blank.</li> </ul>                                                                                                                                                                                                                                                                                                                         |
| Clock Domain    | <ul> <li>For instances, shows a list of all the clock domains of which the instance<br/>is a member.</li> <li>For macros, shows a summary list of the clock domains for all the<br/>contained instances. This value does not change for macros during<br/>filtering.</li> </ul>                                                                                                                                                            |
| Core            | <ul> <li>For instances, this is checked if the instance is considered a member of the Core, or blank if it is not.</li> <li>For macros, this is checked if any contained instances are considered a member of the Core, or blank if no contained instances are in the Core. This value does not change for macros during filtering.</li> </ul>                                                                                             |
| IORing          | <ul> <li>For instances, this is checked if the instance is considered a member of the IORing, or blank if it is not.</li> <li>For macros, this is checked if any contained instances are considered a member of the IORing, or blank if no contained instances are in the IORing. This value does not change for macros during filtering.</li> </ul>                                                                                       |
| Partition       | <ul> <li>For instances, the name of the Partition to which the item belongs, if any.<br/>See Using Incremental Compilation (Partitions) (page 404).</li> <li>For macros, (same).</li> </ul>                                                                                                                                                                                                                                                |

### Table 48 · Netlist Browser Table Columns

| Column Name | Description                                                                                                                                                                                                                    |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Resource    | <ul> <li>For instances, this is one if the instance is of type <i>resource</i>, or zero otherwise.</li> <li>For macros, this is the sum count of all contained <i>resource</i> instances (regardless of filtering).</li> </ul> |

Icons decorate all the nodes in the tree in the Instance Name column.

Table 49 • Netlist Browser View Icons

| lcon     | Description             |
|----------|-------------------------|
| <b>#</b> | Масто                   |
| Θ        | Unplaced Instance       |
| *        | Placed Instance (Soft)  |
| ۵        | Placed Instance (Fixed) |

A number of actions are available in the view via:

- Buttons at the top of the view
- The (...) ellipsis view menu button
- Right-click context menus on the nodes of the tree

### (i) Note

If these actions are performed upon macros, all child leaf nodes, even those currently filtered to be hidden in the tree, are affected by the chosen action.

### Table 50 • Netlist Browser View Actions

| lcon | Action                | Toolbar<br>Button | Context<br>Menu | View<br>Menu | Description                                                                                 |
|------|-----------------------|-------------------|-----------------|--------------|---------------------------------------------------------------------------------------------|
| +    | Add to Selection      |                   | Y               |              | Adds the item(s) to the ACE selection set (as shown in the Selection View (page 137)).      |
| -    | Remove from Selection |                   | Y               |              | Removes the item(s) from the ACE selection set (as shown in the Selection View (page 137)). |

| lcon     | Action                      | Toolbar<br>Button | Context<br>Menu | View<br>Menu | Description                                                                                                                                                                              |  |
|----------|-----------------------------|-------------------|-----------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|          | Choose Highlight Color      | Y                 | Y               |              | Determines which color is applied to the objects<br>chosen from the tree the next time the highlight<br>action is selected for this view.                                                |  |
| <u>_</u> | Highlight                   | Y                 | Y               |              | Applies the currently active highlight color to the chosen item(s) in the tree. See Highlighting Objects in the Floorplanner View (page 342).                                            |  |
| ×        | Un-Highlight                | Y                 | Y               |              | Clears the Highlight for the chosen item(s) in the<br>tree. When painted in the Floorplanner view, the<br>chosen item(s) now use their default color(s)<br>instead of a highlight color. |  |
| 1        | Auto-Highlight              | Y                 |                 |              | Automatically applies unique highlight colors to<br>all visible core hierarchy levels in the tree.<br>IORing hierarchy levels are skipped.                                               |  |
| Q        | Zoom To                     |                   | Y               |              | Zooms the Floorplanner view to a region containing the instances currently chosen in t tree.                                                                                             |  |
| ₿¢       | Show in Netlist $^{(1)}$    |                   | Y               |              | Attempts to open a text editor to the file and line<br>number relevant to the chosen instance.<br>Available only when a single instance is chosen<br>in the view.                        |  |
| ì        | Unfix Placement of Instance |                   | Y               |              | Changes the state of an already-placed instance<br>from fixed placement to soft placement. This<br>choice is only available when an instance<br>already has fixed placement.             |  |
| ۵        | Fix Placement of Instance   |                   | Y               |              | Changes the state of an already-placed instance<br>from soft placement to fixed placement. This<br>choice is only available when an instance<br>already has soft placement.              |  |
| ۲        | Unplace Instance            |                   | Y               |              | Completely removes the site assignment for an instance, making it unplaced. This choice is only available when an instance is already placed.                                            |  |
| Æ        | Expand All                  | Y                 |                 |              | Expands all collapsed macro branches in the tree, making all leaf instances visible.                                                                                                     |  |
| E        | Collapse All                | Y                 |                 |              | Collapses all expanded macro branches in the tree.                                                                                                                                       |  |

| lcon | Action                               | Toolbar<br>Button | Context<br>Menu | View<br>Menu | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|--------------------------------------|-------------------|-----------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Ŧ    | Show Power and Grounds               | Y                 |                 | Y            | Disabled by default. When disabled, all instances<br>of power and ground are hidden within the tree,<br>effectively acting as a filter. Therefore, the <b>Cell</b><br><b>Type</b> column gains the active filter indicator<br>(yellow background by default) when power and<br>ground are hidden.<br>This filter is a higher priority than user custom<br>filters applied to the <b>Cell Type</b> column. If a<br>custom filter is created to expose only "GND"<br>grounds, but <b>Show Power and Grounds</b> is<br>disabled, the "GND" instances remain hidden.                                                                                                                                                                                                                                                                                                                                                               |
| 7.2  | Show Boundary Pins                   | Y                 |                 | Y            | Disabled by default. When disabled, all instances<br>of boundary pins are hidden within the<br>tree, effectively acting as a filter. Therefore, the<br><b>Cell Type</b> column gains the active filter indicator<br>(yellow background by default) when boundary<br>pins are hidden.<br>This filter is a higher priority than user custom<br>filters applied to the <b>Cell Type</b> column. If a<br>custom filter is created to expose only "OPIN"<br>instances, but <b>Show Boundary Pins</b> is disabled,<br>the "OPIN" instances remain hidden.                                                                                                                                                                                                                                                                                                                                                                            |
|      | Show Feedthrough LUTs <sup>(2)</sup> |                   |                 | γ            | Toggles the visibility of all feedthrough<br>instances, most often created by Achronix<br>optimizations. These always have "_ft_" plus<br>some additional notation in the ACE-generated<br>instance name.<br>Enabled by default. When disabled, all<br>feedthrough instances are hidden within the<br>tree, effectively acting as a filter. Therefore, the<br><b>Instance Name</b> column gains the active filter<br>indicator, a yellow background by default, when<br>feedthrough instances might consist of more<br>than just LUTs.<br>This filter is a higher priority than the user<br>custom filters applied to the <b>Instance Name</b><br>column. If a custom filter is created to expose<br>only instances that contain "LUT" in the name,<br>but <b>Show Feedthrough LUTs</b> is disabled, any<br>instances that have a feedthrough-based name<br>remain hidden, even if they have an explicit<br>"LUT" in the name. |

| lcon             | Action                                      | Toolbar<br>Button | Context<br>Menu | View<br>Menu | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------|---------------------------------------------|-------------------|-----------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | Show Constants <sup>(2)</sup>               |                   |                 | Y            | Toggle the visibility of all instances with "const"<br>somewhere in the name, most often created by<br>Achronix optimizations.<br>Enabled by default. When disabled, all instances<br>with "const" anywhere in the name are hidden<br>within the tree, effectively acting as a filter.<br>Therefore, the <b>Instance Name</b> column gains the<br>active filter indicator, a yellow background by<br>default, when constants are hidden.<br>This filter is a higher priority than the user<br>custom filters applied to the <b>Instance Name</b><br>column. If a custom filter is created to expose<br>only instances that contain "LUT" in the name,<br>but <b>Show Constants</b> is disabled, any instances<br>that have a "const" in their name remain hidden,<br>even if they have an explicit "LUT" in the name.                                                                |
|                  | Show Duplicates/Clones <sup>(2)</sup>       |                   |                 | Y            | Toggle the visibility of instances with various<br>forms of "_DUP_" in the name, most often<br>created by Achronix optimizations.<br>Enabled by default. When disabled, instances<br>with "_DUP_" or "_dup_" in the name (typically<br>with some additional notation) are hidden<br>within the tree, effectively acting as a filter.<br>Therefore, the <b>Instance Name</b> column gains the<br>active filter indicator (yellow background by<br>default) when duplicates/clones are hidden.<br>This filter is a higher priority than the user<br>custom filters applied to the <b>Instance Name</b><br>column. If a custom filter is created to expose<br>only instances that contain "LUT" in the name,<br>but <b>Show Duplicates/Clones</b> is disabled, any<br>instances that have a "_DUP_" in their name<br>remain hidden, even if they have an explicit<br>"LUT" in the name. |
|                  | Toggle Filter Row Visibility <sup>(3)</sup> | γ                 | Υ               |              | Changes whether the filter row (of filter icons) is visible or not.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <mark>9</mark> £ | Configure view                              |                   | Y               |              | Jumps to the Netlist Browser view in the Preferences dialog.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

#### ▲ Warning!

- Be aware that when actions are performed upon macros, all the children of that macro, even the invisible/filtered nodes, are affected.
- With default preference settings, in the Floorplanner View (page 45), highlight colors of (placed) instances are only visible when the instances layer is enabled, and the instances are not members of the ACE selection set. This is because the instance selection color has a higher priority than the highlight color.

## **Filtering Displayed Instances**

Some convenience filters for **Cell Type** are already present as visibility toggles in the Netlist browser. These filters are represented by the  $(\overline{i}, \underline{j})$  Show Boundary Pins and  $(\underline{+})$  Show Power and Grounds toggle actions/buttons. Be aware that the "hide" functionality of these actions (when the Show toggle is disabled) is considered a higher-priority filter than any user custom filters. For example, when boundary pins are hidden due to this toggle, even if a custom filter tries to expose boundary pins, the toggled filter wins, and the pins remain hidden.

Additionally, some convenience filters for **Instance Name** are already present as visibility toggles. These filters are represented by the **Show Feedthrough Luts**, **Show Constants**, and **Show Duplicates/Clones** toggled menu items. Be aware that the "hide" functionality of these actions (when the Show toggle is disabled) is considered a higher-priority filter than any user custom filters. For example, when constant instances are hidden due to this toggle, even if a custom filter tries to expose constants, the toggled filter wins, and the constant instances remain hidden.

To enable custom instance filter manipulations, it might be necessary to click (<sup>1</sup>/<sup>2</sup>) **Toggle Filter Row Visibility** to cause the filter manipulation row to become visible. This toggle action is available in a context menu when rightclicking any table column header and is also available in the view supplemental menu (the small down arrow icon in the upper-right of the view, to the left of the **Minimize View** button).

Most columns of the table can filter the displayed instances (not the macros) by value. When filtering by column value, only instances with column values matching the filter are retained; non-matching values are excluded from the table.

Be aware that macro rows do not directly respond to filters, and remain visible as long as any single child instance remains visible. When all child instances of a macro are hidden, the parent macro is hidden as well. On a related note, macro summary counts in numeric columns (as when counting LUTs in a macro) do not change when filters are applied. The displayed counts are always the complete, unfiltered counts.

### 🔒 Warning!

- When using filters, the values being filtered are those of the individual instances, not the macros. Macros are filtered out only if all of their children are filtered out. As a result, when filtering by the logic types, the only possible filter numeric values in this table are 0 or 1, because these are the only legal values for an instance.
- Also, be aware that when filtering the **Instance Name** column, the parent macro names are considered part of the instance name — the prefix (the fully qualified instance name is used, not just the terminating leaf name).

Columns containing text can be filtered by string value (simple wildcard substring matching by default, but regular expression matching using Java rules is also available, see https://en.wikipedia.org/wiki/Regular\_expression). Columns with checkmarks can be filtered by boolean value. Columns containing numbers can be filtered by numerical value.

To add a filter to a column:

- 1. Click the (abla) filter icon, which causes a data-appropriate filter dialog to appear.
- 2. Fill in the desired filter values.
- 3. Click **Apply** to apply the filter to the instances in the table.

All values matching that filter are retained, and all other values are excluded. Additionally, the background color of the column changes to a bright yellow to indicate the filter is active, and the filter icon at the head of the column also changes to the ( $\checkmark$ ) active filter icon.

An example filter for the **Cell Types** column that uses regular expressions to block PWR, GND, ASC, SAC, and bit\* cell types in the following image.

| 7 Netli | ist Browser Filter Configuration 📃 🗉 🔀 |
|---------|----------------------------------------|
| Filter: | ^((?!(bit GND PWR ASC SAC)).)*\$       |
| Cas     | e sensitive                            |
| 🔽 Reg   | ular Expression                        |
|         | Apply Clear Cancel                     |

Figure 36 • Cell Types Column Filter Example

To edit (or clear) an existing filter:

- 1. Click the (Y) active filter icon causing the data-appropriate filter dialog to appear, now pre-populated with the existing filter setting.
- 2. Change the filter value and click **Apply** again to edit the filter.
- 3. Click Cancel to leave the filter unchanged.
- 4. Click **Clear** to remove the filter from the column.

If the filter is cleared, the background color of the column returns to the default background color, and the filter icon also changes to the ( $\Upsilon$ ) inactive version.

# Drag-and-Drop

The Netlist browser supports a limited set of drag-and-drop interactions with other views in the **Floorplanner perspective** (page 6). The Netlist browser view only acts as a drag-and-drop source, not a destination; items dropped on the Netlist browser view are ignored.

Any node of the tree may be dragged to the Tcl Console view (page 146), and when dropped anywhere in the view, appropriate text is inserted at the beginning of the Tcl command-line.

Instance nodes may also be dragged to the Floorplanner view (page 45). When dropped on the Floorplanner view, the behavior depends upon the current Tool mode. When the Floorplanner **Placement/Panning Tool** is active, placement is attempted.

Any node of the tree may be dragged to the **Placement Regions view** (page 114) or the Floorplanner view (when that view has the **Placement Regions Tool** active) to assign placement region constraints (page 398). Dragging a macro is the equivalent of dragging all individual instances which are members of that macro.

# NoC Performance View

The NoC Performance view shows an interactive diagram that includes the I/O ring and the 2D NoC resources for the target device. Loading a simulation log file produced by the device simulation model (DSM) into the view provides graphic visualization of traffic between Network Access Points (NAPs) for different periods of time ("time slices") during the simulation.

# Loading Simulation Log Files

Load simulation log files by clicking **Browse** on the view control bar as shown:

| IIII NoC Performance ×             |                                   | 000 |
|------------------------------------|-----------------------------------|-----|
| Log: (no log file is loaded) Brows | Time Slice: (no timeslices found) | -   |
| Device:                            | Filter:                           | ×   |

#### Figure 37 • Simulation Log File Loading Example

When a log file has been loaded, hover the mouse pointer over the Log text field to see the full path to the loaded file:



### Figure 38 • Simulation Log File Path Example

## **Browsing Time Slices**

Use the **Time Slice** combo box on the view control bar to choose a time slice to visualize. The statistics in the chosen time slice are used to colorize portions of the view diagram.

Use the **Filter** text control to enter a regular expression; the list of choices available in the **Time Slice** combo will be filtered down to only those choices that match the expression.

When the time slice list is being filtered, both the **Time Slice** combo box and the **Filter** text control will be colorized to remind you that filtering is taking place.

These colors can be adjusted in the **Colors and Fonts** preferences area. The Preferences dialog can be accessed through the main application menu (**Window**  $\rightarrow$  **Preferences**), or by clicking the "three-dots" shortcut in the upper right of the view and then clicking **Configure view...**:

| IIII NoC Performance $\times$ |        |   |                                   |   | - 0 |
|-------------------------------|--------|---|-----------------------------------|---|-----|
| Log: (no log file is loaded)  | Browse | Ŷ | Time Slice: (no timeslices found) | ~ |     |
| Device:                       |        |   | Filter:                           |   | ×   |

#### Figure 39 • Preferences Dialog Shortcut Location

There is a "tool box" of additional controls in a collapsible flyout panel to the right of the diagram, similar to the one found in the Floorplanner view (page 45):



### Figure 40 • Time Slice Tool Box Panel Example

The tool box contains three main sections:

- Traffic Type toggles for choosing which types of traffic data to display in the diagram.
- Traffic Mode two diagram display modes may be selected: **Throughput** or **Blockage**.
- Legend displays the gradient range coloring for the selected traffic mode.

In Throughput mode, the diagram is colored using the following gradient range:

### Table 51 · Throughput Mode Gradient Range

| Throughput<br>Gradient | Default<br>Color |
|------------------------|------------------|
| High                   | Green            |
| Medium                 | Light blue       |
| Low                    | Darker blue      |

The Throughput mode diagram coloring is illustrated in the following figure:



Figure 41 • Throughput Mode Diagram Coloring Example

In Blockage mode, the diagram is colored using the following gradient range:

### Table 52 · Blockage Mode Gradient Range

| Blockage<br>Gradient | Default<br>Color |
|----------------------|------------------|
| Low                  | Green            |
| Medium               | Yellow           |
| High                 | Red              |

The Blockage mode diagram coloring is illustrated in the following figure:



Figure 42 • Blockage Mode Diagram Coloring Example

Hover the mouse pointer over any colored portion of the diagram and a tool tip is displayed showing the raw data from the simulation log file used to determine the color.

There is also a breakdown of how much time was spent "idle" versus "trying," with the "trying" time further broken down into time spent "blocked" and time spent "transferring":



Figure 43 • Simulation Data Tool Tip Example

### Zooming

The view can be zoomed in or out several levels with the mouse wheel while the mouse pointer is hovering over the diagram.

### **Drag-Scrolling**

When zoomed in, the diagram can be scrolled in any direction by clicking and dragging the mouse pointer anywhere inside of the diagram.

### Adjusting Diagram Properties

The font used in the diagram, as well as the colors used to generate the throughput and blockage gradients, can be configured in the Preferences dialog.

The Preferences dialog can be accessed through the main application menu (**Window**  $\rightarrow$  **Preferences**), or by clicking the "three-dots" shortcut in the upper right of the view and then clicking **Configure view...**:

| IIII NoC Performance ×       |        |         |                                   | 8 | - 0 |
|------------------------------|--------|---------|-----------------------------------|---|-----|
| Log: (no log file is loaded) | Browse | s<br>S  | Time Slice: (no timeslices found) | ~ |     |
| Device:                      |        | Filter: |                                   | × |     |

### Figure 44 • Preferences Dialog Shortcut Location

The Preferences Dialog and the available settings are shown in the following figure.

| Preferences                                                                                                                                                                                                                                                                                                                                        | —                                                              | οx             |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|----------------|
| type filter text                                                                                                                                                                                                                                                                                                                                   | NoC Performance                                                | <> ▼ □ ◆ \$    |
| Configure DCC Connection<br>Configure JTAG Connection<br>Critical Path Diagram View<br>Floorplanner View Colors and Layers<br>Floorplanner View Optimizations<br>General<br>Help<br>I/O Designer<br>Multiprocess<br>Netlist Browser<br>NoC Performance<br>Placement Regions<br>Project Management<br>Tcl Console View<br>User Advanced Preferences | See also: ' <u>Colors and Fonts</u> '.<br>Log File Browse Path | <u>C</u> hange |
|                                                                                                                                                                                                                                                                                                                                                    | Apply and Close                                                | Cancel         |

Figure 45 • NoC Performance Preferences

| Preferences                                                                                                                                                                                                                                                                        | -                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                      |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| type filter text<br>Configure DCC Connection<br>Configure JTAG Connection<br>Critical Path Diagram View<br>Floorplanner View Colors and Layers<br>Floorplanner View Optimizations<br>General<br>Appearance<br>Colors and Fonts<br>Editors<br>Link Handlers<br>Quick Search<br>Help | Colors and Fonts Colors and Fonts Colors and Fonts (font, size, type, ? = any character, * = any string) : type filter text  Colors and Fonts Dotate Performance Views Blockage:2: Medium Blockage:3: High Data Flow Arrows Filtered Control Background Filtered Control Background Filtered Control Background Filtered Control Foreground A@ NoC Performance Diagram font M NoC Time Slice View font (set to default: Tcl Cons Throughput:1: High | □       ×         ↓ → ↓ → ↓       ↓         Edit       ↓         Use System Font       ↓         Reset       ↓         Edit Default       ↓         Go to Default       ↓         Expand All       ↓ |
| Help<br>I/O Designer<br>Multiprocess<br>Netlist Browser<br>NoC Performance<br>Placement Regions<br>Project Management<br>Tcl Console View<br>User Advanced Preferences                                                                                                             | <ul> <li>Throughput:1: High</li> <li>Throughput:2: Medium</li> <li>Throughput:3: Low</li> <li>Time Slice View: Notes</li> <li>Time Slice View: Stats</li> </ul> Description: Preview: No preview available.                                                                                                                                                                                                                                         |                                                                                                                                                                                                      |
|                                                                                                                                                                                                                                                                                    | Restore Defaults Apply and Close                                                                                                                                                                                                                                                                                                                                                                                                                    | Apply<br>Cancel                                                                                                                                                                                      |

### Figure 46 • NoC Performance Preferences: Colors and Fonts

### Table 53 · NoC Performance Preferences

| Preference                   | Description                                                                                                   |
|------------------------------|---------------------------------------------------------------------------------------------------------------|
| See Also: 'Colors and Fonts' | Clicking this hyperlink moves to the NoC Performance section of the <b>Colors and Fonts</b> preferences area. |

| Preference           | Description                                                                                                                                                                           |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Log File Browse Path | By default, the log file <b>Browse</b> button in the NoC Performance view begins browsing at the last path used. To always start browsing in a specific folder, enter that path here. |

# NoC Time Slice View

The NoC Performance time slice view displays information about the time slice currently selected in the NoC Performance View (page 89).

Statistics and "Notes" from the simulation log data can be rendered in different colors that can be specified in the application preferences.

Word-wrap can be toggled via a button in the upper-right of the view tool bar.

As with all views in ACE, this view can be dragged and dropped to any convenient location: left of the NoC Performance View, below it, etc.

| O NoC Ti       | me Slice 🛙 |                                                      |     | ₹ " |   |
|----------------|------------|------------------------------------------------------|-----|-----|---|
| @123           |            | AXI Read Requests, Responses                         |     |     |   |
| @1234          |            | nap axi slave c1 r1> [AR 95/ 5 38] [ R 0/28 212]     |     |     | _ |
| @1234          |            | nap_axi_slave_c2_r1> [AR 95/ 5 38] [ R 0/28 212]     |     |     |   |
| @1234          |            | nap_axi_slave_c3_r1> [AR 95/ 5 38] [ R 0/28 212]     |     |     |   |
| @1234          | -          | nap_axi_slave_c4_r1> [AR 95/ 5 38] [ R 0/28 210]     |     |     |   |
| @1234          |            | nap_axi_slave_c5_r1> [AR 95/ 5 38] [ R 0/28 208]     |     |     |   |
| @1234          |            | nap_axi_slave_c6_r1> [AR 95/ 5 37] [ R 0/28 207]     |     |     |   |
| @1234          |            | nap_axi_slave_c7_r1> [AR 95/ 5 38] [ R 0/28 208]     |     |     |   |
| @1234          | -          | nap_axi_slave_c8_r1> [AR 95/ 5 36] [ R 0/26 198]     |     |     |   |
| @1234          |            | fabric_axi_w_r1> [AR 87/13 251] [ R 0/84 1686]       |     |     |   |
| @1234          |            | AXI Write Requests/Data/Responses                    |     |     |   |
| @1234<br>@1234 |            | ddr4_dc0_axi> [AW 0/ 9 90] [ W 0/72 721] [ B         | 0/9 | 901 |   |
| @1234<br>@1234 |            | gddr6_1_dc0_axi> [AW 0/ 9 90] [ W 0/72 721] [ B      | 0/9 | 901 |   |
| @1234<br>@1234 |            |                                                      | 0/9 | 901 |   |
| 0              |            |                                                      |     | -   |   |
| @1234          |            | gddr6_2_dc0_axi> [AW 0/9 90] [W 0/72 721] [B         | 0/9 | 90] |   |
| @1234          |            | gddr6_2_dc1_axi> [AW 0/ 9 90] [W 0/72 721] [B        | 0/9 | 90] |   |
| @1234          |            | gddr6_5_dc0_axi> [AW 0/9 90] [W 0/72 721] [B         | 0/9 | 90] |   |
| @1234          |            | gddr6_5_dc1_axi> [AW 0/9 90] [W 0/72 721] [B         | 0/9 | 90] |   |
| @1234          |            | gddr6_6_dc0_axi> [AW 0/ 9 90] [W 0/72 721] [B        | 0/9 | 90] |   |
| @1234          |            | gddr6_6_dc1_axi> [AW 0/ 9 90] [W 0/72 721] [B        | 0/9 | 90] |   |
| @1234          |            | pcie_x16_dc_slave_axi> [AW 0/ 9 90] [W 0/72 721] [B  | 0/9 | 90] |   |
| @1234          |            | pcie_x16_dc_master_axi> [AW 0/ 9 90] [W 0/72 721] [B | 0/9 | 90] |   |
| @1234          |            | Flit Requests/Responses                              |     |     |   |
| @1234          |            | noc_ws_to_wn> [Rq 10/18 10] [Rs 33/ 2 100]           |     |     |   |
| @1234          |            | noc_wn_to_ws> [Rq 50/18 25] [Rs 75/ 2 80]            |     |     |   |
| @1234          |            | noc_wn_to_n> [Rq 10/18 75] [Rs 33/ 2 60]             |     |     |   |
| @1234          |            | noc_n_to_wn> [Rq 50/18 100] [Rs 75/ 2 40]            |     |     |   |
| @1234          |            | noc_en_to_n> [Rq 10/18 75] [Rs 33/ 2 60]             |     |     |   |
| @1234          | acx_perf>  | noc_n_to_en> [Rq 50/18 100] [Rs 75/ 2 40]            |     |     |   |
| @1234          |            | noc_es_to_en> [Rq 10/18 10] [Rs 33/ 2 100]           |     |     |   |
| @1234          | acx_perf>  | noc_en_to_es> [Rq 50/18 25] [Rs 75/ 2 80]            |     |     |   |
| @1234          |            | noc_es_to_s> [Rq 10/18 75] [Rs 33/ 2 60]             |     |     |   |
| @1234          | acx_perf>  | noc_s_to_es> [Rq 50/18 100] [Rs 75/ 2 40]            |     |     |   |
| @1234          | acx_perf>  | noc_ws_to_s> [Rq 10/18 75] [Rs 33/ 2 60]             |     |     |   |
| @1234          | acx_perf>  | noc_s_to_ws> [Rq 50/18 100] [Rs 75/ 2 40]            |     |     |   |
| @1234          | acx_perf>  | noc_es_to_s> [Rq 10/18 75] [Rs 33/ 2 60]             |     |     |   |
| @1234          | acx_perf>  | noc_s_to_es> [Rq 50/18 100] [Rs 75/ 2 40]            |     |     |   |
| @1234          | acx_perf>  | Channel 0/1 Flits                                    |     |     |   |
| @1234          | acx_perf>  | ethernet_flit_s_c1> [C0 0/37 745]                    |     |     |   |
| @1234          | acx_perf>  | ethernet_flit_n_c2> [C0 0/37 745]                    |     |     |   |
| @1234          | acx_perf>  | ethernet_flit_s_c2> [C0 0/37 745]                    |     |     |   |
| @1234          | acx_perf>  | ethernet_flit_n_c4> [C0 0/37 745]                    |     |     |   |
| @1234          |            | ethernet_flit_s_c4> [C0 0/37 745]                    |     |     |   |
| @1234          |            | ethernet_flit_s_c1> [C1 10/100 1000]                 |     |     |   |
| @1234          |            | ethernet_flit_n_c2> [C1 20/100 1000]                 |     |     |   |
| @1234          |            | ethernet flit s c2> [C1 30/100 1000]                 |     |     |   |
| @1234          |            | ethernet_flit_n_c4> [C1 40/100 1000]                 |     |     |   |
| @1234          |            | ethernet_flit_s_c4> [C1 50/100 1000]                 |     |     |   |
|                | _r · · ·   |                                                      |     |     |   |
|                |            |                                                      |     |     |   |
|                |            |                                                      |     |     |   |
|                |            |                                                      |     |     |   |

Figure 47 • NoC Performance Time Slice View Example

# **Adjusting View Properties**

The font used in the Time Slice View, as well as the colors used to differentiate statistics from notes, can be configured in the Preferences dialog.

The Preferences dialog can be accessed through the main application menu, **Window**  $\rightarrow$  **Preferences**. The dialog can also be opened by double-clicking the gradient **Legend** section in the NoC Performance View toolbox.

The Preferences Dialog and the available settings are shown in the following example:

| Preferences                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| type filter text                                                                                                                                                                                                                                                                                                                                                                                        | Colors and Fonts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ⇔ ▼ ↔ ▼ 8                                                                       |
| Configure DCC Connection<br>Configure JTAG Connection<br>Critical Path Diagram View<br>Floorplanner View Colors and Layers<br>Floorplanner View Optimizations<br>Colors and Fonts<br>Editors<br>Link Handlers<br>Quick Search<br>Help<br>I/O Designer<br>Multiprocess<br>Netlist Browser<br>NoC Performance<br>Placement Regions<br>Project Management<br>Tcl Console View<br>User Advanced Preferences | Colors and Fonts (font, size, type, ? = any character, * = any string) : type filter text  Colors and Fonts (font, size, type, ? = any character, * = any string) : type filter text  Description:  Colors and Fonts (font, size, type, ? = any character, * = any string) : type filter text  Colors and Fonts (font, size, type, ? = any character, * = any string) : type filter text  Colors and Fonts (font, size, type, ? = any character, * = any string) : type filter text  Colors and Fonts (font, size, type, ? = any character, * = any string) : type filter text  Colors and Fonts (font, size, type, ? = any character, * = any string) : type filter text  Colors and Fonts (font, size, type, ? = any character, * = any string) : type filter text  Colors and Fonts (font, size, type, ? = any character, * = any string) : type filter text  Colors and Fonts (font, size, type, ? = any character, * = any string) : type filter text  Colors and Fonts (font, size, type, ? = any character, * = any string) : type filter text  Colors and Fonts (font, size, type, ? = any character, * = any string) : type filter text  Colors and Fonts (font, size, type, ? = any character, * = any string) : type filter text  Colors and Fonts (font, size, type, ? = any character, * = any string) : type filter text  Colors and Fonts (font, size, type, ? = any character, * = any string) : type filter text  Colors and Fonts (font, size, type, ? = any character, * = any string) : type filter text  Colors and font (set to default : Tcl Console  Colors and font (set to default : Tcl Console  Colors and font (set to default : type, ? = any string) : type filter text  Colors and font (set to default : Tcl Console  Colors and font (set to default : type, ? = any string) : type filter text  Colors and font (set to default : type, ? = any string) : type filter text  Colors and font (set to default : type, ? = any string) : type filter text  Colors and font (set to default : type, ? = any string) : type filter text  Colors and font (set to default : type, ? = any string) | Edit<br>Use System Font<br>Reset<br>Edit Default<br>Go to Default<br>Expand All |
|                                                                                                                                                                                                                                                                                                                                                                                                         | Apply and Close                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Cancel                                                                          |

Figure 48 • NoC Time Slice View Colors and Fonts Preferences

| Preference               | Description                                                   |
|--------------------------|---------------------------------------------------------------|
| NoC Time Slice View font | The font to be used in the NoC Time Slice view.               |
| Time Slice View: Notes   | The color used to render "notes" in the NoC Time Slice view.  |
| Time Slice View: Stats   | Color used to render "statistics" in the NoC Time Slice view. |

# **Options View**

The Options view displays project implementation options (page 231) for the active implementation (page 231). From this view, the active project implementation (page 231) can be configured for its run through the flow (page 235).

This view does not display any information unless an active implementation is selected in the **Projects view** (page 120). When running the flow (page 305), the implementation options of the active implementation are used to govern the flow.

By default, the Options view is included in the **Projects perspective** (page 6). To add the Options view to the current perspective, select **Window**  $\rightarrow$  **Show View...**  $\rightarrow$  **Options**.

| 🗄 Options 🗡                                                      |                |        |  |  |
|------------------------------------------------------------------|----------------|--------|--|--|
| Project:                                                         | quickstart_o   | canary |  |  |
| Implementation                                                   | n: impl_1      |        |  |  |
| Project Opti                                                     | ions           |        |  |  |
| Simulation                                                       |                |        |  |  |
| <ul> <li>Synthesis</li> </ul>                                    |                |        |  |  |
| > Place and R                                                    | oute           |        |  |  |
| Advanced P                                                       | lace and Rou   | te     |  |  |
| ▼ Timing Ana                                                     | lysis          |        |  |  |
| Number of o                                                      | critical paths | 10     |  |  |
| Number of v                                                      | worst paths    | 1      |  |  |
|                                                                  |                |        |  |  |
| $\Box$ Report asynchronous clear/preset to register output paths |                |        |  |  |
| Report Gene                                                      | eration        |        |  |  |
| • Bitstream G                                                    | eneration      |        |  |  |
| FPGA Down                                                        | load           |        |  |  |
|                                                                  |                |        |  |  |
|                                                                  |                |        |  |  |
|                                                                  |                |        |  |  |

Figure 49 • Options View Example

### 🕑 Tip

#### **Tcl Equivalence**

Each implementation option that can be configured via this graphical view may also be configured via the **set\_impl\_option** (page 712) Tcl command. The current value of each option can be retrieved with the **get\_impl\_option** (page 648) Tcl command. The values of options may be reset back to their default values with the **reset\_impl\_option** (page 687) Tcl command.

Likewise, each project-level option that can be configured via this graphical view may also be configured via the set\_project\_option (page 715) Tcl command. The current value of each option can be retrieved with the get\_project\_option (page 656) Tcl command. The values of options may be reset back to their default values with the reset\_project\_option (page 688) Tcl command.

#### (i) Note

The Options view does not show all available options.

- The options included in this view while ACE is running are the most used standard supported options, but are only a subset of all options available.
- The options shown in the tables below are the subset of non-advanced options in the view that are relevant to all libraries/devices. Library-specific or device-specific options are not listed within these tables.
- Power users of ACE may also configure the Options view to display all "advanced" options by setting the GUI preference under the main menu: Window → Preferences → User Advanced Preferences → Display Advanced Impl Options.
- A complete list (with descriptions) of all available library-specific, device-specific, and advanced options, along with default values and current values, is available in the Implementation Options Report (page 258), which can be generated with the report\_impl\_options (page 680) Tcl command. Be aware that the report content varies with the chosen active device/library and as new ACE releases alter the available options/values.

| Option                       | Tcl Option           | Description                                                  |
|------------------------------|----------------------|--------------------------------------------------------------|
| Target Device <sup>(1)</sup> | partname             | Specifies the name of the FPGA part for this implementation. |
| Package                      | package              | Specifies the FPGA package for the target device.            |
| Speed Grade                  | speed_grade          | Selects the desired speed grade for the target device.       |
| Core Voltage                 | core_voltage         | Selects the core voltage for the target device.              |
| Junction Temperature         | junction_temperature | Selects the junction temperature for the target device.      |

## Table 55 Project Options

| Option                          | Tcl Option                          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------------------------|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Flow Mode <sup>(2)</sup>        | flow_mode                           | <ul> <li>Evaluation mode – ignores non-fatal DRCs as long as possible, allows I/O Virtualization, and ignores missing SDC constraints to get a post-route timing report quickly.</li> <li>Normal mode – enforces all DRC checks necessary to generate a correct bitstream. Some checks are flagged as warnings early on in the flow to provide an opportunity to fix the problems (for example, fixing the placement of I/Os). These same checks may change to report an error during final DRC checks.</li> <li>Strict mode – similar to Normal flow mode, but enforces all DRC checks and errors out as early in the flow as possible.</li> <li>See also: Flow Mode (page 243)</li> </ul> |
| Enable Incremental Compile      | incremental_compile                 | Enables the ACE Incremental Compilation functionality. The<br>upstream synthesis tool must also have incremental<br>compilation enabled (Synplify Pro compile points), and the<br>necessary constraint files must be included in the ACE project,<br>otherwise ACE is unable to make use of this feature as intended.<br>See Using Incremental Compilation (Partitions) (page 404).                                                                                                                                                                                                                                                                                                         |
| Incremental Compile Mode        | incremental_compile_mode            | Incremental Compile can either be in <b>Strict</b> or <b>Smart</b> mode.<br><b>Strict</b> mode – ensures that Placement of locked instances in<br>unchanged partitions is completely preserved.<br><b>Smart</b> mode – allows ACE to attempt intelligently preserving<br>placement in locked partitions for better design performance.                                                                                                                                                                                                                                                                                                                                                      |
| Export All Partitions           | export_all_partitions               | When enabled, all leaf-level partitions are exported.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Auto-Select Top Module          | autoselect_top_module               | Specifies whether the top module name for this implementation should be automatically selected. A value of <b>1</b> automatically selects the name. A value of <b>0</b> forces use of the -top_module implementation option value.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Top Module Name                 | top_module                          | Specifies the top module name for this implementation when the -autoselect_top_module implementation option is set to <b>0</b> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Enable Final Timing Checks      | check_final_timing                  | Causes the flow to stop and error out prior to Bitstream<br>Generation if final sign off timing is not met across all<br>temperature corners.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| HDL Include Path                | hdl_include_path                    | Specifies HDL include paths for Synthesis and Simulation, in semicolon separated string format.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| HDL Defines                     | hdl_defines                         | Specifies HDL defines for Synthesis and Simulation, in space-<br>separated string format.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Use Default Project Output Path | use_default_project_output<br>_path | When enabled, uses the default output directory file path, which is the same as the ACE project file (ACXPRJ) source directory.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Project Output Path             | project_output_path                 | Provides the output directory file path for output generation.<br>Relative paths are relative to the ACXPRJ file.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| Option                                                                                                                                                                                       | Tcl Option                     | Description                                                       |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|-------------------------------------------------------------------|
| Table Notes                                                                                                                                                                                  |                                |                                                                   |
| 1. Caution: The chosen "Target                                                                                                                                                               | Device" affects other options. |                                                                   |
| Each target device can have u shared or common between o                                                                                                                                     |                                | ay even have different default values for those options which are |
| Changing the target device value may have a ripple effect upon other option values. Thus, reviewing the values of all other options after changing the target device value may be necessary. |                                |                                                                   |
| 2. Bitstream generation requires <b>Normal</b> or <b>Strict</b> flow mode.                                                                                                                   |                                |                                                                   |

## Table 56 · Simulation Options

| Option                    | Tcl Option                 | Description                                                                                                                                                                                                                                                                   |
|---------------------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Simulation Flow           | sim_flow                   | Select Default to use the built-in simulation flow scripts. Select Custom to call your own custom simulation Tcl proc, which is defined in your ACE_INIT_SCRIPT setup.                                                                                                        |
| Simulation Tool           | sim_tool                   | Determines the simulation tool to use in the simulation flow steps.                                                                                                                                                                                                           |
| Custom Simulation Command | sim_custom_command         | Custom simulation Tcl command to run simulation. This Tcl procedure should be defined in your ACE_INIT_SCRIPT setup. ACE automatically calls this Tcl procedure and adds a -sim_step <step> option to the command, which is set to one of rtl, gate, routed, or final.</step> |
| Testbench Top Module      | <pre>sim_tb_top_name</pre> | Specifies the name of the testbench top module to simulate.                                                                                                                                                                                                                   |
| Compile Simulation        | sim_ <tool>_compile</tool> | Runs the appropriate <tool> commands to compile your Verilog and/or VHDL.</tool>                                                                                                                                                                                              |
| Run Simulation            | sim_ <tool>_run</tool>     | Run the appropriate <tool> commands to run the simulation.</tool>                                                                                                                                                                                                             |

# Table 57 · Synthesis Options

| Option                | Tcl Option                    | Description                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------------|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Generate Project File | syn_use_default_pro<br>ject   | When enabled, the source Synthesis project file is automatically generated from the ACE project settings and managed by ACE in the Project/<br>Output/ <impl>/syn directory. When this option is disabled, the full file path to the synthesis project file must be specified, which then gets copied to the Project/Output/<impl>syn directory in the run_synthesis flow step.</impl></impl> |
| Project Override Path | syn_project_overrid<br>e_path | Synthesis project file override path. Use this option to specify the full file path to an existing synthesis project file to prevent ACE from automatically loading all ACXPRJ source files.                                                                                                                                                                                                  |

| Option                    | Tcl Option                | Description                                                                                                                                                                                                                                                                                                                                              |
|---------------------------|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Route Delay Model         | syn_route_delay_mod<br>el | The synthesis route delay model represents the instance and fanout-based<br>net delays synthesis uses to approximate the post-place-and-route delays.<br>Different route delay models map better to different designs. Sweeping<br>over these options using the Multi-Process ACE feature helps to find the<br>optimal setting for your specific design. |
| Fanout Limit              | syn_fanout_limit          | Specifies the maximum fanout any net can have when generating the gate level netlist. Nets that exceed the limit are cloned to reduce the fanout.                                                                                                                                                                                                        |
| Enable Retiming           | syn_retiming              | Enables the running of re-timing during synthesis.                                                                                                                                                                                                                                                                                                       |
| Default Frequency (MHz)   | syn_default_frequen<br>cy | Specifies the assumed default clock frequency in MHz for unconstrained clock domains.                                                                                                                                                                                                                                                                    |
| Advanced Synplify Options | syn_advanced_option<br>s  | Specifies a string of key value pairs for synthesis override options in Tcl list format (i.e., {{option1 val1} {option2 val2}}).                                                                                                                                                                                                                         |

# Table 58 • Place and Route Options

| Option                                          | Tcl Option                          | Description                                                                                                                                                                                                |
|-------------------------------------------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PnR Mode                                        | timing_driven_pnr                   | Timing Driven – data from timing analysis is used to<br>optimize the design for high speed.<br>Fast – placement and routing are optimized for runtime.                                                     |
| Multi-Threaded PnR                              | mt_pnr                              | Enables multi-threaded place and route. Enabling this can decrease compile time.                                                                                                                           |
| PnR Seed                                        | seed                                | Initializes the random number state in the place and route algorithms.                                                                                                                                     |
| Placement Effort                                | placement_effort                    | <b>Low</b> – placement has a shorter runtime, but may yield less<br>design QoR than High effort placement.<br><b>High</b> – increases placement runtime to further optimize the<br>design QoR if possible. |
| Router Hold-Violation Fix Limit (ps)            | router_max_hold                     | Specifies the maximum hold-time violation (in picoseconds) that the router attempts to fix.                                                                                                                |
| Post-PnR Buffer Limit                           | <pre>max_postpnr_buffer_limit</pre> | Specifies the maximum number of post-placement buffers that can be inserted.                                                                                                                               |
| Route Reset as Clock                            | route_rst_as_clock                  | Specifies the number of reset nets that should be routed on the clock network.                                                                                                                             |
| Physical Synthesis during Placement/<br>Routing | physical_synthesis                  | Specifies the use of physical synthesis during placement and routing.                                                                                                                                      |
| Place and Route driven Rewiring                 | postpnr_rewire                      | If enabled, allows rewiring during place and route to improve performance and resource usage.                                                                                                              |
| Rewiring Wide Gate Inputs                       | rewire_wide_gates                   | Enables wide gate input re-assignment.                                                                                                                                                                     |

| Option                                    | Tcl Option                                                         | Description                                                                                                                                                                                                            |
|-------------------------------------------|--------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Placement-Driven Netlist Optimizations    | <pre>post_place_netlist_optimiza tion</pre>                        | Enables placement-driven netlist optimizations.                                                                                                                                                                        |
| Clock Skew optimization                   | clock_skew_opt                                                     | <ul> <li>Specifies whether to enable clock skew optimization to increase design performance.</li> <li>O – Disabled.</li> <li>A – After clock routing.</li> <li>B – After final routing.</li> <li>12 – Both.</li> </ul> |
| Place and Route Constraint Files $^{(1)}$ | <pre>enable_project_source_file, disable_project_source_file</pre> | Allows enabling or disabling an existing project place and<br>route SDC/PDC constraint file for use in this<br>implementation flow. All constraint files defined for the<br>active project are listed.                 |
| Netlist Files                             | <pre>enable_project_source_file, disable_project_source_file</pre> | Allows enabling or disabling an existing project place and<br>route netlist file for use in this implementation flow. All<br>Netlist files defined for the active project are listed.                                  |

1. Constraint files are loaded in the order listed. To change the constraint file load order, see Adding Source Files (page 296).

| Option                         | Tcl Option               | Description                                                                                                                |
|--------------------------------|--------------------------|----------------------------------------------------------------------------------------------------------------------------|
| Timing-Driven Clustering       | timing_driven_clustering | Specifies whether timing-driven clustering is enabled during placement.                                                    |
| Fanout Control                 | fanout_control           | When enabled, nets with a fanout higher than the <b>Fanout Limit</b> are refactored.                                       |
| Fanout Limit                   | fanout_limit             | Specifies the maximum fanout any net can have when <b>Fanout Control</b> is enabled.                                       |
| Fanout Limit for Critical Nets | critical_fanout_limit    | Specifies the maximum fanout critical nets can have when <b>Fanout Control</b> is enabled.                                 |
| Isolate Bigblk loads           | isolate_bigblk_loads     | When enabled, allows replication of LUTs driving NAPs, BRAMs,<br>and FIFOs.<br><b>1</b> – enables.<br><b>0</b> – disables. |

| Option                                                 | Tcl Option                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------------------------------------------------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Resynthesis Mode                                       | synthesis_remap           | Specifies whether resynthesis should optimize for timing, area,<br>or be disabled.<br>Off – disables all resynthesis.<br>Optimize for Area – can be used to reduce the total number of<br>LUTs.<br>Optimize for Timing – can be used to improve timing, but may<br>increase area.<br>The optimizations performed depend upon the following<br>strategies chosen. If the "Place and Route" implementation<br>option, Timing-Driven PnR, is disabled, resynthesis timing<br>optimizations are also disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Rewrite Rule-1                                         | resynthesis_rewrite_rule1 | When enabled, and <b>Resynthesis Mode</b> is set to <b>Optimize for</b><br><b>Timing</b> , attempts to reduce the number of LUTs in series. In<br>critical paths, rewrite looks at the LUT programs and the<br>number of used inputs to determine where to apply the<br>transformation. The following transformation is then applied<br>when feasible:<br><b>Rewrite Rule 1</b><br><b>Uut_1 + Lut_2 + Gate1</b><br><b>Gate2</b><br><b>Uut_1 + Gate1</b><br><b>Uut_1 + Gate1</b><br><b>Uut_1 + Gate1</b><br><b>Uut_1 + Gate1</b><br><b>Uut_1 + Gate2</b><br><b>Uut_1 + Gate2</b><br><b>UUT</b> |
| Move Flip-flop Reset                                   | resynthesis_move_ff_reset | Specifies whether resynthesis moves flip-flop reset logic to LUTs when <b>Resynthesis Mode</b> is set to <b>Optimize for Timing</b> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Period of Anti-Aging Oscillator (in ns) <sup>(1)</sup> | areafill_clock_period     | Period of areafill oscillator in ns (0 to disable).<br>For anti-aging purposes, setting this option to a <b>non-zero</b> value<br>causes ACE to automatically insert logic during Run Prepare to<br>fill the area in the core fabric not consumed by the user design<br>logic, driven by a ring oscillator which toggles at the specified<br>period in nanoseconds. When <b>0</b> , disables insertion of anti-aging<br>area fill logic.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Limit Anti-Aging to Clocks Paths                       | anti_aging_onlyclock      | Use anti-aging areafill only on clock nodes. Data paths are not filled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Option                      | Tcl Option                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Virtual IO Style            | virtual_io_style                | Reduces the number of I/O pads by collapsing bussed ports.<br>Only applies in Evaluation flow mode when I/O pad utilization<br>exceeds the value of Virtual IO Utilization.<br>Off – disables this feature.<br>Stubout using Floating LUTs – converts the pads into<br>unconnected LUTs.<br>Serialize using LUTs – reduces the bus into a single pad<br>feeding a scan chain made of LUTs, with a second pad used to<br>select between "load" and "shift" modes.<br>Serialize using DFFs – builds the scan chain from DFFs,<br>allowing the boundary connections to be timed.<br>Port buses to be virtualized can be specified manually in the<br>RTL or PDC file with the port attribute, ace_virtualize, or<br>automatically by ACE. See Working with Virtual I/O (page 460) for<br>details. |
| Virtual IO Utilization      | virtual_io_utilization          | The I/O pad utilization percentage targeted by I/O<br>virtualization. Must be an integer between <b>0</b> and <b>100</b> . An error<br>is returned if the given utilization cannot be met.<br><b>0</b> – requests that all possible port buses and non-bused ports<br>are virtualized to achieve the smallest possible number of pads.<br><b>100</b> – requests that port buses and non-bused ports are to be<br>virtualized until the number of remaining ports fit in the target<br>device.                                                                                                                                                                                                                                                                                                  |
| Push Flops Into Pads        | push_flops_into_pads            | Control over whether the first level of flip-flops is to be<br>automatically pushed into the I/O pins.<br><b>Disabled</b> – turns off pushing of flip-flops into the I/O pins.<br><b>Automatic</b> – enables full automatic pushing of all possible flip-<br>flops into the I/O pins except for pins with the attribute<br>"syn_useioff=0".<br><b>Manual</b> – push flip-flops only into the I/O pins which have the<br>attribute "syn_useioff=1".<br>See Automatic Flop Pushing into I/O Pins (page 452) for details.                                                                                                                                                                                                                                                                         |
| Pad Flop Pushing Clock Type | pad_flop_pushing_clock_ty<br>pe | Controls flop pushing into I/O pins by clock type.<br><b>Boundary</b> – Only enable flop pushing into I/O pins clocked by a<br>boundary clock.<br><b>Trunk</b> – Only enable flop pushing into I/O pins clocked by a<br>trunk clock.<br><b>All</b> – Enable flop pushing into all I/O pins.<br>See Automatic Flop Pushing into I/O Pins (page 452) for details.                                                                                                                                                                                                                                                                                                                                                                                                                                |

#### Table Notes

1. Setting the Period of Anti-Aging Oscillator option to a **non-zero** value increases the size of the user design in place and route and the corresponding bitstream to near maximum size.

## Table 60 • Timing Analysis Options

| Option                                                          | Tcl Option                                   | Description                                                                                                          |
|-----------------------------------------------------------------|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------|
| Number of critical paths                                        | sync_timing_num_paths                        | Maximum number of critical paths per clock group.                                                                    |
| Number of worst paths                                           | sync_timing_num_worst                        | Maximum number of worst paths per end point.                                                                         |
| Report unconstrained paths                                      | report_unconstrained_timing_pa ths           | When enabled, ACE includes unconstrained timing paths in the timing analysis reports.                                |
| Report asynchronous<br>clear/preset to register<br>output paths | <pre>report_clear_preset_timing_pat hs</pre> | When enabled, ACE includes asynchronous clear/preset to register output timing paths in the timing analysis reports. |

## Table 61 · Report Generation Options

| Option                           | Tcl Option        | Description                                                          |
|----------------------------------|-------------------|----------------------------------------------------------------------|
| Output Obfuscated Timing Reports | report_obfuscate  | Generates obfuscated timing reports in addition to standard reports. |
| Output Partition Reports         | report_partitions | Enables partition report generation in the flow.                     |
| Output Pin Assignment Reports    | report_pins       | Enables pin assignment report generation in the flow.                |
| Output Clock Reports             | report_clocks     | Enables clock analysis and report generation in the flow.            |
| Output Placement Reports         | report_placement  | Enables placement report generation in the flow.                     |
| Output Routing Reports           | report_routing    | Enables routing report generation in the flow.                       |
| Output Power Reports             | report_power      | Enables power analysis and report generation in the flow.            |

## Table 62 · Bitstream Generation Options

| Option              |    | Tcl Option             | Description                                                                                                                                                                                                                                |
|---------------------|----|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Serial Flash (.flas | h) | bitstream_output_flash | Enables the generation of an additional serial flash formatted output<br>file, named the same as the STAPL file, but with a .flash<br>extension. Contains a binary image that can be directly loaded into a<br>single serial flash memory. |

| Option         | Tcl Option                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CPU Mode(.cpu) | bitstream_output_cpu       | Enables the generation of an additional CPU Mode formatted output<br>file, named the same as the STAPL file, but with a . cpu extension.<br>Contains hexadecimal-formatted data organized in "CPU Bus Width"<br>number of bits per file line. Data from this file is sent to the FCU CPU<br>interface line by line (one line per clock cycle) from the top to the<br>bottom of the file, where the left-most bit on each line is the MSB and<br>the right-most bit is the LSB.<br>In simulation, this file may be loaded using the readmemh<br>function. For convenience, an additional binary representation of the<br>CPU Mode output file is written, named the same as the STAPL file,<br>but with a _cpu.bin extension. The file contains the same data in<br>the same bit order as the .cpu file. |
| CPU Bus Width  | bitstream_output_cpu_width | Controls the bit width of the CPU-mode formatted output file. When<br>using the CPU interface in ×8 mode, set this value to <b>8</b> . If using the<br>CPU interface in ×128 mode, set this to <b>128</b> . Determines how many<br>bitstream bits are printed per line in the . cpu output file. The bit<br>sequence required by the FCU (and output in the generated bitstream<br>file) may be different for each CPU Bus Width setting. Therefore, it is<br>important to set this option to match the actual CPU hardware<br>interface width.                                                                                                                                                                                                                                                         |

# Table 63 · FPGA Download Options

| Option                                  | Tcl Option              | Description                                                                                                                                                                                                                                                                                                                                              |  |  |
|-----------------------------------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| JTAG Device ID (jtag_id) $^{(1)}$       | download_jtag_id        | Specifies the JTAG programming device name to which a connection is attempted during FPGA download. If not populated, auto-detection of JTAG programming devices is attempted, and the download fails if more than one JTAG device is auto-detected. The device naming schemes are described in the <i>Speedster7t Configuration User Guide</i> (UG094). |  |  |
| Single Device Scan Chain                | download_single_device  | Should be enabled when the target device is the only device on single-device JTAG scan chain. If set to <b>0</b> , the pre-IR, post-IR, an chain offset options are used to configure the scan chain.                                                                                                                                                    |  |  |
| IR Bits Before Target FPGA Device       | download_preir_padding  | Specifies the total number of instruction register bits on the JTAG scan chain prior to the target device instruction register. Used for multi-device scan chains to pad the IR chain properly with ones placing other devices in bypass mode.                                                                                                           |  |  |
| IR Bits After Target FPGA Device        | download_postir_padding | Specifies the total number of instruction register bits on the JTAG scan chain after the target device instruction register. Used for multi-device scan chains to pad the IR chain properly with ones placing other devices in bypass mode.                                                                                                              |  |  |
| Target FPGA Device Offset in Scan Chain | download_chain_offset   | Specifies the offset of the target device on the JTAG scan chain<br>for multi-device chains.<br><b>0</b> – selects the first device on the chain.<br><b>1</b> – selects the second device on the chain, etc.                                                                                                                                             |  |  |

| Option             |                      | Tcl Option                        | Description                                                                                                                                                                                            |
|--------------------|----------------------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| able Notes         |                      |                                   |                                                                                                                                                                                                        |
| or Snapshot Debugg | ger view (page 141). | The pod selection for those views | : affect Bitporter pod selection for the Download view (page 43)<br>s is a user preference, which is managed by the Configure JTAG<br>See Configuring the JTAG Connection (page 359) for more details. |

# **Outline View**

The Outline view displays a tree of all pages in the currently active IP Configuration Editor (page 9). Each page has its own title, and an icon to indicate the cumulative validity of all IP configuration contained on that page.

The information in the tree is dynamic, and changes as corresponding values are changed in the active IP Configuration Editor. As pages in the Editor are added or removed, entries in the tree are added or removed accordingly. As values in the Editor page change validity, the validity of the corresponding page in the Outline view tree also change.

In addition to showing the page validity, the Outline view provides an alternate method for navigating between the various dynamic pages of the IP Configuration Editors (page 9). Selecting (clicking) an item in the Outline view causes the IP Configuration Editor to turn to the associated page.



Figure 50 • Outline View Example

| Table | 64  | • Outline  | View    | lcons  |
|-------|-----|------------|---------|--------|
| IUNIC | UT. | · Outilite | VICVV I | 100113 |

| lcon | Description                                      |
|------|--------------------------------------------------|
| ×    | No errors or warnings on the page.               |
| ٨    | At least one warning on the page, but no errors. |
| 8    | At least one error on the page.                  |

See also: Creating an IP Configuration (page 335)

# **Partitions View**

#### (i) Note

The Partitions view is only relevant when Incremental Compilation is enabled and partitions (compile points) have been defined in the project constraints files. Otherwise, this view table is empty.

The Partitions view displays the state of the active implementation partitions, and allows (through interactions with the Floorplanner view (page 45), Search view (page 133), and Selection view (page 137)) visualizations of the partitions and their relationships with the rest of the active implementation.

The Partitions view is a default member of the Floorplanner perspective, and can be added to any other perspective by selecting **Window**  $\rightarrow$  **Show View**  $\rightarrow$  **Other...**  $\rightarrow$  **Partitions View**.

See also: Using Incremental Compilation (Partitions) (page 404)

| Partition Name                                                      | Hi_   | Timestamp                    | Clock Pre-Routes                                      | Anchor Instance                                                                        | Re-compiled | Force Re-compile . | Imported | LUTs | Flops | ALUs | LRAMs | BRAM: |
|---------------------------------------------------------------------|-------|------------------------------|-------------------------------------------------------|----------------------------------------------------------------------------------------|-------------|--------------------|----------|------|-------|------|-------|-------|
| artial_reconfig_partition_top                                       |       | Tue Oct 11 17:53:07 CDT 2022 |                                                       |                                                                                        | 4           |                    |          | 5    | 39    | 4    | 0     | 0     |
| vartial_reconfig_partition_top/pr_col_1_pr_row_1_i_partial_reconfig | ore 📕 | Tue Oct 11 17:53:07 CDT 2022 | (i_clk_pr_1_ipin_net: 2) (i_reset_n_pr_1_ipin_net: 1) | pr_col_1_pr_row_1_i_partial_reconfig_corei_reg_row_cs_block.i_axi_master.i_axi_master  |             | ~                  | ~        | 521  | 357   | 19   | 0     | 0     |
| vartial_reconfig_partition_top/pr_col_1_pr_row_2_i_partial_reconfig | ore 📃 | Tue Oct 11 17:53:07 CDT 2022 | (i_clk_pr_1_ipin_net: 2) (i_reset_n_pr_1_ipin_net: 1) | pr_col_1_pr_row_2_i_partial_reconfig_corei_reg_row_cs_block.i_axi_master.i_axi_master  |             | ~                  | ~        | 521  | 357   | 19   | 0     | 0     |
| vartial_reconfig_partition_top/pr_col_1_pr_row_3_i_partial_reconfig | ore 🛄 | Tue Oct 11 17:53:07 CDT 2022 | (i_clk_pr_1_ipin_net: 2) (i_reset_n_pr_1_ipin_net: 1) | pr_col_1_pr_row_3_i_partial_reconfig_core.i_reg_row_cs_block.i_axi_master.i_axi_master |             | ~                  | ~        | 521  | 357   | 19   | 0     | 0     |
|                                                                     |       |                              |                                                       | pr_col_1_pr_row_4_i_partial_reconfig_core.i_reg_row_cs_block.i_axi_master.i_axi_master |             | ~                  | ~        | 521  | 357   | 19   | 0     | 0     |
| artial_reconfig_partition_top/pr_col_1_pr_row_5_i_partial_reconfig  | ore 🔲 | Tue Oct 11 17:53:07 CDT 2022 | (i_clk_pr_1_ipin_net: 2) (i_reset_n_pr_1_ipin_net: 1) | pr_col_1_pr_row_5_i_partial_reconfig_corei_reg_row_cs_blocki_axi_masteri_axi_master    |             | ~                  | ~        | 521  | 357   | 19   | 0     | 0     |

### Figure 51 • Partitions View Example

#### Caution!

Resource type columns, such as Flops, BRAMs, ALUs, etc. are dynamic and change to match the target device after running the Prepare flow step. The screenshots and example descriptions in this section do not reflect the resource types of the actual device being used.

#### Table 65 • Partitions View Columns

| Column           | Description                                                                                                                                                                                                                                                               |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Partition Name   | The name of the partition as specified in the design constraints file(s).                                                                                                                                                                                                 |
| Highlight Color  | If all instances within the partition have the same highlight color, the<br>row shows a color square with that same highlight color. If even one<br>contained instance has a differing highlight color, or no highlight at all,<br>then the row displays no color square. |
| Time Stamp       | The timestamp of the last compile for this partition (compile point) in the upstream synthesis tool.                                                                                                                                                                      |
| Clock Pre-Routes | If any clock pre-routes exist for a given partition, they are listed here.                                                                                                                                                                                                |
| Anchor Instance  | The instance in the partition to "anchor" drag-and-drop operations.                                                                                                                                                                                                       |

| Column                       | Description                                                                                                                                                                                                                                        |  |  |  |  |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Re-compiled                  | Contains a checkmark if the partition was recompiled, requiring placement and routing to be re-run.                                                                                                                                                |  |  |  |  |
| Force Re-compile on Next Run | Indicates whether the partition is forced to re-compile during the next pass through ACE. This checkbox may be toggled on or off using the right-click Context Menu choices <b>Force Partition Changed</b> and <b>Un-Force Partition Changed</b> . |  |  |  |  |
| Resource                     | The sum count of all <i>resource</i> instances contained in this partition and no other partitions.                                                                                                                                                |  |  |  |  |
| Cumulative Resource          | The sum count of all contained <i>resource</i> instances, including in child partitions (below this partition in the RTL hierarchy).                                                                                                               |  |  |  |  |

A number of actions are available within the view, available in the toolbar at the top of the view and/or in right-click context menus for each partition in the table.

## Table 66 • Partitions View Actions

| lcon | Action                     | Toolbar<br>Button | Context<br>Menu | Description                                                                                                                                                        |
|------|----------------------------|-------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A    | Search for Instances       | Y                 | Y               | Issues a find Tcl command that returns the names of all the instances in the selected partition(s).                                                                |
| +    | Add Instances to Selection | γ                 | Y               | Adds the instances within the partition to the ACE Selection Set (as shown in the Selection view (page 137)).                                                      |
| 1    | Highlight                  | Y                 | Y               | Applies the currently active Highlight color to the<br>instances within the chosen partition (see<br>Highlighting Objects in the Floorplanner View (page<br>342)). |
| ×    | Un-Highlight               | Y                 | Y               | Clears the Highlight for the instances within the chosen partition.                                                                                                |
|      | Choose Highlight Color     | γ                 | Y               | Determines which color is applied to the objects<br>chosen the next time the Highlight action is selected<br>for this view.                                        |
| 1    | Auto-Highlight             | Y                 |                 | Automatically assigns a unique highlight color to each partition.                                                                                                  |
| Q    | Zoom To                    | Y                 | Y               | Zooms the Floorplanner view to a region containing the instances within the partition currently chosen in the tree.                                                |

| lcon | Action                                      | Toolbar<br>Button | Context<br>Menu | Description                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|---------------------------------------------|-------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Toggle Filter Row Visibility <sup>(1)</sup> | Y                 |                 | Changes whether the filter row (of filter icons) is visible.                                                                                                                                                                                                                                                                                                                                                                      |
| ₽.   | Configure Clock Pre-Routes                  |                   | Y               | Allows adding clock pre-route information for the selected partition(s).                                                                                                                                                                                                                                                                                                                                                          |
|      | Force Partition Changed                     |                   | Y               | Override the partition timestamp during the next pass<br>through Ace: A check mark appears in the <b>Force Re-</b><br><b>compile on Next Run</b> column, and the partition is re-<br>placed and re-routed the next time the flow is run,<br>even if there were no RTL changes and it was not re-<br>compiled in the upstream synthesis tool. <b>Un-Force</b><br><b>Partition Changed</b> removes the check mark in the<br>column. |
|      | Un-Force Partition Changed                  |                   | Y               | Removes the check mark from the <b>Force Re-compile</b><br><b>on Next Run</b> column, so the compilation timestamp<br>is no longer overridden. This is essentially an undo<br>operation for the <b>Force Partition Changed</b> action.                                                                                                                                                                                            |
|      | Export Partition                            |                   | Y               | Exports the selected partition to an .epdb file under {impl_name}/output/partitions, and exports a blackbox netlist for the partition to a .v file under {impl_name}/output/blackboxes.                                                                                                                                                                                                                                           |

#### **Table Notes**

1. Toggle Filter Row Visibility does not alter whether filters are active, it only changes the visibility of the row of filter icons.

#### (i) Note

All actions upon a partition act only upon the members of that partition, not upon the members of any child partitions.

# Drag-and-Drop

The Partitions view supports a limited set of Drag-and-Drop interactions with other views in the **Floorplanner perspective** (page 6). The view only acts as a Drag-and-Drop source; items dropped on the Partitions view are ignored.

Any row of the table may be dragged to the Tcl Console view (page 146), and when dropped anywhere in the view the partition name (with the appropriate object type prefix) is inserted at the beginning of the Tcl command-line.

Any partition in the table may be dragged to the **Placement Regions view** (page 114) or the **Floorplanner View** (page 45) (when that view has the **Placement Regions Tool** active) to assign placement region constraints (page 398). Dropping in the Placement Regions view uses the

```
add_region_find_insts (page 613)
Tcl command. Dropping onto the Floorplanner view uses the
  set_placement -partition (page 714)
```

Tcl command. Dragging a partition is the equivalent of dragging all individual instances which are members of that partition.

# Partial Reconfig Cluster Value

The partial reconfig cluster value display at the bottom of the view shows a value representing the set of all selected partition rows in the view. Selecting more or fewer rows in the view updates this value accordingly.

The Copy hex value to clipboard button copies the current value to the system clipboard.

The **Send Tcl command** button automatically issues an appropriate set\_impl\_option bitstream\_prc\_cluster\_map {partial\_reconfig\_value} command.

# **Placement Regions View**

The Placement Regions view provides a tabular representation of the content of all user-created **Placement Regions** (page 394) for the design. The view allows the manipulation of the visibility of the Placement Region itself as painted (as a colored overlay) in the **Floorplanner view** (page 45), and the content (the instances constrained to the region) of each Placement Region. The view table remains empty until the currently active implementation has completed the **Run Prepare** flow step.

Because Placement Regions are manually defined, and Instances are manually constrained to the Placement Regions, it is necessary to track the total number of sites and associated instances for each Resource type. Accordingly, based upon the chosen target device Implementation Option, there are columns for each available resource type found within the device. If more instances are ever assigned to a Placement Region than there are available sites of that type within that Placement Region, the view displays an error for that placement region and resource type combination.

The Placement Regions and Placement Region Constraints (page 394) section describes the creation and usage of Placement Regions in greater detail.

By default, the Placement Regions view is included in the **Floorplanner perspective** (page 6). To add the view to another perspective, select **Window**  $\rightarrow$  **Show View**  $\rightarrow$  **Other...**  $\rightarrow$  **Achronix**  $\rightarrow$  **Placement Regions**.

In the following example, error icons are shown for the CLK\_IPIN assignments of region\_2, indicating that too many instances (1) are assigned for the available sites (0) within the region. The region itself also shows an error icon to indicate when an erroneous resource type is scrolled offscreen.

| Visibility   | Name                                              | Ove | Clock Pre-Routes                                                            | Soft | Keep out | Include Routing | PR Zone      | LUTs      | Flops      | ALUs     | LRAM |
|--------------|---------------------------------------------------|-----|-----------------------------------------------------------------------------|------|----------|-----------------|--------------|-----------|------------|----------|------|
| $\checkmark$ | PR_ZONE_pr_col_1pr_row_1i_partial_reconfig_core   |     |                                                                             |      |          | ~               | ~            | 521/8,640 | 357/17,280 | 19/2,160 | 0/32 |
| $\checkmark$ | PR_ZONE_pr_col_1_pr_row_2_i_partial_reconfig_core |     | (i_clk_pr_1_ipin_net: 2) (i_clk_ipin_net: 1,3) (i_reset_n_pr_1_ipin_net: 1) |      |          | ~               | $\checkmark$ | 521/8,640 | 357/17,280 | 19/2,160 | 0/32 |
|              | PR_ZONE_pr_col_1_pr_row_3_i_partial_reconfig_core |     |                                                                             |      |          | ~               | ~            | 521/8,640 | 357/17,280 | 19/2,160 | 0/32 |
|              | PR_ZONE_pr_col_1_pr_row_4_i_partial_reconfig_core |     |                                                                             |      |          | ~               | $\checkmark$ | 521/8,640 | 357/17,280 | 19/2,160 | 0/32 |
| $\checkmark$ | PR_ZONE_pr_col_1_pr_row_5_i_partial_reconfig_core |     |                                                                             |      |          | ~               | $\checkmark$ | 521/8,640 | 357/17,280 | 19/2,160 | 0/32 |
|              |                                                   |     |                                                                             |      |          |                 |              |           |            |          |      |

Figure 52 • Placement Regions View Example

### (i) Note

Resource type columns, such as Flops, BRAMs, ALUs, etc. are dynamic. When the Run Prepare flow step has completed, the columns appropriate to the target device are chosen and values are updated. The resource type columns shown in the screenshots should be considered examples only — they might not match the exact resources of any particular target device.

## Table 67 · Placement Regions Table Columns

| Column           | Description                                                                                                                                                                                                                          |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Visibility       | When selected (this is user-editable), this placement region overlay is painted in the <b>Floorplanner view</b> (page 45), using the chosen translucent <b>Overlay Color</b> .                                                       |
| Name             | The name of this placement region.                                                                                                                                                                                                   |
| Overlay Color    | The (user editable) translucent color used to paint an overlay in the Floorplanner view, showing the location of the placement region.                                                                                               |
| Clock Pre-Routes | If any clock pre-routes exist for a given partition, they are listed here.                                                                                                                                                           |
| Soft             | When the placement region is created, it can be defined as a Soft region.<br>Soft regions contain a checkmark in this column. The "soft" placement<br>region status cannot be changed after creation.                                |
| Keep Out         | When the placement region is created, it can be defined as a Keep Out region. Keep Out regions contain a checkmark in this column. The "keep out" placement region status cannot be changed after creation.                          |
| Include Routing  | Treats the region as a routing constraint as well as a placement constraint, keeping all routing wires and instances inside the region boundary box.                                                                                 |
| PR Zone          | When the placement region is created, it can be defined as a Partial<br>Reconfiguration (PR) zone. PR Zone regions contain a checkmark in this<br>column. The "PR zone" placement region status cannot be changed after<br>creation. |
| Resource         | The number of <i>Resource</i> instances constrained to this placement region or the number of <i>Resource</i> sites contained within the bounds of this placement region.                                                            |

## Table 68 • Placement Regions View Actions

| lcon     | Action                            | Toolbar<br>Button | Context<br>Menu | Description                                                                                                                                                                               |
|----------|-----------------------------------|-------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | Show/Hide overlay:<br>region_name |                   | Y               | Toggles the <b>Visibility</b> checkbox for this placement<br>region, showing or hiding the colored translucent<br>overlay for the placement region in the<br>Floorplanner View (page 45). |
| <b>@</b> | Show or Hide All                  | Y                 |                 | Toggles the <b>Visibility</b> checkbox for all placement regions, showing or hiding their colored translucent overlays in the Floorplanner View.                                          |
| +        | Select Constrained Instances      |                   | Y               | Adds all Instances constrained within this placement region to the ACE Selection Set (see Selection View (page 137)).                                                                     |

## Table 69 • Placement Regions View Actions (cont.)

| lcon | Action                             | Toolbar<br>Button | Context<br>Menu | Description                                                                                                                                                                                                                                                                                               |
|------|------------------------------------|-------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ж    | Deselect Constrained Instances     |                   | Y               | Removes all Instances constrained within this placement region from the ACE Selection Set.                                                                                                                                                                                                                |
|      | Change Overlay Color               |                   | Y               | Allows the choice of which translucent Overlay Color is<br>used to represent this placement region in the<br>Floorplanner View.                                                                                                                                                                           |
|      | Reset Overlay Color                |                   | Y               | Resets the chosen placement region overlay color,<br>allowing ACE to automatically pick a new color. If the<br>overlay colors of two placement regions are too<br>similar for easy discernment, another color is pseudo-<br>randomly picked. Each time this action is chosen,<br>another color is picked. |
|      | Reset All Overlay Colors           |                   | Y               | Pseudo-randomly reassigns new overlay colors for all placement regions.                                                                                                                                                                                                                                   |
| ×    | Un-Highlight Constrained Instances | Y                 | Y               | Clears the opaque Highlight color for all instances constrained to the selected Placement Region.                                                                                                                                                                                                         |
|      | Highlight Constrained Instances    | Y                 | Y               | Highlights all instances constrained to the currently<br>selected placement region with the currently-selected<br>opaque highlight color. The highlighted results are<br>visible in the Floorplanner view (see Highlighting<br>Objects in the Floorplanner View (page 342)).                              |

| lcon      | Action                                               | Toolbar<br>Button | Context<br>Menu | Description                                                                                                                                                                                                                                                                                                                                                          |
|-----------|------------------------------------------------------|-------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | Choose Highlight Color for next<br>Highlight command | Y                 | Ŷ               | Allows the changing of the current placement region<br>constrained instances opaque highlight color (which is<br>different from the placement region translucent<br>overlay color). This opaque highlight color is used in<br>the Floorplanner view when the <b>Highlight</b><br><b>Constrained Instances</b> ( ) action is chosen in the<br>Placement Regions view. |
| Q         | Zoom to: region_name                                 | Y                 | Ŷ               | Zooms and pans the Floorplanner view to show the<br>location of the selected Placement Region (the<br>Placement Region itself is not visible as an overlay<br>unless the appropriate <b>Visibility</b> checkbox is enabled<br>in the Placement Region View table).                                                                                                   |
|           | Print Instances: region_name                         |                   | Y               | Causes a list of all Instances constrained to the<br>selected placement region to be printed in the Tcl<br>Console. Issues the<br>get_region_insts (page 660)<br>Tcl command.                                                                                                                                                                                        |
| *         | Remove All Instance Constraints                      |                   | Y               | Removes all Instances from this Placement Region, thus clearing their placement region constraints.                                                                                                                                                                                                                                                                  |
| ×         | Delete Placement Region                              |                   | Y               | Removes the selected Placement Region and all associated placement region constraints from the design.                                                                                                                                                                                                                                                               |
| <b>!.</b> | Configure Clock Pre-Routes                           |                   | Y               | Allows adding clock pre-route information to the selected partition(s).                                                                                                                                                                                                                                                                                              |
| 1         | Save Placement Regions                               | Y                 |                 | Brings up the Save Placement Regions Dialog (page 187)<br>to save one or all of the Placement Regions definitions<br>and all associated instance placement region<br>constraints.                                                                                                                                                                                    |
| 72        | Toggle Filter Row Visibility                         | Y                 |                 | Changes whether the filter row (of filter icons) at the<br>top of the table is visible or not. This does not alter<br>whether filters are active, it only changes the visibility<br>of the row of filter icons.                                                                                                                                                      |

# Using the Table to Display Placement Regions in the Floorplanner View

Each Placement Region is automatically given a unique translucent overlay color to represent the Placement Region when painting the **Floorplanner view** (page 45). By default, no Placement Region overlays are painted in the Floorplanner view. The Placement Region overlays to be displayed must be enabled. The overlay color may optionally be altered for each or all Placement Regions, but these color choices are not persistent between ACE sessions.

## (i) Note

While alternate overlay colors may be chosen for each Placement Region, these overlay colors are not saved between sessions. Each time a design is loaded, new overlay colors are automatically chosen for each Placement Region.

The following are ways to alter the presentation of Placement Region data in the Floorplanner view (page 45):

### Enable/Disable Painting of Individual Placement Regions Within the Target Device

When the checkbox in the **Visibility** column for a Placement Region is selected, the area of the target device (in the Floorplanner view) representing that Placement Region is painted in the displayed translucent overlay color. When the checkbox is unchecked, the Floorplanner view is redrawn with the chosen Placement Region overlay no longer painted.

## Enable/Disable Painting of all Placement Regions Within the Target Device

When the ( I Show/Hide All Placement Regions action is chosen, the visibility of all Placement Regions is simultaneously either enabled or disabled, causing the Floorplanner view to be repainted appropriately.

## Temporarily Alter the Overlay Rendering Color of Individual Placement Regions

The overlay rendering color of each individual Placement Region may be chosen as follows:

- 1. Right-click anywhere on the row of the desired Placement Region.
- 2. Select Choose Overlay Color from the popup context menu.
- 3. Use the Color Dialog to choose the desired color for the Placement Region.

This is a temporary color change — colors are reverted to automatically chosen defaults every time ACE starts. During a session, colors are also reverted to the defaults if any of the following are changed:

- The active design
- The active implementation
- The target device

ACE automatically picks a different overlay color for an individual Placement Region if **Reset Overlay Color** is chosen from the right-click popup content menu.

#### Temporarily Alter the Overlay Rendering Color for All Placement Regions

ACE automatically picks different overlay colors for all Placement Regions if the **Reset All Overlay Colors** action is chosen.

## **Organizing Table Data**

The following are ways to alter the presentation of the data in the Placement Regions table:

#### **Column Resizing**

The width of a column can be changed as follows:

- 1. Place the mouse cursor over the boundary between columns. The mouse cursor changes to indicate resizing is possible.
- 2. Click and drag left or right to resize the column to the desired width.
- 3. Release the mouse button.

## **Column Reordering**

The order of the columns in the table can be changed as follows:

- 1. Click and hold any column name.
- 2. Drag left or right to move the column between any other pair of columns.
- 3. Release the mouse button to insert the column header at the new location.

While dragging, the dragged column header appears alongside the mouse cursor. A thick column header separator appears at the present cursor location to show where the column insertion occurs if the mouse button is released.

## Filtering

Most table columns can filter the displayed Placement Regions by value. When filtering by column value, only Placement Regions with column values matching the filter are retained; non-matching values are excluded from the table.

- Columns containing text can be filtered by string value. Simple substring text matching (with optional wildcard) is used by default, but Regular Expression matching, also known as RegEx (see https://en.wikipedia.org/wiki/Regular\_expression), is also available. The ACE GUI RegEx matching follows Java rules (see https://docs.oracle.com/en/java/javase/11/docs/api/java.base/java/util/regex/Pattern.html), which are extremely similar to Perl rules.
- Columns with checkmarks can be filtered by boolean value.
- Columns containing numbers can be filtered by numerical value.
- Columns which may not be filtered (i.e., the **Overlay Color** column) lack a filter icon in the filter row.

#### To add a filter to a column:

- 1. The Filter row must first be visible. Select the (View) Toggle Filter Row Visibility action to show the row if necessary.
- 2. Click the ( $\Psi$ ) filter icon for the desired column, which causes a data-appropriate filter dialog to appear.
- 3. Fill in the desired filter values and click Apply to apply the filter to the rows in the table.

All values matching that filter are retained, and all other values are excluded. Additionally, the background color of the filtered column changes to a bright yellow to indicate the filter is active, and the filter icon at the head of the column also changes to the ( $\checkmark$ ) active filter icon.

To edit (or clear) an existing filter:

- 1. Click the ( $\Upsilon$ ) active filter icon, which causes the data-appropriate filter dialog to appear pre-populated with the current column filter setting.
- 2. Change the filter value and click **Apply** to edit the filter.
- 3. Click Cancel to leave the filter unchanged.
- 4. Click **Clear** to remove the filter from the column.

If the filter is cleared, the background color of the column returns to the default background color, and the filter icon also changes to the ( $\Upsilon$ ) inactive version.

# Partial Reconfig Cluster Value

The partial reconfig cluster value display at the bottom of the view shows a value representing the set of all placement regions marked as "visible" in the view. Making more or fewer placement regions visible updates this value accordingly.

The Copy hex value to clipboard button copies the current value to the system clipboard.

The **Send Tcl command** button automatically issues an appropriate set\_impl\_option bitstream\_prc\_cluster\_map {partial\_reconfig\_value} command.

# **Projects View**

The Projects view provides a hierarchical view of the projects (page 224) in the workbench (page 6). From here, projects can be added and removed, project configurations edited, the active implementation (page 231) can be chosen, saved, or restored, files may be opened for editing, etc.

Clicking an implementation **activates** (page 231) it. Similarly, clicking a project activates the first implementation in the project definition. The active project and active implementation are both displayed in a bold font.

The various source files (page 226) making up a project are added and removed from this view. Source files of the project are listed in the order in which they are loaded. To change the order the source files are listed or loaded, see Adding Source Files (page 296).

By default, the Projects view is included in the **Projects perspective** (page 6). To add it to the current perspective, click **Window**  $\rightarrow$  **Show View...**  $\rightarrow$  **Projects**.

For detailed information about managing projects, implementations, source files, etc., see Working with Projects and Implementations (page 293). See also: Project Management Preference Page (page 217).



Figure 53 • Projects View Example

| lcon | Action         | Toolbar Button | Context Menu | Description                                                                                                                                                    |
|------|----------------|----------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Þ    | Open File      |                | Y            | Opens the selected file in a text editor within ACE. See also: display_file (page 627).                                                                        |
|      | Open With      | N              | Y            | Opens the selected file with the chosen external editor.                                                                                                       |
| Ċ    | Create project | Y              |              | Opens the <b>Create Project dialog</b> (page<br>174) to allow creating a new project<br>definition in the tool. See also:<br><b>create_project</b> (page 623). |

## Table 70 • Projects View Actions

| lcon | Action                                           | Toolbar Button | Context Menu | Description                                                                                                                                                                                                                                                                             |
|------|--------------------------------------------------|----------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ¢    | Load project                                     | Y              |              | Opens the Load Project dialog (page 179)<br>to allow loading an existing ACE<br>Project file into the tool. See also:<br>load_project (page 668).                                                                                                                                       |
| দ্বি | Save project                                     | Υ              | Y            | Saves the changes to the selected ACE Project to its ACE Project file on disk. See also: <b>save_project</b> (page 708).                                                                                                                                                                |
|      | Save Project As                                  |                | Y            | Saves the selected ACE project to a newly-chosen filename and location on disk.                                                                                                                                                                                                         |
| ŝ    | Reload project                                   | Υ              | Y            | Reloads the selected ACE Project. See also: restore_project (page 689).                                                                                                                                                                                                                 |
| Ê    | Add source file                                  | Y              | Y            | This is a parent action, which allows<br>selecting between the file category<br>specific Add Source Files actions that<br>follow.                                                                                                                                                       |
| Ê    | Add IP Configuration Files                       | Υ              | Y            | Opens the Add Source Files<br>Dialogs (page 152) to allow adding<br>source IP Configuration (page 335) files<br>(.acxip) to the project for use in<br>generation of configurable IP block<br>RTL wrappers or I/O Ring design files.<br>See also:<br>add_project_source_files (page 612) |
| Ê    | Add RTL Files <sup>(1)</sup>                     | Y              | Y            | Opens the Add Source Files<br>Dialogs (page 152) to allow adding<br>source RTL files to the selected<br>project in the Projects view for use in<br>the Synthesis and Simulation flow<br>steps. See also:<br>add_project_source_files (page 612)                                         |
| Ê    | Add Synthesis Constraint<br>Files <sup>(2)</sup> | Y              | Y            | Opens the Add Source Files<br>Dialogs (page 152) to allow adding<br>source synthesis constraint files to the<br>selected project in the Projects view<br>for use in the Synthesis flow steps.<br>See also:<br>add_project_source_files (page 612)                                       |

| lcon | Action                                                 | Toolbar Button | Context Menu | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|------|--------------------------------------------------------|----------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Ê    | Add Place and Route<br>Constraint Files <sup>(3)</sup> | Y              | Y            | Opens the Add Source Files<br>Dialogs (page 152) to allow adding<br>source place and route constraint files<br>to the selected project in the Projects<br>view for use in the place and route<br>flow steps. See also:<br>add_project_source_files (page 612)                                                                                                                               |
| Ê    | Add Place and Route<br>Netlist Files <sup>(4)</sup>    | Y              | Y            | Opens the Add Source Files<br>Dialogs (page 152) to allow adding<br>source place and route netlist files to<br>the selected project in the Projects<br>view for use in the place and route<br>flow steps. <sup>(5)</sup>                                                                                                                                                                    |
| Ê    | Add Simulation<br>Testbench Files <sup>(6)</sup>       | Y              | Y            | Opens the Add Source Files<br>Dialogs (page 152) to allow adding<br>source simulation files to the selected<br>project in the Projects view for use in<br>the Simulation flow steps. See also:<br>add_project_source_files (page 612)                                                                                                                                                       |
| e s  | Import Synplify Project<br>File                        | Y              | Y            | Opens the Import Synplify Project File<br>Dialog to allow browsing to an existing<br>Synplify Pro project file (*.prj), and<br>import all of its settings into the ACE<br>project. This imports the source RTL,<br>synthesis constraints, HDL include<br>path, and all other project options, and<br>sets them in the ACE project. See also:<br>import_synplify_project_file (page<br>665). |
| ٢    | Create implementation                                  | Y              | Y            | Opens the <b>Create Implementation</b><br><b>Dialog</b> (page 170) to allow creating a new<br>project implementation definition for<br>the selected project in the Projects<br>view. See also: <b>create_impl</b> (page 622)<br>Tcl command.                                                                                                                                                |
| ٢    | Restore implementation                                 | Y              | Y            | Opens the <b>Restore Implementation</b><br><b>Dialog</b> (page 183) to allow restoring the<br>active project implementation from<br>a .acxdb Archive file. See also:<br><b>restore_impl</b> (page 688) Tcl command.                                                                                                                                                                         |

| lcon | Action                              | Toolbar Button | Context Menu | Description                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-------------------------------------|----------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Rename implementation               |                | Y            | Allows renaming the Implementation.<br>See also: <b>rename_impl</b> (page 678) Tcl<br>command.                                                                                                                                                                                                                                                                                                                                              |
| r    | Save implementation                 | Y              | Y            | Opens the Save Implementation<br>Dialog (page 184) to allow saving the<br>active project implementation to<br>a .acxdb Archive file. See also:<br>save_impl (page 706) Tcl command.                                                                                                                                                                                                                                                         |
|      | Open Multiprocess<br>Report         |                | Y            | Opens the Multiprocess Summary<br>Report (page 256) for the selected<br>project, if the project has one. See<br>also: display_file (page 627) Tcl<br>command.                                                                                                                                                                                                                                                                               |
| ф.   | Refresh contents                    | Y              | Y            | Refreshes the listing of supporting files contained within the selected project or implementation.                                                                                                                                                                                                                                                                                                                                          |
| ж    | Remove                              | Y              | Y            | Allows removing the selected items<br>from the Projects view. Removing<br>items from a project does not delete<br>the corresponding resources from the<br>file system, except for removing<br>implementation output and report<br>files. See also: remove_project (page<br>674),<br>remove_project_constraints (page 675)<br>remove_project_netlist (page 676),<br>remove_project_ip (page 675) and<br>remove_impl (page 674) Tcl commands. |
| 4    | Clone IP                            |                | Y            | Creates a duplicate of the selected IP and adds it to the project.                                                                                                                                                                                                                                                                                                                                                                          |
| ۰    | Rename IP                           |                | Y            | Renames the selected IP.                                                                                                                                                                                                                                                                                                                                                                                                                    |
|      | Add IP to another project           |                | Y            | Adds the selected IP to another project in the ACE workspace.                                                                                                                                                                                                                                                                                                                                                                               |
|      | Add copies of IP to another project |                | Y            | Adds a copy of the selected IP to another project in the ACE workspace.                                                                                                                                                                                                                                                                                                                                                                     |

| lcon | Action                            | Toolbar Button | Context Menu | Description                                                                                                                                                                                                                                                                                 |
|------|-----------------------------------|----------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Regenerate All IP Design<br>Files |                | Y            | Regenerates HDL (Verilog and,<br>optionally, VHDL), constraint files<br>(*.pdc and *.sdc), etc. for all IP<br>Design files contained in the project<br>(as found in the IP folder of the project<br>in the Projects view). See also:<br>generate_ip_design_files (page 641) Tcl<br>command. |
|      | Group reports by type             |                | Y            | If enabled, reports are grouped into subfolders in the Projects view tree.                                                                                                                                                                                                                  |
|      | Only show HTML reports            |                | Y            | If enabled, only HTML reports are shown in the Projects view tree.                                                                                                                                                                                                                          |
|      | Only show the most recent report  |                | Y            | If enabled, only the most recent report<br>is shown in any subfolder in the<br>Projects view tree.                                                                                                                                                                                          |
| Ē    | Expand all children               |                | Y            | Recursively expand all tree nodes that are children of the selected tree node                                                                                                                                                                                                               |
| E    | Collapse all children             |                | Y            | Recursively collapse all tree nodes that are children of the selected tree node                                                                                                                                                                                                             |

#### **Table Notes**

- 1. RTL files are loaded by the Synthesis and Simulator tools in the same order they are displayed within this view. For details on how to change this display/load order, see Adding Source Files (page 296).
- 2. Synthesis Constraint files are loaded by the Synthesis tool in the same order they are displayed within this view. For details on how to change this display/load order, see Adding Source Files (page 296).
- 3. Place and Route Constraint files are loaded by ACE in the same order they are displayed within this view. For details on how to change this display/load order, see Adding Source Files (page 296).
- 4. Place and Route Netlist files are loaded by ACE in the same order they are displayed within this view. For details on how to change this display/load order, see Adding Source Files (page 296).
- 5. The Run Synthesis flow step automatically adds the generated synthesized netlist file to the ACE project place and route netlists after it successfully completes, so there is no need to manually add the synthesized netlist file if running the Run Synthesis flow step. See also: add\_project\_source\_files (page 612).
- 6. Simulation Testbench files are loaded by the Simulator tool in the same order they are displayed within this view. For details on how to change this display/load order, see Adding Source Files (page 296).

### Table 71 • Project View Icons

| lcon                                                                                                            | Description                        |
|-----------------------------------------------------------------------------------------------------------------|------------------------------------|
| È                                                                                                               | Project.                           |
| 1                                                                                                               | Project (Active).                  |
| <b>F</b>                                                                                                        | Project (Save Needed).             |
| <b>F</b>                                                                                                        | Project (Active, Save Needed).     |
| ٠                                                                                                               | Implementation.                    |
| ۲                                                                                                               | Implementation (Active).           |
|                                                                                                                 | File.                              |
| ē                                                                                                               | Folder.                            |
| ÷                                                                                                               | Folder containing unsaved changes. |
| ۵                                                                                                               | IP file.                           |
| 4                                                                                                               | IP file with warnings.             |
| <b>4</b> 2                                                                                                      | IP file with errors.               |
| 1990 - 1990 - 1990 - 1990 - 1990 - 1990 - 1990 - 1990 - 1990 - 1990 - 1990 - 1990 - 1990 - 1990 - 1990 - 1990 - | IP file with unsaved changes.      |

### (i) Note

Some files in the "Constraints" or "Netlists" sections of the tree may appear greyed-out to indicate that those constraint files are not enabled in the Active implementation (page 231) as shown in the following figure. Various constraint files in a project can be enabled or disabled for an implementation in the Options view (page 100), under **Design Preparation**  $\rightarrow$  **Constraint Files**.



Figure 54 • Disabled Constraints File Example

# **Properties View**

The Properties view can provide in-depth specifics about many types of pin, net, and instance items on demand, and the view then allows navigating many of the relationships between connected items.

To initialize the Properties view with desired information, use the **Display Properties For...** choices found on the right-click context menus of many of the views within the Floorplanner Perspective. The **display\_properties** (page 628) Tcl command can also be used to populate the Properties view.

| 🕆 Netlist Browser | 🔋 Netlist Browser 🖾 🔯 Clock Domains |                                                   |                          |              |           |         |        |   |
|-------------------|-------------------------------------|---------------------------------------------------|--------------------------|--------------|-----------|---------|--------|---|
| Instance Name     |                                     |                                                   | Hig                      | Cell Type    | Clock Dom | Core    | IORing |   |
| 🗉 🌐 X_ADDSUB48    | 🗉 🌐 X_ADDSUB48                      |                                                   |                          |              | clk       | ~       |        |   |
| 🔒 a[0]_ipin       |                                     |                                                   |                          | IPIN         | clk       | ~       |        |   |
| 🔒 a[10]_ipin      |                                     |                                                   |                          | IPIN         | clk       | <b></b> |        |   |
| 🔒 a[11]_ipin      | ÷                                   | Add Instanc                                       | e to Se                  | lection      |           |         |        |   |
| 🔒 a[12]_ipin      |                                     | I Ende Endet Instance                             |                          |              |           |         |        | E |
| 🔒 a[13]_ipin      |                                     | Highlight Instance                                |                          |              |           |         |        |   |
| 🔒 a[14]_ipin      |                                     | Choose Highlight Color for next Highlight command |                          |              |           |         |        |   |
| 🔒 a[15]_ipin      | Q                                   | Zoom To Instance                                  |                          |              |           |         |        |   |
| 🔒 a[16]_ipin      |                                     | Zoon to instance                                  |                          |              |           |         |        |   |
| 🔒 a[17]_ipin      |                                     | Show Instan                                       | Show Instance in Netlist |              |           |         |        | Г |
| 🔒 a[18]_ipin      | (≡                                  | Display Prop                                      | erties                   | for Instance |           |         |        |   |
| 🔒 a[19]_ipin      | a                                   | Unfix Placen                                      | nent of                  | Instance     |           |         |        |   |
| 🔒 a[1]_ipin       |                                     | Unplace Inst                                      |                          | matanet      |           |         |        |   |
| 🔒 a[20]_ipin      |                                     | onplace inst                                      | ance                     | IFUN         | CIN       |         |        | _ |

Figure 55 • Properties View Example

# **General Tab**

The **General** tab shows the basic, top-level information about the item.

|                            | Instance: X_ADDSUB48.X_DSP64_A                                   |
|----------------------------|------------------------------------------------------------------|
| Property                   | Value                                                            |
| Instance Name              | X_ADDSUB48.X_DSP64_A                                             |
| Highlight Color            |                                                                  |
| Cell Type                  | DSP64                                                            |
| Clock Domains              | clk (Target Frequency: 700.28)                                   |
| Core/IO Ring               | Core                                                             |
| Placed                     | Yes                                                              |
| Placed on Site             | x_core.DSP[0][6].logic.dsp                                       |
| Partition                  |                                                                  |
| Placement Region           | region_0                                                         |
| Source Netlist File        | ~/code/projectssp_addsub48/common/tapeout_ab_dsp_addsub48_gate.v |
| Source Netlist Line Number | 214                                                              |

Figure 56 • General Tab Example

#### (i) Note

Double-click a **Source Netlist File** filename to immediately open that file in the Editor area, or double-click a **Source Netlist Line Number** to immediately open the source netlist file, showing the given line number, in the Editor area.

# **Parameters Tab**

The **Parameters** tab shows the type, name, and value of all of the configurable parameters for the item.

| Properties  | 8                    |                 | H | 000 |   |
|-------------|----------------------|-----------------|---|-----|---|
|             | Instanc              | e: ina_int_Z[1] |   |     |   |
| Туре        | Name                 | Value           |   |     |   |
| Parameter   | LOCATION             |                 |   |     |   |
| Parameter   | config_toggle_clk    | 0               |   |     |   |
| Parameter   | enable_initial_token | 1               |   |     |   |
| Parameter   | init                 | 0               |   |     |   |
| Parameter   | retain_token         | 0               |   |     |   |
|             |                      |                 |   |     |   |
|             |                      |                 |   |     |   |
|             |                      |                 |   |     | _ |
|             |                      |                 |   |     | _ |
|             |                      |                 |   |     | _ |
| General Par | ameters Pins         |                 |   |     |   |

Figure 57 • Parameters Tab Example

# Pins Tab

The **Pins** tab shows a variety of information about the item pins.

|           |          |       |                      |            | Instance: ina_int_Z[1                          | ]                 |              |                  |                                       |
|-----------|----------|-------|----------------------|------------|------------------------------------------------|-------------------|--------------|------------------|---------------------------------------|
| Direction | Pin Name | Туре  | Net Name             | Net Fanout | Driving Pin                                    | Driver Cell Type  | Clock Domain | Target Frequency | Placed on Site Pin                    |
| Input     | ck       | Clock | clka_c               | 19         | clka_ibuf.x_ipad.i_bit_module_rx_clk:oclkbit_y | bit_module_rx_clk | clka         | 10               | x_core.L[0][318].rlb.hlc[1].seq_b:clk |
| Input     | d        | Data  | net_ina_c[1]_sac_cdc | 1          | ina_c[1]_sac:dout                              | SAC               | Unspecified  |                  | x_core.L[0][318].rlb.hlc[1].seq_b:d   |
| Output    | q        | Data  | ina_int[1]           | 1          | ina_int_Z[1]:q                                 | DFF               | clka         | 10               | x_core.L[0][318].rlb.hlc[1].seq_b:q   |

## Figure 58 • Pins Tab Example

A number of actions are available on the Pins tab right-click menus as shown in the following table.

### Table 72 • Properties View Pins Tab Actions

| lcon | Action                         | Advanced | Description                                                                                                                                             |
|------|--------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Copy Cell Text                 |          | Copies the text onto the system clipboard.                                                                                                              |
| +    | Add to Selection               |          | Adds the item to the ACE selection set (as shown in the Selection view (page 137)).                                                                     |
|      | Remove from Selection          |          | Removes the item from the ACE selection set (as shown in the <b>Selection view</b> (page 137)).                                                         |
| 1    | Highlight                      |          | Applies the currently active highlight color to the chosen item (see Highlighting Objects in the Floorplanner View (page 342)).                         |
|      | Choose Highlight Color         |          | Determines which color is applied the next time the Highlight action is selected.                                                                       |
| Q    | Zoom To                        |          | Zooms the Floorplanner view to an area containing the item.                                                                                             |
|      | Show in Netlist <sup>(1)</sup> |          | Attempts to open a text editor to the file and line<br>number relevant to the chosen item (available<br>only when a single item is chosen in the view). |
| =    | Display Properties             |          | Display properties for the chosen item in the<br>Properties view.                                                                                       |

| Table Notes                                     |  |                       |                                                  |  |  |
|-------------------------------------------------|--|-----------------------|--------------------------------------------------|--|--|
| Table Notes                                     |  |                       |                                                  |  |  |
| 1. <b>Caution:</b> The Sho<br>to the expected I |  | early access functior | nality and might not always open the text editor |  |  |

### (i) Note

#### **Reminder: Instances Selection color vs Highlight color priority**

• With default preference settings, in the Floorplanner view (page 45), highlight colors of (placed) instances are only visible when the Instances layer is enabled, and the instances are not members of the ACE selection set. This behavior is due to the instance selection color having a higher priority than the highlight color.

#### **Properties Navigation**

- Move from one item to another by using the **Display Properties** right-click menu items in the Pins tab.
- Use **Display Properties** to move between related pins, nets, and instances.

# **Diagram Tab**

Some items are complicated or interesting enough to warrant a supplemental diagram. For these types of items, a diagram showing the current item configuration can be found on the **Diagram** tab. Tooltips over the diagram can provide supplemental information where useful.



Figure 59 • Diagram Tab Example

# **Save Properties**

The **Save Properties** action can be used to save all changed properties on objects in the database after Prepare has been run. See the **save\_properties** (page 708) Tcl command reference for details.

This action can be performed by clicking Save Properties on the Properties view tool bar:





# **Register Browser View**

The Register Browser view can be used to read/write values from/to actual hardware using the (e)FPGA JTAG interface with Tcl commands (see the *JTAG Configuration User Guide* (UG004) for details about the available Tcl commands). The view is typically used for very targeted interactions with a connected FPGA. This tool is not designed for efficient bulk reads of block RAM.

#### Caution!

#### **JTAG Connection Requirement**

To use the Register Browser view, a valid JTAG connection is required. See **Configuring the JTAG Connection** (page 359) and the **Configure JTAG Connection Preference Page** (page 193).

Be aware that not all Achronix FPGAs support Register Browser functionality. If the target FPGA for the active implementation does not support this functionality, the view is not interactive.

Values can be read from or written to hardware by right-clicking any row in the table and choosing **Read Values From Chip** or **Write Values To Chip** in the popup context menu. All child rows are read from or written to as well.

The Register Browser interacts with the FPGA at the register level with all reads and writes happening at that level. When writing register field values to hardware, the entire register value is updated via a read-modify-write operation, combining the current hardware register value with the updated register field values.



Figure 61 • Register Browser View Example

When the view first appears, even if a compatible device is connected and running, no current register values are pre-populated in the table. Values are only read from the device when commanded to do so. Drill down to just the specific register values needed to query. Be aware that the more rows read or written at a time, the longer it takes. Be careful not to read or write more than is needed.

The tree of register namespaces is organized hierarchically by memory addresses and by conceptual relationships. Fields which are read-only have their entire row colored with a blue background.

Fields with a green background in the **Update Value** column are writable but have not been given a value to be written. Click in any of these cells to enter a hexadecimal value to be written to that field. Invalid values or values that are too large for the given register field are rejected automatically.

When any field within a register has its **Update Value** populated, the background of the field being edited plus those of all other fields within that same register turn yellow, indicating a write is pending but has not yet been committed. The **Update Value** column shows a register value combining the current hardware value of the register (as of the last time one of the fields of that register was edited) combined with any register field values just entered. Put another way, the current register value is read from hardware, and then any values in the yellow register fields for that register are applied to it.

When using **Write Values To Chip**, the current register value at that time is read into ACE, any register field values entered are applied to it, and the updated register value is written back to the device. The **Last Value** column is updated for the register and all fields within that register. All register writes are always performed as a read-modify-write, including when all fields within the register are being edited.

# Search View

The Search view provides an interface for searching the ACE design database for design objects (instances, nets, ports, pins, sites, and paths), displaying the results of a search in a list, organized by object type. Optionally, all or part of the results of a search can be added to the current ACE Selection Set, as displayed in the Selection view (page 137). The Search view is a graphical interface to the find (page 638) Tcl command.

Instances and Ports in the results list may be dragged and dropped onto the Floorplanner view (page 45) to assign placement or add placement region (page 394) constraints (the behavior depends upon the Floorplanner active tool/ mode). Instances and paths in the results list may be dragged to the Placement Regions view (page 114) to add placement region constraints.

By default, the Search view is included in the Floorplanner perspective (page 6). To add it to the current perspective, select **Window**  $\rightarrow$  **Show View...**  $\rightarrow$  **Search**.

See also: Object Type Prefixes (page 334)

#### (i) Note

A maximum of 200 objects are displayed in the Search view at a time. Use the arrow buttons ( $\hookrightarrow$  and  $\Rightarrow$ ) on the view toolbar to page through the full set of search results.



Figure 62 • Search View Example

| lcon       | Description                                                            |
|------------|------------------------------------------------------------------------|
| Θ          | Object (unplaced instances and ports; all pins, nets, and paths).      |
| ~          | Placed Object (applies to instances and ports).                        |
| ۵          | Fixed-Placed Object (applies to instances and ports).                  |
| <b>#</b>   | I/O Macro (applies to ports).                                          |
| ••         | Instances (all instances are under this branch of the search results). |
| ۷          | Ports (all ports are under this branch of the search results).         |
| -19<br>-19 | Pins (all pins are under this branch of the search results).           |
| e[ie       | Nets (all nets are under this branch of the search results).           |
| •+•        | Paths (all paths are under this branch of the search results).         |
| 8          | Sites (All sites are under this branch of the search results).         |

### Table 73Search View Icons

Many of the actions in the Selection view are available as both toolbar buttons and right-click context menu choices. Toolbar buttons typically act upon all the listed Search results items, while context menu actions only affect the subset of items currently chosen within the Results list.

### Table 74 · Search View Actions

| lcon | Action                          | Toolbar Button | Context Menu | Description                                                                                           |
|------|---------------------------------|----------------|--------------|-------------------------------------------------------------------------------------------------------|
| A    | Find objects                    | Υ              |              | Searches for objects in the ACE design<br>database using the search criteria<br>from the Search view. |
| ⇔    | Display next 200 results        | Υ              |              | Displays the next 200 objects in the search results list.                                             |
| ¢    | Display previous 200<br>results | Υ              |              | Displays the previous 200 objects in the search results list.                                         |

| lcon | Action                              | Toolbar Button | Context Menu | Description                                                                                                                                                                                                                        |
|------|-------------------------------------|----------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ÷    | Add to selection                    | Y              | Y            | Adds all objects that are currently<br>chosen in the Search view "Results"<br>list to the current selection set (as<br>displayed in the Selection View).                                                                           |
|      | Remove from selection               |                | Y            | Removes all objects that are currently<br>chosen in the Search view "Results"<br>list from the current selection set (as<br>displayed in the Selection View).                                                                      |
| ×    | Un-highlight Results <sup>(1)</sup> | Y              | Y            | Turns off the highlight color for objects.                                                                                                                                                                                         |
| ø    | Highlight Results                   | Y              | Y            | Highlights objects with the currently-<br>selected search highlight color. The<br>highlighted results are visible in the<br>Floorplanner view (other views are not<br>affected by highlights).                                     |
|      | Choose Highlight Color              | Y              |              | Allows changing the current highlight<br>color for search result highlighting.<br>This color is used in the Floorplanner<br>view when the Search view ( <i>I</i> )<br><b>Highlight Results</b> button is clicked.                  |
| Q    | Zoom To Object                      |                | Y            | Zooms the Floorplanner view to a region containing the item currently chosen in the results list.                                                                                                                                  |
|      | Show in Netlist <sup>(2)</sup>      |                | Y            | If relevant data exists, opens a text<br>editor to the file and line number<br>relevant to the chosen result item<br>(available only when a single item is<br>chosen in the results list, and that item<br>is an Instance or Net). |
| ۵    | Fix Placement of<br>Instance        |                | Y            | Causes the placement state of the chosen Instance to change from unfixed (or soft) to Fixed.                                                                                                                                       |
| ì    | Unfix Placement of<br>Instance      |                | Y            | Causes the placement state of the chosen Instance to change from Fixed to unfixed (soft).                                                                                                                                          |
|      | Unplace Instance(s)                 |                | Y            | Unplaces all Instances currently chosen in the results list.                                                                                                                                                                       |

| lcon | Action                                 | Toolbar Button | Context Menu | Description                                                                                                                                           |
|------|----------------------------------------|----------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| -    | Save Placement Using<br>Search Results | Y              |              | Opens the Save Placement Dialog (page<br>185), pre-populating its <b>Specific List of</b><br><b>Instances</b> field with the current search<br>query. |

#### **Table Notes**

- 1. The Un-highlight Results button stops highlighting the search results in the Floorplanner view. Other views are not affected by highlighting.
- 2. The Show in Netlist action is early access functionality and might not always open the text editor to the expected location.

## Table 75• Search View Options

| Option                   | Description                                                                                                                                                                                                  |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Patterns                 | Enter a Tcl regular-expression pattern which is used to perform a name-based search. Previously used search patterns may be selected from the drop-down menu.                                                |
| Filters                  | Enter a search filter to further restrict the search results by properties other than name. Previously used search filters may be selected from the drop-down menu. See <b>Filter Properties</b> (page 264). |
| (Search Filter Builder)  | This button opens the <b>Search Filter Builder Dialog</b> (page 189) providing a guide through the options available for search filters.                                                                     |
| Instances <sup>(1)</sup> | When checked, includes Instances in the search results.                                                                                                                                                      |
| Ports <sup>(1)</sup>     | When checked, includes Ports in the search results.                                                                                                                                                          |
| Pins <sup>(1)</sup>      | When checked, includes Pins in the search results.                                                                                                                                                           |
| Nets <sup>(1)</sup>      | When checked, includes Nets in the search results.                                                                                                                                                           |
| Paths <sup>(1)</sup>     | When checked, includes Paths in the search results.                                                                                                                                                          |
| Sites <sup>(1)</sup>     | When checked, includes Sites in the search results.                                                                                                                                                          |
| Add Results to Selection | If selected when a search is performed, all the results of that search are added to the ACE selection set.                                                                                                   |

| Option                                                                       | Description                                                         |
|------------------------------------------------------------------------------|---------------------------------------------------------------------|
| Table Notes         1. Caution: If none of the object-type opt were checked. | ion checkboxes are checked, the search is performed as if all types |

### Search Results and ACE Selection

The complete results of a search may be added to the current ACE Selection Set (and thus rendered in a special color, by default a bright green, in the Floorplanner view) by checking the **Add Results to Selection** checkbox before starting the search. A subset of the search results may be added to the current ACE selection set by selecting the

desired additions in the search "Results" list and pressing the ( 📌 ) Add to Selection button, or, double-clicking a single entry in the "Results" list adds it to the current selection.

### Search Highlights

There is typically a tremendous amount of visualization data available in the Floorplanner view. The granular highlighting allowed by the Search view, the Selection view, and the Highlight functionality (see Highlighting Objects in the Floorplanner View (page 342)) is an attempt to help turn this data into useful information, to find and focus on specific information within the user designs.

By highlighting multiple search result sets in the same or different colors, desired information is made more visible in the graphical views. By selectively un-highlighting or re-highlighting smaller (more specific) result sets (which are a subset of already-highlighted objects), focus may be directed to just the objects of interest.

When used in combination with the layering functionality (see the Layers portion of the toolbox for the Floorplanner view) and Selection functionality (see the Selection view (page 137) as well as the select (page 709) and deselect (page 625) Tcl commands), a graphical visualization can be achieved at whatever granularity is desired.

#### Caution!

The selection color takes precedence over the highlight color by default. If design objects are both highlighted and selected, they are painted the selection color (bright green by default) in the Floorplanner view. To see the design objects painted in the highlight color (with default precedence settings), the objects must first be removed from the current selection set (as shown in the Selection view). The Floorplanner view settings (including precedence) for highlight and selection colors can be manipulated on the **Floorplanner View Colors and Layers Preference Page** (page 198).

## Selection View

The Selection view provides an interface that allows viewing and managing the current selection set. A selection set consists of a collection of ACE design database objects. The selection set may also be manipulated with the **select** (page 709) and **deselect** (page 625) Tcl commands.

The Selection view displays the current selection set in a list, organized by object type. The object type groupings are Instances, Ports, Pins, Nets, Paths, and Sites; these are the only object types which may be Selected.

### (i) Note

A maximum of 200 objects are displayed in the Selection view at a time. Use the arrow buttons (  $\hookrightarrow$  and  $\Rightarrow$  ) on the view toolbar to page through the full content of the ACE selection set.

The current page of selected objects in the Selection view is also displayed with special coloration (by default a bright green) in the **Floorplanner view** (page 45).

Objects may be added to the selection set from the Search view (page 133) if Add Results to Selection is checked when a search is issued, or by choosing individual objects from the search results and selecting Add to Selection, or from the Floorplanner view (see Selecting Floorplanner Objects (page 340)).

Various drag-and-drop operations may be initiated by dragging single or (in some cases) multiple items from the selection list to other views in the Floorplanner perspective. If dragging all selected objects of a given type (i.e., Instances), including those not in the current page of 200 selected objects, the node with that type name (i.e., Instances) may be dragged. Be aware that some drag-and-drop operations, such as pre-placement assignment, does not work with multiple, simultaneously selected objects.

Instances and Ports in the selection list may be dragged and dropped onto the Floorplanner view to assign preplacement or add **placement region** (page 394) constraints. The behavior depends upon the active Floorplanner tool or mode. Instances and Paths in the results list may be dragged to the **Placement Regions view** (page 114) to add placement region constraints.

By default, the Selection view is included in the Floorplanner perspective (page 6). To add it to the current perspective, select Window  $\rightarrow$  Show View...  $\rightarrow$  Other...  $\rightarrow$  Selection.



Figure 63 • Selection View Example

| lcon              | Description                                                       |
|-------------------|-------------------------------------------------------------------|
| ٥                 | Object.                                                           |
| ~                 | Placed Object (applies to instances and ports).                   |
| <b>a</b>          | Fixed-Placed Object (applies to instances and ports).             |
| <b>#</b>          | I/O Macro (applies to ports).                                     |
| **                | Instances (all instances are under this branch of the selection). |
| ۲                 | Ports (all ports are under this branch of the selection).         |
| -10<br>-10<br>-10 | Pins (all pins are under this branch of the selection).           |
| e[ie              | Nets (all nets are under this branch of the selection).           |
| e He              | Paths (all paths are under this branch of the selection).         |
| 99                | Sites (all sites are under this branch of the selection).         |

Many of the actions available in the Selection view are available as both toolbar buttons and right-click context menu choices. Toolbar buttons act upon all the listed Selection items, while context menu actions only affect the subset of items currently chosen within the Selection list. Be aware that available right-click context menu choices vary depending upon the context: the number and the type of the items alter the available actions.

### Table 77 · Selection View Actions

| lcon | Action                       | Toolbar Button | Context Menu | Description                                                                                                        |
|------|------------------------------|----------------|--------------|--------------------------------------------------------------------------------------------------------------------|
| Q    | Zoom to Full Selection Set   | γ              |              | Zooms the Floorplanner view to a region<br>containing the current list of chosen objects in<br>the Selection view. |
| Q    | Zoom to Object               |                | Y            | Zooms the Floorplanner view to a region containing the currently chosen object in the Selection view.              |
| ⇔    | Display next 200 objects     | γ              |              | Displays the next 200 objects in the selection set.                                                                |
| ¢    | Display Previous 200 objects | Y              |              | Displays the previous 200 objects in the selection set.                                                            |

| lcon                   | Action                                        | Toolbar Button | Context Menu | Description                                                                                                                                                                                                                                                                                   |
|------------------------|-----------------------------------------------|----------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ×                      | Deselect object                               | Ŷ              | Y            | Deselects objects in the Selection view list,<br>removing them from the current selection set in<br>ACE.                                                                                                                                                                                      |
| *                      | Deselect all objects                          | γ              |              | Deselects all objects in the current selection set<br>in ACE, resulting in an empty selection set.                                                                                                                                                                                            |
| X                      | Un-Highlight Selection <sup>(1)</sup>         | Υ              | Y            | Turns off the highlight color for objects in the current selection.                                                                                                                                                                                                                           |
| 1                      | Highlight Selection                           | Y              | Y            | Sets the highlight color for objects in the curren<br>ACE selection set to the currently-chosen<br>highlight color (the highlight coloring is only<br>visible in the Floorplanner view after the object<br>are no longer Selected, since the Selection colo<br>overrides the highlight color. |
|                        | Choose Highlight Color                        | Y              |              | Allows changing the current ACE selection set<br>highlight color (which is different from and<br>overridden by the Selection color). This color is<br>used in the Floorplanner view when the (<br>Highlight Selection action is chosen in the<br>Selection view.                              |
|                        | Show in Netlist <sup>(2)</sup>                |                | Y            | If relevant data exists, opens a text editor to the<br>file and line number relevant to the chosen<br>Selection item (available only when a single iter<br>is chosen in the Selection list, and that item is a<br>Instance or Net).                                                           |
| Fix Instance Placement |                                               |                | Y            | Causes the placement state of the Instance<br>under the mouse cursor to change from unfixed<br>(or soft) to Fixed.                                                                                                                                                                            |
| ì                      | Unfix Instance Placement                      |                | Y            | Causes the placement state of the Instance<br>under the mouse cursor to change from Fixed t<br>unfixed (or soft).                                                                                                                                                                             |
|                        | Unplace Instance(s)                           |                | Y            | Unplaces the Instances chosen in the view.                                                                                                                                                                                                                                                    |
|                        | Unplace All Instances in ACE<br>Selection Set |                | Y            | Unplaces all Instances that are members of the current ACE selection set.                                                                                                                                                                                                                     |
| ~                      | Save Placement of Selection Set               | Y              |              | Opens the Save Placement Dialog (page 185), pre<br>populating its <b>Specific List of Instances</b> field<br>with the query to obtain the active Selection se                                                                                                                                 |

#### Table Notes

- 1. Stops highlighting the ACE selection set in the Floorplanner view. Other views are not affected by highlighting.
- 2. The Show in Netlist action is early access functionality and may not always open the text editor to the expected location.

For more information about the interaction between Selection and Highlighting, please see Search Highlights (page 137) as well as Highlighting Objects in the Floorplanner View (page 342).

See also: Object Type Prefixes (page 334).

## **Snapshot Debugger View**

The Snapshot Debugger view provides a graphical interface for controlling an embedded Snapshot IP block in a programmed Achronix device. By default, the Snapshot Debugger view is included in the **Programming and Debug Perspective** (page 6). To access the Snapshot Debugger view from any other perspective, select **Window**  $\rightarrow$  **Show View**  $\rightarrow$  **Other...**  $\rightarrow$  **Achronix**  $\rightarrow$  **Snapshot Debugger**.

This view allows running the Snapshot Debugger (page 363) embedded in the design. A simple button press collects live sample data (page 375) in a VCD file. This view also allows configuring the debug capture trigger pattern(s) (page 366), configuring a test stimulus (page 371), and configuring the data capture ranges (page 373) before and after the trigger(s).

For convenience, favorite Snapshot configurations can be ( 🔛 ) saved (page 386) and ( 🔄 ) loaded (page 386) via the view toolbar buttons. Saved configurations may also be used to drive the snapshot in Batch mode (page 387) via Tcl.

#### 🕑 Tip

When a user design containing the ACX\_SNAPSHOT macro completes the **Flow step** (page 235) **Run Prepare**, a names . snapshot configuration file, is automatically generated. This file contains harvested information from the design including the widths, depths and signal names for the monitor, trigger, and stimuli busses, user clock frequency, and default log and .vcd file path settings. When an **active Project and Implementation** (page 231) is available, the Snapshot view automatically loads the names.snapshot file to pre-populate the relevant fields of the view.

#### (i) Note

When the names.snapshot file is generated, the file contains only a subset of a complete Snapshot configuration, and thus a generated names.snapshot file should not be used to drive **Snapshot in batch mode** (page 387) via Tcl.

See also: Running the Snapshot Debugger (page 363), Assign Bussed Values Dialog (page 157), Assign Bussed Signal Names Dialog (page 155), VCD Waveform Editor (page 11), and the *Snapshot User Guide* (UG016).

#### Table 78 Snapshot Debugger View Toolbar Buttons

| lcon | Action       | Description                                                                                                                                                                                                                                                                                                                                        |
|------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | Arm Snapshot | <ol> <li>Performs the following steps:         <ol> <li>Sends the trigger conditions configuration to the Snapshot Debugger core.</li> <li>Send the Stimulus value to the design-under-test.</li> <li>Waits for the trigger condition to be met.</li> <li>Retrieves the trace buffer contents.</li> <li>Outputs a VCD file.</li> </ol> </li> </ol> |

| lcon     | Action                              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | Cancel Snapshot                     | Cancels the ( 💟 ) <b>Arm Snapshot</b> by stopping the polling process and then resetting the ACX_SNAPSHOT macro.                                                                                                                                                                                                                                                                                                                                         |
| Þ        | Save Snapshot<br>Configuration      | Saves the current settings of the Snapshot view to a text file. See Saving/Loading Snapshot Configurations (page 386).                                                                                                                                                                                                                                                                                                                                   |
| Þ        | Load Snapshot<br>Configuration      | Loads a previously saved configuration file. See Saving/Loading Snapshot Configurations (page 386).                                                                                                                                                                                                                                                                                                                                                      |
| Q,       | Capture Snapshot<br>Startup Trigger | <ul> <li>Requires that the initial startup trigger parameters on the ACX_SNAPSHOT macro have been configured to enable the Startup Trigger feature, and that the Arm Snapshot action has not been executed since the bitstream has been programmed.</li> <li>Performs the following steps: <ol> <li>Waits for the startup trigger condition to be met.</li> </ol> </li> <li>Retrieves the trace buffer contents.</li> <li>Outputs a VCD file.</li> </ul> |
| <b>₽</b> | Configure JTAG<br>Interface         | Opens the preferences dialog with the Configure JTAG Connection Preference Page (page 193) visible.<br>See Configuring the JTAG Connection (page 359).                                                                                                                                                                                                                                                                                                   |

|                  |                   | 0 🖇 🖻          | 2 😰 🏢 🛃       |                              | . 20 8                                                                                    |                                                                                                                               |                  |
|------------------|-------------------|----------------|---------------|------------------------------|-------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|------------------|
| apshot Debug     | ger 🛛             | 1              |               | 🔍 🔕 🔳 🎼 🛱                    |                                                                                           | snapshot.log                                                                                                                  |                  |
| igger Mode       |                   | Single         |               |                              | ~ ^                                                                                       |                                                                                                                               |                  |
| umber of Seq     | uential Triggers  | 3              |               |                              | $\sim$                                                                                    | Name Value                                                                                                                    |                  |
| igger Channe     | l Width           | 38             |               |                              | ~                                                                                         | l≣ counter_a[7:0] 20 1a 1b 1c 1d 1e 1f 2                                                                                      | 20 21 22         |
| Trigger Chanr    |                   |                |               |                              |                                                                                           | - counter_a[7] 0                                                                                                              |                  |
|                  |                   |                |               |                              |                                                                                           | counter_a[6] 0                                                                                                                |                  |
| Channel          | Trigger 1         | Trigger 2      | Trigger 3     | Signal Name                  | ^                                                                                         | •- counter_a[5] 1                                                                                                             |                  |
| 11               | 0                 | X              | X             | counter_a[0]                 |                                                                                           | counter_a[4] 0                                                                                                                |                  |
| 12               | X                 | X              | 1             | counter_a[1]                 |                                                                                           | counter_a[3] 0                                                                                                                |                  |
| 13<br>14         | X                 | 1<br>X         | X             | counter_a[2]<br>counter_a[3] |                                                                                           | counter_a[2] 0                                                                                                                |                  |
| 14               | X                 | X              | X             | counter_a[3]<br>counter_a[4] |                                                                                           | - counter_a[1] 0                                                                                                              |                  |
| 16               | X                 | x              | X             | counter_a[5]                 |                                                                                           | - counter_a[0] 0                                                                                                              |                  |
| 17               | X                 | X              | X             | counter_a[6]                 |                                                                                           | counter_b[15: 015b     4 0155 0156 0157 0158 0159 015a 01                                                                     | 56 015c 015d 0   |
| 18               | X                 | X              | X             | counter_a[7]                 |                                                                                           | counter_b[15] 0<br>counter_b[14] 0                                                                                            |                  |
| 19               | Х                 | Х              | х             | counter_b[0]                 |                                                                                           | - counter_b[13] 0                                                                                                             |                  |
| 20               | Х                 | Х              | Х             | counter_b[1]                 | ~                                                                                         |                                                                                                                               |                  |
| Load Signal      | Names From Ac     | tive Project   | Reset Signal  | Names                        |                                                                                           | Move Up Add Left: 0000000340 tk Show Times                                                                                    | Right: 00000003  |
| onitor Channe    | els               |                |               |                              |                                                                                           | Move Down Remove Marker: 0000000347 tk                                                                                        | Cursor: 00000003 |
| imuli            |                   |                |               |                              |                                                                                           | Waveform File Preview                                                                                                         |                  |
| Ivanced Optio    |                   |                |               |                              |                                                                                           | E Tcl Console 🕱                                                                                                               | No. 10           |
| nfigure log a    | nd output file lo | cations, and a | advanced opti | ons                          |                                                                                           | ACE Achronix CAD Environment Version Build                                                                                    | 369189 Date      |
| re-Store         | 0%                |                |               |                              | $\sim$                                                                                    | (c) Copyright 2006-2022 Achronix Semiconductor Corp. All r                                                                    |                  |
| Trigger 1 Sele   | ct                |                |               |                              |                                                                                           | all messages logged in file C:/Users/Labadmin/.achronix/ace<br>INFO: License ace-v1.0 on server cad2 (1968 of 2000 licenses a |                  |
|                  | ig AND 🔿 Sele     | ct Using OR    |               |                              |                                                                                           |                                                                                                                               |                  |
| Trigger 2 Select |                   |                |               |                              | <pre>cmd&gt; restore_project "C:/projects/achronix/snapshot_example/acc<br/>cmd&gt;</pre> | :/snapsnot_exa                                                                                                                |                  |
|                  | ig AND 🔿 Sele     | ct Using OR    |               |                              |                                                                                           |                                                                                                                               |                  |
| Trigger 3 Sele   | ct                |                |               |                              |                                                                                           |                                                                                                                               |                  |
| Select Usin      | g AND O Sele      | ct Using OR    |               |                              | ~                                                                                         |                                                                                                                               |                  |



| Option                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Trigger Conditions               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Trigger Mode                     | <ul> <li>Allows selecting the trigger mode to use when the Arm Snapshot action is run.</li> <li>The default trigger mode is Single: <ol> <li>The trigger conditions are programmed into the ACX_SNAPSHOT macro.</li> <li>The GUI waits for a single trigger event to occur which matches those trigger conditions.</li> <li>A single VCD file is recorded.</li> </ol> </li> <li>If Immediate trigger mode is selected, pressing the Arm button results in the same behavior as Single trigger mode, except that all 3 trigger patterns are treated as "Don't Care" (X) so that the trigger event occurs as soon as the Arm button is pressed.</li> <li>If Repetitive trigger mode is selected: <ol> <li>The trigger conditions are programmed into the ACX_SNAPSHOT macro.</li> </ol> </li> <li>Samples are captured repetitively until the upper limit of trigger event records is reached.</li> <li>When Repetitive trigger mode is selected, an additional set of repetitive trigger mode options appear allowing the configuration of: <ol> <li>The number of sequential times Snapshot should be armed repetitively using the configured trigger conditions</li> </ol> </li> </ul> |
| Number of Sequential<br>Triggers | <ul> <li>Allows selecting the use of either 1, 2, or 3 sequential triggers:</li> <li>1 - Trigger 2 and Trigger 3 are ignored during the match</li> <li>2 - Trigger 3 is ignored during the match and Snapshot triggers when Trigger 1 is matched, followed on any subsequent clock by a match on Trigger 2</li> <li>3 - snapshot triggers after a match on Trigger 1, followed by Trigger 2, followed by Trigger 3</li> <li>See Configuring the Trigger Pattern (page 366), Configuring Test Stimulus (page 371), and Configuring the Monitor Signals (page 370).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Trigger Channel Width            | The Snapshot debugger module can be configured to trigger channel widths of <b>1</b> to <b>40</b> channels. The Trigger Channel Width must be set to the value that corresponds with the configured Snapshot RTL instantiation. The trigger width is automatically extracted from the user design and saved in the generated names.snapshot file, which can be loaded and edited.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Channel                          | The trigger channel number connected to the Snapshot Debugger core.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Trigger 1                        | Sets the Trigger 1 value for each channel. Valid options are:<br>X – don't care<br>R – rising edge<br>F – falling edge<br>0 – level 0<br>1 – level 1<br>See Configuring the Trigger Pattern (page 366).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Trigger 2                        | Sets the trigger 2 value for each channel. Valid options are:<br>X – don't care<br>R – rising edge<br>F – falling edge<br>O – level 0<br>1 – level 1<br>This column is only editable if 2 or 3 triggers are selected. See Configuring the Trigger Pattern (page 366).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

### Table 79 · Snapshot Debugger View Options

| Option                                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Trigger 3                                | Sets the trigger 3 value for each channel. Valid options are:<br>X - don't care<br>R - rising edge<br>F - falling edge<br>0 - level 0<br>1 - level 1<br>This column is only editable if 3 triggers are selected. See Configuring the Trigger Pattern (page 366).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Signal Name                              | Sets the user-defined name for the trigger channel. This signal name is automatically extracted from the user design and saved in the generated names.snapshot file, which can be loaded and edited.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Load Signal Names From<br>Active Project | When clicked, loads the names.snapshot file generated during design preparation (the <b>Run Prepare</b> flow step), which renames all signals with their project-specific names and loads other harvested project-specific settings.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Reset Signal Names                       | When clicked, renames all signals back to their default names, which is "signal" with a suffix corresponding to the channel number.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Repetitive Trigger Setting               | S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Record Limit                             | The repetitive trigger Record Limit setting determines how many times (number of records) the GUI repeatedly Arms the Snapshot debugger and captures samples. This may be set to automatically run Snapshot up to 128 times.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| VCD Record Limit                         | Determines how many repetitively triggered Snapshot records to capture in a single VCD file. Essentially concatenates the VCD files from consecutive runs of Snapshot (records) into a single VCD file. The VCD file waveform contains a set of virtual signals to indicate the system timestamp at which each Snapshot record was captured. Up to 10 Snapshot records may be concatenated in a single VCD file.                                                                                                                                                                                                                                                                                                                                                                |
| Overwrite VCD File                       | <ul> <li>When selected, the VCD Waveform File name specified in the Advanced Options section is used to store the output VCD file. The file is overwritten with the new VCD file each time the VCD record limit is reached. If not selected, multiple VCD files are written out and a unique VCD record number is added to the VCD Waveform File name specified in the Advanced Options section for each VCD.</li> <li>For example, if the Record Limit is set to 8, the VCD Record Limit is set to 2, and the VCD Waveform file path set to "./ snapshot.vcd", Snapshot outputs 4 VCD files: <ol> <li>"./snapshot1.vcd"</li> <li>"./snapshot2.vcd"</li> <li>"./snapshot3.vcd"</li> <li>"./snapshot4.vcd"</li> </ol> </li> </ul> Each file contains 2 Snapshot capture records. |
| Monitor Channels                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Monitor Channel Width                    | The Snapshot debugger module can be configured to monitor channel widths of 1 to 4087 channels. The Monitor Channel Width must be set to the value that corresponds with the parameterized Snapshot RTL instantiation. The monitor width is automatically extracted from the user design and saved in the generated names.snapshot file, which can be loaded and edited.                                                                                                                                                                                                                                                                                                                                                                                                        |
| Number of Samples                        | The Snapshot debugger module can be configured to capture between 512 and 16384 samples. The Number of Samples must be set to the value that corresponds with the parameterized Snapshot RTL instantiation. The number of samples is automatically extracted from the user design and saved in the generated names.snapshot file, which can be loaded and edited.                                                                                                                                                                                                                                                                                                                                                                                                               |
| Channel                                  | The monitor channel number connected to the Snapshot Debugger core.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Option                                                                                                                                                                                                                                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Signal Name                                                                                                                                                                                                                              | Sets the user-defined name for the monitor channel. This signal name is automatically extracted from the user design and saved in the generated names.snapshot file, which can be loaded and edited. This signal name is used in the VCD file waveform output.                                                                                                                                                                                                                                                                                                 |
| Load Signal Names From<br>Active Project When clicked, loads the names.snapshot file generated during design preparation (the <b>Ru</b><br>which renames all signals with their project-specific names and loads other harvested project |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Reset Signal Names                                                                                                                                                                                                                       | When clicked, renames all signals back to their default names, which are "signal" with a suffix corresponding to the channel number.                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Stimuli                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Stimuli Channel Width                                                                                                                                                                                                                    | The Snapshot debugger module can be configured to stimuli channel widths of 0 (no stimuli) to 512 channels. The Stimuli Channel Width must be set to the value that corresponds with the parameterized Snapshot RTL instantiation The stimuli width is automatically extracted from the user design and saved in the generated names.snapshot file, which can be loaded and edited.                                                                                                                                                                            |
| Channel                                                                                                                                                                                                                                  | The stimuli channel number connected to the Snapshot Debugger core.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Value                                                                                                                                                                                                                                    | The value to drive out on this stimuli channel ARM_DELAY cycles before Snapshot is Armed (when the Arm button is pressed).                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Signal Name                                                                                                                                                                                                                              | Sets the user-defined name for the stimuli channel. This signal name is automatically extracted from the user design and saved in the generated names.snapshot file, which can be loaded and edited.                                                                                                                                                                                                                                                                                                                                                           |
| Advanced Options                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Pre-Store                                                                                                                                                                                                                                | Controls the ratio of samples collected before and after the trigger. See Configuring Advanced Options (page 373).                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Trigger 1 Select                                                                                                                                                                                                                         | <ul> <li>When set to Select Using AND, Snapshot ANDs the values within the active Trigger to determine a match. This setting indicates that ALL signal values not masked must match the specified pattern in order to generate a trigger match event.</li> <li>When set to Select Using OR, Snapshot ORs the values within the active Trigger to determine a match. This setting indicates the trigger match event is generated if ANY of the non-masked signal values match the specified pattern. See Configuring the Trigger Pattern (page 366).</li> </ul> |
| Trigger 2 Select                                                                                                                                                                                                                         | <ul> <li>When set to Select Using AND, Snapshot ANDs the values within the active Trigger to determine a match. This setting indicates that ALL signal values not masked must match the specified pattern in order to generate a trigger match event.</li> <li>When set to Select Using OR, Snapshot ORs the values within the active Trigger to determine a match. This setting indicates the trigger match event is generated if ANY of the non-masked signal values match the specified pattern. See Configuring the Trigger Pattern (page 366).</li> </ul> |
| Trigger 3 Select                                                                                                                                                                                                                         | <ul> <li>When set to Select Using AND, Snapshot ANDs the values within the active Trigger to determine a match. This setting indicates that ALL signal values not masked must match the specified pattern in order to generate a trigger match event.</li> <li>When set to Select Using OR, Snapshot ORs the values within the active Trigger to determine a match. This setting indicates the trigger match event is generated if ANY of the non-masked signal values match the specified pattern. See Configuring the Trigger Pattern (page 366).</li> </ul> |
| Frequency (MHz)                                                                                                                                                                                                                          | Must be configured to match the the user_clk timing constraint set in the SDC file of the design being debugged.<br>This is automatically set according to the values captured in the names.snapshot file when an active implementation is available.<br>See Configuring Advanced Options (page 373).                                                                                                                                                                                                                                                          |

| Option                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| File Paths Relative To | (Only relevant when the log and VCD file paths provided are relative paths, not absolute paths.) Chooses whether the <b>Log File</b> and <b>Waveform File</b> paths are understood to be relative to the <b>Active Project</b> directory or to the <b>Working Directory</b> . (When using the GUI, the working directory corresponds to the pwd according to the Tcl interpreter.) See Configuring Advanced Options (page 373). |
| Log File               | File name for the Snapshot log file, where raw Snapshot output (including warning and error messages) is logged.<br>The default file name and path can be overwritten, and the accompanying <b>Browse</b> button may be used to<br>graphically navigate to the desired directory or file.                                                                                                                                       |
|                        | See Configuring Advanced Options (page 373).                                                                                                                                                                                                                                                                                                                                                                                    |
| Waveform File          | File name for the Snapshot VCD waveform output file, where the Snapshot sampled values (the trace buffer) is stored. The default file name and path can be overwritten, and the accompanying <b>Browse</b> button may be used to graphically navigate to the desired directory or file.                                                                                                                                         |
|                        | See Configuring Advanced Options (page 373).                                                                                                                                                                                                                                                                                                                                                                                    |
| Startup Trigger        | This is the same as the ( 4) Capture Snapshot Startup Trigger button in the view toolbar.                                                                                                                                                                                                                                                                                                                                       |
| Startup Trigger        | See Collecting Samples of the User Design (page 375).                                                                                                                                                                                                                                                                                                                                                                           |
|                        | This is the same as the ( 💟 ) <b>Arm Snapshot</b> button in the view toolbar.                                                                                                                                                                                                                                                                                                                                                   |
| Arm                    | See Collecting Samples of the User Design (page 375).                                                                                                                                                                                                                                                                                                                                                                           |
| Canaal                 | This is the same as the ( 📕 ) <b>Cancel Snapshot</b> button in the view toolbar.                                                                                                                                                                                                                                                                                                                                                |
| Cancel                 | See Collecting Samples of the User Design (page 375).                                                                                                                                                                                                                                                                                                                                                                           |

# Tcl Console View

The Tcl Console view provides an interactive Tcl console for ACE. All user interactions that change design and project data go through the Tcl command interface, including all commands executed while in the GUI. From the Tcl Console view, executed commands and their information are displayed, including any warning and error messages. The Tcl console can also be used interactively by typing Tcl commands directly into the console to manipulate projects or the current design.

The following highlights are used:

Bold Green – valid ACE commands.
 Blue Text – informational messages.
 Yellow Text – warning messages.
 Red Text – error messages.

The Tcl Console view consists of two main areas: a "readout" area at the top, and an "entry" area at the bottom.

- When the cursor is in the entry area, the up and down arrow keys can be used to move forward and backward through the history of recently-issued commands.
- When typing in a command or file path, pressing the **TAB** key causes an auto-completion window to pop up. The up and down arrow keys can be used to move through entries in the content-assist list. Pressing **Enter** chooses the selected entry in the list. Entries in the list may also be chosen with the mouse.
- When the focus is in the entry area:
  - Pressing **ESCAPE** clears the currently entered command text. If there is no command text in the entry area, pressing **ESCAPE** clears any row selection from the readout area.

- Pressing CTRL+V pastes the contents of the system clipboard into the entry area.
- Pressing **CTRL+SPACE** jumps into the multi-line entry dialog, useful to execute more complicated Tcl commands.
- When the focus is in the multi-line entry dialog, Pressing **ALT+UP ARROW** and **ALT+DOWN ARROW** can be used to move forward and backward through the history of recently-used commands.
- When the focus is in the readout area:
  - Pressing **ESCAPE** moves the focus to the entry area.
  - Pressing **CTRL+C** copies the contents of the currently selected row(s) to the system clipboard.
  - Pressing CTRL+V pastes the contents of the system clipboard into the entry area.
  - Pressing **CTRL+F** performs a "find" operation. A dialog appears to permit searching through all of the text in the readout area.
  - Typing characters other than navigation keys (arrows, home, end, page up, page down, etc.) moves the focus to the readout area.
- When the cursor is anywhere over the readout or entry areas, **CTRL+MOUSEWHEEL** can be used to quickly increase or decrease the size of the font.

The colors of all the different elements of the view can be configured by selecting the **Configure View...** action and choosing **Colors and Fonts**.

By default, the Tcl Console view is included in all **perspectives** (page 6). If it is not visible, add it with **Window**  $\rightarrow$  **Show View**  $\rightarrow$  **Tcl Console**.

For more details, see Using the Tcl Console (page 331), check the available preferences on the Tcl Console View Preference Page (page 219), and see the available commands in the Tcl Command Reference (page 580).

147

| 📃 Tcl Console $	imes$                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                         |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GUIProfiling: Clock Nets data read in cputime 0.00 seconds (usertime 0.                                                                                                                                                                                                                                                            | .00 seconds systemtime 0.00 seconds) clocktime 0.00 seconds                                                                                                                                                                                                                                                             |
| GUIProfiling: Clock Nets data parsed in cputime 0.00 seconds (usertime                                                                                                                                                                                                                                                             | 0.00 seconds systemtime 0.00 seconds) clocktime 0.00 seconds                                                                                                                                                                                                                                                            |
| Transmitting placement visualization data                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                         |
| GUIProfiling: Placement data read/parsed in cputime 0.00 seconds (usert                                                                                                                                                                                                                                                            | time 0.00 seconds systemtime 0.00 seconds) clocktime 0.00 seconds                                                                                                                                                                                                                                                       |
| Completed transmitting placement visualization data                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                         |
| Profile SendPlacementData Tcpu 49/+0(0+0) Twck 1:18:47/+0 Mpk 4340/+0.0                                                                                                                                                                                                                                                            | 0 Mcur 4134/+0.0                                                                                                                                                                                                                                                                                                        |
| Transmitting routing visualization data                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                         |
| GUIProfiling: Routing data read/parsed in cputime 0.00 seconds (usertim                                                                                                                                                                                                                                                            | me 0.00 seconds systemtime 0.00 seconds) clocktime 0.01 seconds                                                                                                                                                                                                                                                         |
| Completed transmitting routing visualization data                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                         |
| Profile SendRoutingData Tcpu 49/+0(0+0) Twck 1:18:47/+0 Mpk 4340/+0.0 M                                                                                                                                                                                                                                                            | Mcup 4134/+0.0                                                                                                                                                                                                                                                                                                          |
|                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                         |
| md> message -error "This is what an error looks like"                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                         |
| -                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                         |
| This is what an error looks like                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                         |
| This is what an error looks like<br>md> message -warning "This is what a warning looks like"                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                         |
| This is what an error looks like<br>cmd> message -warning "This is what a warning looks like"<br>This is what a warning looks like                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                         |
| <pre>xmd&gt; message -error "This is what an error looks like" This is what an error looks like xmd&gt; message -warning "This is what a warning looks like" This is what a warning looks like xmd&gt; message -info "This is what an info message looks like" This is what an info message looks like</pre>                       |                                                                                                                                                                                                                                                                                                                         |
| This is what an error looks like<br>md> message -warning "This is what a warning looks like"<br>This is what a warning looks like<br>md> message -info "This is what an info message looks like"                                                                                                                                   |                                                                                                                                                                                                                                                                                                                         |
| This is what an error looks like<br>cmd> message -warning "This is what a warning looks like"<br>This is what a warning looks like<br>cmd> message -info "This is what an info message looks like"                                                                                                                                 |                                                                                                                                                                                                                                                                                                                         |
| This is what an error looks like<br>md> message -warning "This is what a warning looks like"<br>This is what a warning looks like<br>md> message -info "This is what an info message looks like"<br>This is what an info message looks like                                                                                        | "ace::message" : This command prints a status message to the console and the log                                                                                                                                                                                                                                        |
| This is what an error looks like<br>md> message -warning "This is what a warning looks like"<br>This is what a warning looks like<br>md> message -info "This is what an info message looks like"<br>This is what an info message looks like<br>cmd> m                                                                              | "ace::message" : This command prints a status message to the console and the log file.                                                                                                                                                                                                                                  |
| This is what an error looks like<br>md> message -warning "This is what a warning looks like"<br>This is what a warning looks like<br>md> message -info "This is what an info message looks like"<br>This is what an info message looks like<br>emd> m<br>mem_dump                                                                  | "ace::message" : This command prints a status message to the console and the log                                                                                                                                                                                                                                        |
| This is what an error looks like<br>md> message -warning "This is what a warning looks like"<br>This is what a warning looks like<br>md> message -info "This is what an info message looks like"<br>This is what an info message looks like<br>mem_set<br>mem_set<br>message<br>move_project_constraints                           | "ace::message" : This command prints a status message to the console and the log<br>file.<br><msg> : The message to be printed.<br/>[-file <string>] : The TCL channel to use - if set and not 'none', only print the<br/>message to the file.</string></msg>                                                           |
| This is what an error looks like<br>md> message -warning "This is what a warning looks like"<br>This is what a warning looks like<br>md> message -info "This is what an info message looks like"<br>This is what an info message looks like<br>mem_dump<br>mem_set<br>message<br>move_project_constraints<br>move_project_netlists | *ace::message" : This command prints a status message to the console and the log<br>file.<br><msg> : The message to be printed.<br/>[-file <string>] : The TCL channel to use - if set and not 'none', only print the<br/>message to the file.<br/>[-info] : Make this message an informational message.</string></msg> |
| This is what an error looks like<br>md> message -warning "This is what a warning looks like"<br>This is what a warning looks like<br>md> message -info "This is what an info message looks like"<br>This is what an info message looks like<br>mem_dump<br>mem_set<br>message<br>move_project_constraints                          | "ace::message" : This command prints a status message to the console and the log<br>file.<br><msg> : The message to be printed.<br/>[-file <string>] : The TCL channel to use - if set and not 'none', only print the<br/>message to the file.</string></msg>                                                           |

### Figure 65 • Tcl Console View Example

### Table 80 Tcl Console View Actions

| lc<br>o<br>n | Action                     | Description                                                                          |
|--------------|----------------------------|--------------------------------------------------------------------------------------|
| ->           | Find                       | Find instances of specified text in the readout area.                                |
| <b>a</b> :   | Scroll Lock                | When enabled, the readout area does not automatically scroll as new lines are added. |
| i            | Toggle Info<br>Messages    | Toggles the display of info messages in the readout area.                            |
|              | Toggle Warning<br>Messages | Toggles the display of warning messages in the readout area.                         |
|              | Clear Console              | Clears the readout area.                                                             |
|              | Open Log File              | Opens the log file on disk in the ACE editor area.                                   |

| LIG070 |  |
|--------|--|
| 000/0  |  |

| lc<br>o<br>n | Action           | Description                                                                                                                                                     |
|--------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 000          | Configure view   | Opens the <b>Configure View</b> menu item.                                                                                                                      |
| 1            | Multi-line entry | Opens the multi-line entry dialog.                                                                                                                              |
|              | View entire line | When one or more lines are selected in the readout area, displays the lines in a floating dialog including a "word wrap" toggle to assist with very-long-lines. |
| $\diamond$   | Re-run command   | Re-runs a command.                                                                                                                                              |
| 2            | Edit command     | Opens the multi-line entry dialog with the given command in it for editing.                                                                                     |

### ▲ Warning!

When Tcl command return values are displayed in the Tcl Console, any long returned values are visually truncated to 500 characters in the console. The actual returned value is not truncated, only the visual representation in the console. Thus, scripts using long return values still behave properly.

#### Right-click anywhere in the readout area to access a context menu of actions.

| ☐ Id Console ×          Protile SendUlockDomains icpu 58/+8(8+8) iwck 1:58:54/+8 Mpk 4334/+8.8 Mcur 3755/+8.8                      |            |                                             |                                                      |  |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------|------------|---------------------------------------------|------------------------------------------------------|--|--|--|--|--|
| GUIProfiling: Clock Nets data read in cpu                                                                                          | tim        | e 0.00 seconds (usertime                    | 0.00 seconds systemtime 0.00 seconds) clocktime 0.0  |  |  |  |  |  |
| GUIProfiling: Clock Nets data parsed in 禄                                                                                          | , <b>.</b> | Find                                        | me 0.00 seconds systemtime 0.00 seconds) clocktime C |  |  |  |  |  |
| Transmitting placement visualization data<br>GUIProfiling: Placement data read/parsed<br>Completed transmitting placement visualiz |            | Fina<br>Scroll Lock<br>Toggle info messages | rtime 0.00 seconds systemtime 0.00 seconds) clockti  |  |  |  |  |  |
| Profile SendPlacementData Tcpu 58/+0(0+0)                                                                                          | <u>.</u>   | Toggle warning messages                     | 0.0 Mcur 3755/+0.0                                   |  |  |  |  |  |
| Transmitting routing visualization data<br>GUIProfiling: Routing data read/parsed in<br>Completed transmitting routing visualizat  |            | Clear Console<br>Open Log File              | ime 0.00 seconds systemtime 0.00 seconds) clocktime  |  |  |  |  |  |
| Profile SendRoutingData Tcpu 58/+0(0+0) T                                                                                          |            | View Entire Line<br>Copy                    | Mcur 3755/+0.1                                       |  |  |  |  |  |
| cmd>                                                                                                                               | ۶          | Configure View                              | r i                                                  |  |  |  |  |  |

Figure 66 • Readout Area Context Menu Example

# Dialogs

Several dialogs are used within ACE. These dialogs are typically shown in response to specific menu choices or button clicks.

# Add Signals to Waveform Viewer Dialog

The Add Signals to Waveform Viewer dialog appears when the **Add...** button is clicked in the VCD Waveform editor (page 11).

This dialog allows:

- 1. Making signals visible which were previously hidden by clicking the **Remove** button in the VCD Waveform editor.
- 2. Adding duplicates of already-shown signals to the table and waveform.

The choice of which rows (if any) are selected in the VCD Waveform editor signal value table when the **Add** button is pressed affects where the to-be-added signals appear in the signal values table. The signals chosen in the dialog are added or inserted using the **Append** and **Insert** buttons. When the dialog **Insert** button is pressed, signals chosen in the dialog are inserted above the first row currently selected in the VCD signal value table, or at the top of the table if no rows are currently selected. Alternatively, when the **Append** button is pressed, signals are added to the bottom of the table, regardless of which rows are selected. Remember that the **Move Up** and **Move Down** buttons on the VCD Waveform editor may be used to move the added/inserted signals to a different location in the table after this dialog is closed.

| O Add Signals to Waveform Viewer                                                | × |
|---------------------------------------------------------------------------------|---|
| ■— signal12<br>■— signal13<br>■— signal14                                       |   |
| <ul> <li>Select from All Signals</li> <li>Select from Hidden Signals</li> </ul> |   |
| Append Insert Close                                                             |   |

Figure 67 • Add Signals to Waveform Viewer Dialog Example

The majority of the dialog is taken up by an area listing the signals. The listed signals are filtered depending upon the radio-button currently selected in the dialog.

| Action                     | Description                                                                                                                                                                                                                                                                                                                                                       |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Select from All Signals    | Causes the list to be populated with all signals contained in the current VCD file.                                                                                                                                                                                                                                                                               |
| Select from Hidden Signals | Causes the list to be populated with all signals found in the VCD file<br>which are currently hidden (includes signals removed from the VCD<br>Waveform editor signal table). If no signals are currently hidden, the list<br>of hidden signals is empty. When collapsed, the bits of buses are not<br>considered hidden, and thus do not appear in this listing. |
| Append <sup>(1)</sup>      | Appends the currently-selected signal to the bottom of the VCD Waveform editor signal table.                                                                                                                                                                                                                                                                      |
| Insert <sup>(1)</sup>      | Inserts the signal(s) currently selected in the dialog immediately above<br>the signal currently selected in the VCD Waveform editor signal table. If<br>no signal was selected when the <b>Add</b> button was pressed to open this<br>dialog, the signal selected in the dialog is inserted at the top of the VCD<br>Waveform editor signal table.               |
| Close                      | Closes the dialog.                                                                                                                                                                                                                                                                                                                                                |

- 1. The Append and Insert buttons have the following characteristics:
  - Each button may be clicked multiple times for a given signal, adding the signal selected in the dialog list to the VCD Waveform editor signal table multiple times.
  - The buttons are disabled if no signal is currently selected in the dialog signal list.
  - If either button is used to un-hide a previously-hidden signal, the signal is removed from the list of hidden signals (if that filter is active) since it is no longer considered hidden.

There are also some icons used by content displayed in the dialog signal list as shown in the following table.

#### Table 82 • Add Signals to Waveform Viewer Dialog Icons

| lcon | Description |
|------|-------------|
| ı    | Signal      |

| lcon                                              | Description                                |
|---------------------------------------------------|--------------------------------------------|
| [≡                                                | Bus                                        |
| (j) Note<br>The dialog does not show individual b | ous bits, so the bus bit icon is not used. |

# Add Source Files Dialogs

There a several categories of **source files** (page 226) that can be added to the ACE project. Under the parent ( ) Add **Project Source Files** action, there are category-specific actions to add files to each category. Each category has its own dialog as shown in the following examples.

After selecting the files to add, click **Open** (in Windows) or **OK** (in Linux) to add them to the project.

## Add IP Configuration Files Dialog

The Add IP Configuration Files dialog browses for IP Configuration (.acxip) source files (page 226) to add to the selected project (page 224).

| Add IP Configuration Files to "quickstart_canary"                                                                  |      |      |                     |            |         |         |
|--------------------------------------------------------------------------------------------------------------------|------|------|---------------------|------------|---------|---------|
| $\leftarrow$ $\rightarrow$ $\checkmark$ $\uparrow$ $\blacksquare$ « AC7t1500 $\rightarrow$ src $\rightarrow$ acxip | ~    | Ō    | Search acxip        |            |         | Q       |
| Organize 🔻 New folder                                                                                              |      |      |                     |            |         | ?       |
| quickstart                                                                                                         | ^    | Nai  | me                  | ^          |         |         |
| AC05SC0103R0                                                                                                       |      |      | quickstart_clock_id | o_bank_A   | C7t1500 | ).acxip |
| AC05SC0104R0                                                                                                       |      |      | quickstart_gpio_b   | ank_AC7t   | 1500.ac | xip     |
| AC05SC0105R0                                                                                                       |      |      | quickstart_pll_AC7  | /t1500.acx | ip      |         |
| AC05SC0201R0                                                                                                       |      |      |                     |            |         |         |
| AC05SE16A0034R0                                                                                                    |      |      |                     |            |         |         |
| AC7t800ES0                                                                                                         |      |      |                     |            |         |         |
| AC7t1450                                                                                                           | ~    | <    |                     |            |         | >       |
| File name: quickstart_clock_io_bank_AC                                                                             | 7t15 | 00 ~ | *.acxip             |            |         | ~       |
|                                                                                                                    |      |      | Open                | (          | Cancel  |         |

Figure 68 • Add IP Configuration Files Dialog Example

### Add RTL Files Dialog

The Add RTL Files dialog browses for Verilog and VHDL RTL (.v, .sv, .vhd, and .vhdl) source files (page 226) to add to the selected project (page 224).

| Add RTL Files to "quickstart_canary"                                                                                    |                                                                           | $\times$ |
|-------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|----------|
| $\leftarrow$ $\rightarrow$ $\checkmark$ $\uparrow$ $\blacksquare$ « AC20SE16A0012R0 $\rightarrow$ src $\rightarrow$ rtl | ✓ 乙 Search rtl                                                            | Q        |
| Organize 🔻 New folder                                                                                                   |                                                                           | ?        |
| src<br>constraints<br>rtl<br>syn<br>tb<br>Python27<br>Recovery                                                          | Name iii counter.v iii quickstart.v                                       |          |
| File name:                                                                                                              | < <ul> <li>*.vhd;*.vhdl;*.v;*.sv</li> <li>Open</li> <li>Cancel</li> </ul> | ><br>~   |

Figure 69 • Add RTL Files Dialog Example

## Add Synthesis Constraint Files Dialog

The Add Synthesis Constraint Files dialog browses for Synthesis constraints (.fdc, .sdc, and .scf) **source files** (page 226) to add to the selected **project** (page 224).

| Add Synthesis Constraint Files to "quickstart_canary"                                             |   |     |                   |     |        | ×  |
|---------------------------------------------------------------------------------------------------|---|-----|-------------------|-----|--------|----|
| $\leftarrow$ $\rightarrow$ $\checkmark$ $\uparrow$ $\blacksquare$ « src $\rightarrow$ constraints | ~ | Ö   | Search constrai   | nts |        | Q  |
| Organize 🔻 New folder                                                                             |   |     |                   |     |        | ?  |
| Project Space Test                                                                                | ^ | Nan | ne                | ^   |        |    |
| AC20SC3AA0038R0                                                                                   |   | 2   | quickstart.sdc    |     |        |    |
| AC20SE16A0012R0                                                                                   |   |     |                   |     |        |    |
| src                                                                                               |   |     |                   |     |        |    |
| constraints                                                                                       |   |     |                   |     |        |    |
| 📊 rtl                                                                                             |   |     |                   |     |        |    |
| syn                                                                                               |   |     |                   |     |        |    |
| tb                                                                                                | ~ | <   |                   |     |        | >  |
| File name: quickstart.sdc                                                                         |   | ~   | *.fdc;*.sdc;*.scf |     |        | ~  |
|                                                                                                   |   |     | Open              |     | Cancel | .1 |

Figure 70 • Add Synthesis Constraint Files Dialog Example

## Add Place and Route Constraint Files Dialog

The Add Place and Route Constraint Files dialog browses for Place and Route constraints (.pdc, .sdc, .prt, .scf, .xml, and .hex) source files (page 226) to add to the selected project (page 224).

| Add Place and Route Constrait                                                                                                                                    | nt Files to "quickstart_canary | <b>,</b> " |        |                                        |       |                   | × |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|------------|--------|----------------------------------------|-------|-------------------|---|
| $\leftarrow$ $\rightarrow$ $\checkmark$ $\uparrow$ $\square$ $\ll$ src $\rightarrow$                                                                             | constraints                    | ~          | ē      | Search constr                          | aints |                   | Q |
| Organize 🔻 New folder                                                                                                                                            |                                |            |        |                                        |       |                   | ? |
| <ul> <li>Project Space Test</li> <li>AC20SC3AA0038R0</li> <li>AC20SE16A0012R0</li> <li>src</li> <li>constraints</li> <li>rtl</li> <li>syn</li> <li>tb</li> </ul> |                                | ^          |        | ne<br>quickstart.pdc<br>quickstart.sdc | ~     |                   |   |
| File name:                                                                                                                                                       |                                | ~          | <<br>~ | *.pdc;*.sdc;*.p                        | _     | l;*.hex<br>Cancel | ~ |

Figure 71 • Add Place and Route Constraint Files Dialog Example

### Add Place and Route Netlist Files Dialog

The Add Place and Route Netlist Files dialog browses for source Place and Route Netlist (.vm and .vma) source files (page 226) to add to the selected project (page 224).

| S Add Place and Route Netlist Files to "quickstart_canary"                               |   |    |                    |   |        | × |
|------------------------------------------------------------------------------------------|---|----|--------------------|---|--------|---|
| $\leftarrow$ $\rightarrow$ $\checkmark$ $\uparrow$ $\square$ $\ll$ src $\rightarrow$ syn | ~ | Ō  | Search syn         |   |        | Q |
| Organize 🔻 New folder                                                                    |   |    |                    |   | •      | ? |
| AC205C3AA0038R0                                                                          | ^ | Na | me                 | ^ |        |   |
| AC20SE16A0012R0                                                                          |   |    | quickstart.vma     |   |        |   |
| src                                                                                      |   |    |                    |   |        |   |
| constraints                                                                              |   |    |                    |   |        |   |
| ntl                                                                                      |   |    |                    |   |        |   |
| 🔄 syn                                                                                    |   |    |                    |   |        |   |
| tb                                                                                       |   |    |                    |   |        |   |
| Python27                                                                                 | ~ | <  |                    |   |        | > |
| File name: quickstart.vma                                                                |   | ~  | *.vma;*.vm<br>Open |   | Cancel | ~ |

Figure 72 • Add Place and Route Netlist Files Dialog Example

### Add Simulation Testbench Files Dialog

The Add Simulation Testbench Files dialog browses for source Simulation Testbench (.v, .sv, .vhd, .vhdl, .f, .txt, .dat, and .mem) source files (page 226) to add to the selected project (page 224).

| Ø Add Simulation Testbench Files to "quickstar                                       | t_canary" X                              |
|--------------------------------------------------------------------------------------|------------------------------------------|
| $\leftarrow \rightarrow$ $\checkmark$ $\uparrow$ $\checkmark$ « src $\rightarrow$ tb | ✓ C̄ Search tb                           |
| Organize 🔻 New folder                                                                | III 🗸 🔟 😮                                |
| Project Space Test AC20SC3AA0038R0                                                   | ↑ Name<br>↓ tb_quickstart.v              |
| AC20SE16A0012R0                                                                      |                                          |
| constraints                                                                          |                                          |
| syn                                                                                  |                                          |
| Li tb                                                                                | ~ < >                                    |
| File name: tb_quickstart.                                                            | v  v  v  v  v  v  v  v  v  v  v  v  v  v |

Figure 73 • Add Simulation Testbench Files Dialog Example

See also: Adding Source Files (page 296) and Adding Configuration Files to a Project (page 338).

# Assign Bussed Signal Names Dialog

The Assign Bussed Signal Names dialog wizard allows the assigning multiple signal names from the **SnapShot Debugger view** (page 141) "Monitor Channels", "Trigger Channels", or "Stimuli Channels" tables using bus notation. After configuring the bus in the dialog, the bus name and indices are propagated to all the selected signals, changing the signal names appropriately. Monitor channel signal names are then used in the Snapshot sampled output, visible in the VCD Waveform editor (page 11).

#### (i) Note

This dialog is only useful when creating a Snapshot configuration from scratch. Typically, this dialog is not needed since ACE automatically outputs all signal names from the user design into the names.snapshot file as part of the normal ACE place and route flow.

| 🖸 Assign Bussed Signal Names 📃 🗖 🛛                                                                                                                                               |   |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--|--|--|--|--|--|
| Bus Name Assignment<br>This wizard allows you to automatically configure<br>the signal name with bus notation in the selected                                                    |   |  |  |  |  |  |  |
| Signal Name     bus       Width     4       Starting Index     0       Image: Ascending Order     Image: Ascending Order       Image: Decending Order     Image: Ascending Order | ] |  |  |  |  |  |  |
| ⑦ <u>Einish</u> Cancel                                                                                                                                                           | ) |  |  |  |  |  |  |



| Table 83 | <ul> <li>Assign</li> </ul> | Bussed | Signal | Names | Dialog | Options |
|----------|----------------------------|--------|--------|-------|--------|---------|
|----------|----------------------------|--------|--------|-------|--------|---------|

| Option           | Description                                                                                                                                                                       |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Signal Name      | The desired name of the bus.                                                                                                                                                      |
| Width            | The width (in bits) of the bus. This value is not editable. It reflects the number of signals which were selected from the table in the <b>Snapshot Debugger view</b> (page 141). |
| Starting Index   | The desired starting index of the bus, sometimes also called the offset into the bus.                                                                                             |
| Ascending Order  | When selected, the bus indices start at <b>Starting Index</b> and increment <b>Width</b> times.                                                                                   |
| Descending Order | When selected, the bus indices start at <b>Starting Index</b> and decrement <b>Width</b> times.                                                                                   |
| Finish           | Accepts the specified bus configuration, closes the dialog, and applies the changes to the <b>SnapShot Debugger view</b> (page 141) table.                                        |
| Cancel           | Discards the specified bus configuration and closes the dialog. No changes are applied to the <b>SnapShot Debugger view</b> (page 141) table.                                     |

# Assign Bussed Values Dialog

The Assign Bussed Values Dialog allows assigning a value to multiple signals from the SnapShot Debugger view (page 141) "Trigger Channels" or "Stimuli Channels" tables as a bus. After configuring the bus in the dialog, the values of each signal are propagated to all of the selected signals in the SnapShot Debugger View (page 141). Two methods are available to launch this dialog allowing bus value assignments:

## Method 1

- 1. Click to select a single row in the SnapShot Debugger View (page 141) table which has a bussed signal name (i.e., limit\_a[2]).
- 2. Right click to edit the Value by Bus.

This method automatically finds all other bits in the bus with the same signal name (e.g.,  $limit_a[0]$ ,  $limit_a[1]$ ,  $limit_A[2]$ , etc.) and opens the dialog to allow editing of the entire bus of signals.

| O Assi | Assign Bussed Values  |                                                                         |               |  |  |  |  |  |
|--------|-----------------------|-------------------------------------------------------------------------|---------------|--|--|--|--|--|
| This   | vizard all            | <b>signment</b><br>ows you to automatically configure<br>bussed signal. |               |  |  |  |  |  |
| Binary | Binary Value 10100011 |                                                                         |               |  |  |  |  |  |
| Hex Va | alue                  | a3                                                                      |               |  |  |  |  |  |
| Decim  | al Value              | 163                                                                     |               |  |  |  |  |  |
| Bit    | Valu                  | e Signal Name                                                           |               |  |  |  |  |  |
| 0      | 1                     | limit_a[0]                                                              |               |  |  |  |  |  |
| 1      | 1                     | limit_a[1]                                                              |               |  |  |  |  |  |
| 2      | 0                     | limit_a[2]                                                              |               |  |  |  |  |  |
| 3      | 0                     | limit_a[3]                                                              |               |  |  |  |  |  |
| 4      | 0                     | limit_a[4]                                                              |               |  |  |  |  |  |
| 5      | 1                     | limit_a[5]                                                              |               |  |  |  |  |  |
| 6      | 0                     | limit_a[6]                                                              |               |  |  |  |  |  |
| 7      | 1                     | limit_a[7]                                                              |               |  |  |  |  |  |
|        |                       |                                                                         |               |  |  |  |  |  |
|        |                       |                                                                         |               |  |  |  |  |  |
|        |                       |                                                                         |               |  |  |  |  |  |
| 0      |                       |                                                                         | Finish Cancel |  |  |  |  |  |

Figure 75 • Value By Bus Assignment Example

## Method 2

- 1. Hold CTRL or SHIFT and click to select multiple rows in the SnapShot Debugger View (page 141) table.
- 2. Right-click to edit the Value by Selection.

This method opens the dialog to allow editing all of the selected signals as a bussed value.

| O Assi | gn Busse | d Values                                             |       | X  |
|--------|----------|------------------------------------------------------|-------|----|
| Bus Va | alue Ass | signment                                             |       |    |
|        |          | ows you to automatically configure<br>bussed signal. |       |    |
| Binary | Value    | X1R0F                                                | <br>  |    |
| Hex Va | alue     | ??                                                   |       |    |
| Decim  | al Value | ?                                                    |       |    |
| Bit    | Valu     | e Signal Name                                        |       |    |
| 0      | F        | reset_n                                              |       |    |
| 1      | 0        | stimuli_valid                                        |       |    |
| 2      | R        | arm                                                  |       |    |
| 3      | 1        | limit_a[0]                                           |       |    |
| 4      | Х        | limit_a[1]                                           |       |    |
|        |          |                                                      |       |    |
|        |          |                                                      |       |    |
|        |          |                                                      |       |    |
|        |          |                                                      |       |    |
|        |          |                                                      |       |    |
|        |          |                                                      |       |    |
|        |          |                                                      |       |    |
|        |          |                                                      |       |    |
| 0      |          | Finish                                               | Canco | el |

Figure 76 • Bus Value By Selection Assignment Example

See also: Configuring the Trigger Pattern (page 366).

### Table 84 · Assign Bussed Values Dialog Options

| Option        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Binary Value  | The desired value for the bus in binary. Valid values for each bit for Trigger<br>Channels are <b>X</b> (don't care), <b>R</b> (rising edge), <b>F</b> (falling edge), <b>1</b> (level 1), and <b>0</b><br>(level 0). Valid values for each bit for Stimuli Channels are <b>1</b> (level 1), and <b>0</b><br>(level 0). The right-most bit corresponds to bit 0 in the table of signal<br>names, and the left-most bit corresponds to the MSb in the table. |
| Hex Value     | The desired value for the bus in hexadecimal. This field is only capable of representing level (1 or 0) values for each channel. <b>X</b> (don't care), <b>R</b> (rising edge), and <b>F</b> (falling edge) binary values result in a "?" character in this field.                                                                                                                                                                                          |
| Decimal Value | The desired value for the bus in decimal. This field is only capable of representing level (1 or 0) values for each channel. <b>X</b> (don't care), <b>R</b> (rising edge), and <b>F</b> (falling edge) binary values result in a "?" character in this field.                                                                                                                                                                                              |
| Bit           | The bit offset into the bus value being edited.                                                                                                                                                                                                                                                                                                                                                                                                             |
| Value         | The bit value at the bit offset into the bus value being edited.                                                                                                                                                                                                                                                                                                                                                                                            |
| Signal Name   | The signal name at the bit offset into the bus value being edited.                                                                                                                                                                                                                                                                                                                                                                                          |
| Finish        | Accepts the specified bus configuration, closes the dialog, and applies the changes to the corresponding <b>SnapShot Debugger view</b> (page 141) table.                                                                                                                                                                                                                                                                                                    |
| Cancel        | Discards the specified bus configuration and closes the dialog. No changes are applied to the corresponding <b>SnapShot Debugger view</b> (page 141) table.                                                                                                                                                                                                                                                                                                 |

# Configure Clock Pre-Routes Dialog

The Configure Clock Pre-Routes dialog allows the creation of new clock pre-route constraints.

This dialog appears after the **Configure Clock Pre-Routes...** action is selected from a context menu in the **Clock Regions view** (page 25), **Clusters view** (page 30), **Partitions view** (page 111), or **Placement Regions view** (page 114).

| Onfigure Clock Pre-Routes                                                |       |   |              |   |   |   |   |   |   |   |    |    |    |    | (  | כ      | × |
|--------------------------------------------------------------------------|-------|---|--------------|---|---|---|---|---|---|---|----|----|----|----|----|--------|---|
| Clusters:<br>LOGIC_CLUSTER_0_5<br>LOGIC_CLUSTER_0_6<br>LOGIC_CLUSTER_0_7 |       |   |              |   |   |   |   |   |   |   |    |    |    |    |    |        |   |
| Clock Pre-Routes:                                                        |       |   |              |   |   |   |   |   |   |   |    |    |    |    |    |        |   |
| Net Name                                                                 | 0     | 1 | 2            | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15     |   |
| i_clk_ipin_net                                                           |       |   |              |   |   |   |   |   |   |   |    |    |    |    |    |        |   |
| i_clk_pr_1_ipin_net                                                      |       |   | $\checkmark$ |   |   |   |   |   |   |   |    |    |    |    |    |        |   |
| i_reset_n_pr_1_ipin_net                                                  |       |   |              |   |   |   |   |   |   |   |    |    |    |    |    |        |   |
| Add Net: Enter the name of an existin                                    | g net |   |              |   |   |   |   |   |   |   |    |    |    |    |    |        | + |
|                                                                          |       |   |              |   |   |   |   |   |   |   |    |    | OK |    | (  | Cancel |   |

Figure 77 • Configure Clock Pre-Routes Dialog Example

### Table 85 · Configure Clock Pre-Routes Dialog Options

| Option                                                  | Description                                                                                                                              |
|---------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Clock Regions/Clusters/<br>Partitions/Placement Regions | A list of the targets to which pre-route table changes are to be applied.                                                                |
| Net Name                                                | Each row in the table contains the name of a net to be constrained.                                                                      |
| Numbered columns                                        | Each numbered column represents a numbered clock track. Checking a cell in the table constrains the given net to the given clock track.  |
| Add Net                                                 | Type the name of any net in the design into the text field, press ENTER or click the (+) <b>Add</b> button to add that net to the table. |

The table in this dialog uses background colors to indicate the actions performed since the dialog appeared:

 A red background indicates that a check box was removed. Red cells indicate that one or more remove\_clock\_preroute commands are to be issued if the **OK** button is clicked.

- A green background indicates that a check box was added. Green cells indicate that one or more add\_clock\_preroute commands are to be issued if the **OK** button is clicked.
- A purple background indicates that a check box exists somewhere in the given clock track column. Only one net at a time may be associated with any clock track. Checking any cell in the table automatically unchecks all other cells in that column.
- Hovering over a green or red cell shows the add\_clock\_preroute or remove\_clock\_preroute commands to be issued for that row in the table when the **OK** button is clicked.

### (i) Note

If some, but not all, targets have a given net associated with a given clock track, *all* targets can be assigned that net/clock track association by unchecking and then re-checking the appropriate check box. When the dialog was first shown, the check box had a purple background. After unchecking and then re-checking, the box has a green background to indicate that new add\_clock\_preroute commands are to be executed to cover any additional targets.

For example, in the following example, the previous example was changed as follows:

- (i\_reset\_n\_pr\_1\_ipin\_net:1) was clicked, unchecking it
- (i\_clk\_ipin\_net:2) was clicked, checking it and automatically unchecking (i\_clk\_pr\_1\_ipin\_net:2)
- (i\_clk\_pr\_1\_ipin\_net: 4,5,6) were all clicked, checking them

| Onfigure Clock Pre-Routes                                                                         |        |   |   |   |   |        |   |  |  |    |    | ( |        | ×    |
|---------------------------------------------------------------------------------------------------|--------|---|---|---|---|--------|---|--|--|----|----|---|--------|------|
| Clusters:<br>LOGIC_CLUSTER_0_5<br>LOGIC_CLUSTER_0_6<br>LOGIC_CLUSTER_0_7                          |        |   |   |   |   |        |   |  |  |    |    |   |        |      |
| Clock Pre-Routes:<br>Net Name<br>i_clk_ipin_net<br>i_clk_pr_1_ipin_net<br>i_reset_n_pr_1_ipin_net | 0      | 1 | 2 | 3 | 4 | add_cl | 6 |  |  | 12 | 13 |   | 15     | .0_5 |
| Add Net: Enter the name of an existin                                                             | ng net |   |   |   |   |        |   |  |  |    |    |   |        | +    |
|                                                                                                   |        |   |   |   |   |        |   |  |  | OK |    |   | Cancel |      |

Figure 78 · Configure Clock Pre-Routes Dialog Update Indicators

# Create a New Constraints File Dialog

The Create a New Constraints File dialog easily creates a new, empty constraints file and optionally adds it to the currently active project. The dialog is available in all perspectives, and can be accessed by selecting **File**  $\rightarrow$  **New**  $\rightarrow$  **SDC Constraints File...**.

| 🖸 Create a New Cons   | traints File                                                                    | - • ×   |
|-----------------------|---------------------------------------------------------------------------------|---------|
| New Constraints File  | I.                                                                              |         |
|                       | create a new SDC Constraints file on the file<br>g, and add it to your project. |         |
| Directory             | Culoutout/acc. projects/timing_test                                             | Browner |
| <u>D</u> irectory:    | C:/output/ace_projects/timing_test                                              | Browse  |
| <u>Fi</u> le name:    | new_1.sdc                                                                       | ]       |
| Add to active project |                                                                                 |         |
|                       |                                                                                 |         |
|                       |                                                                                 |         |
| 0                     | <u>F</u> inish                                                                  | Cancel  |

Figure 79 • Create a New Constraints File Dialog Example

The dialog allows typing the file destination Directory, or selecting it graphically using the **Browse...** button. The Directory name provided must already exist. If selected, the **Browse...** button displays a Directory Selection dialog, which also allows creating a new directory and then selecting it.

The File Name must be unique — a file with that name must not already exist in the destination Directory.

If there is currently an active project in ACE, the **Add to active project** checkbox is enabled and checked by default. If there is no project active, the checkbox is disabled and deselected.

When Finish is selected, the text file is created, and a text editor (page 10) is opened in ACE for the new text file.

#### Note

This dialog may be used to create PDC files as well as SDC files. Simply use .pdc instead of .sdc for the file extension.

# Create a New Flow Step dialog

The Create a New Flow Step dialog (available from the Flow view (page 55)) allows creating a custom step to add to the flow.

| 🛛 🗐 Create a Ne | w Flow Step                                                                     |        | × |
|-----------------|---------------------------------------------------------------------------------|--------|---|
| Custom Flow     | Step Creation                                                                   |        |   |
| A custom flow   | step can be created to perform user-defined actions in the context of the flow. |        |   |
| Flow Step ID:   | custom_step_1                                                                   |        |   |
| Label:          | Custom User Step                                                                |        |   |
| Parent:         | Prepare                                                                         |        | ~ |
| Run after:      | Run Estimated Timing Analysis                                                   |        | ~ |
| TCL Command:    |                                                                                 |        |   |
| Description:    |                                                                                 |        |   |
| Required:       |                                                                                 |        |   |
|                 |                                                                                 |        |   |
|                 |                                                                                 |        |   |
| 0               | <u> </u>                                                                        | Cancel | I |

Figure 80 • Create a New Flow Step Dialog Example

| Field        | Description                                                                                                                         |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Flow Step ID | A unique ID for the new flow step.                                                                                                  |
| Label        | The label to appear in ACE.                                                                                                         |
| Parent       | The parent flow step. Leave blank to create a new "top level" flow step.                                                            |
| Run after    | Name of the flow step after which the new step should be run. Leave blank to create a new "first" flow step.                        |
| Tcl Command  | The Tcl command to run for the new flow step.                                                                                       |
| Description  | A description of the new step to be displayed in a tool tip when the cursor hovers over the step in the <b>Flow view</b> (page 55). |

| Field    | Description                                                               |
|----------|---------------------------------------------------------------------------|
| Required | Checked if this step must always be run, cleared if the step is optional. |

See also: create\_flow\_step (page 621), Custom Flow Steps (page 329), and ACE\_INIT\_SCRIPT (page 284)under Running ACE (page 282)

# Create a New Text File Dialog

The Create a New Text File dialog simply allows creating a new text file and opening the file in the ACE text editor in a single action. The dialog is available in all **Perspectives** (page 6), and can be selected via **File**  $\rightarrow$  **New**  $\rightarrow$  **Text File**.

| O Create           | a New Text File                                                             |        |
|--------------------|-----------------------------------------------------------------------------|--------|
| New Text           | File                                                                        |        |
|                    | d allows you to create a new text file on the file system<br>t for editing. |        |
| <b>N</b> 1         |                                                                             |        |
| Directory:         | C:/                                                                         | Browse |
| <u>F</u> ile name: | new_1.txt                                                                   |        |
|                    |                                                                             |        |
|                    |                                                                             |        |
| 0                  | <u> </u>                                                                    | Cancel |

### Figure 81 • Create a New Text File Dialog Example

The dialog allows typing the file destination directory, or selecting it graphically using the **Browse...** button. The **Directory** name provided must already exist. If selected, the **Browse...** button displays a Directory Selection dialog, which also allows creating a new directory and then selecting it.

The File name must be unique — a file with that name must not already exist in the destination Directory.

When Finish is selected, the text file is created, and the ACE text editor (page 10) is opened for the new text file.

# Create a SecureShare Zip File Dialog

The Create a SecureShare ZIP File dialog allows choosing or refining the contents of a SecureShare file, which is then zipped and placed in the chosen directory, ready for delivery to Achronix Technical Support at <a href="https://support.achronix.com/hc/en-us/">https://support.achronix.com/hc/en-us/</a>. By default, the ZIP file contains all of the important details of the design, enabling Achronix support engineers to examine the design and all output files created during the ACE flow.

Optionally, files may be removed from the default lists of chosen files if it is preferred that those files are not sent to Achronix. In addition, the information may be optionally encrypted in the SecureShare ZIP file.

There are presently three main sections of information in the dialog:

- 1. The Configuration section
- 2. The ACE input files section
- 3. The ACE output files section

More sections are planned to appear in future ACE releases, covering additional support categories, such as synthesis.

This dialog is accessed by selecting **Help**  $\rightarrow$  **Start SecureShare**, or by using the keyboard shortcut **Ctrl + Alt + Shift + S**. When the dialog is shown, it is completely populated by default based upon information gathered from the Active Project and Implementation (page 231). See also Using the ACE SecureShare Tool to Create a Support Zip File (page 471).

## Configuration

| 0   | Create a SecureShare zip file                                                                                     | • • •               |
|-----|-------------------------------------------------------------------------------------------------------------------|---------------------|
| Sec | ureShare                                                                                                          |                     |
|     | noose which files to include in the SecureShare zip file,<br>nich can then be sent to Achronix technical support. |                     |
| С   | onfigure SecureShare                                                                                              | 1                   |
|     | Path to zip file (to be generated):                                                                               |                     |
|     | /home/exampleuser/exampleproj/exampleproj_SecureShare_2021_05_18.zip                                              | Browse              |
|     | Encrypt included files                                                                                            |                     |
| Ŧ   | ACE input files                                                                                                   |                     |
|     |                                                                                                                   |                     |
|     |                                                                                                                   |                     |
| (   | Cancel Create S                                                                                                   | ecureShare zip file |

Figure 82 · Create A SecureShare ZIP File Dialog

### Table 87 · Create A SecureShare ZIP File Options

| Control                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Path to ZIP file (to be generated) | This is the SecureShare file to be generated by ACE when the <b>Finish</b> button is clicked.<br>By default, the ZIP file is written to the output subdirectory of the active implementation, with the file name being the design name as a prefix, followed by "SecureShare", then a suffix comprised of the date the file is generated. For example,<br><active_impl_output_directory>/<br/><active_project_name>_SecureShare_<yyyy>_<mm>_<dd></dd></mm></yyyy></active_project_name></active_impl_output_directory> |
| Encrypt included files             | Defaults to false/unchecked. When checked, the ZIP file (above) is<br>encrypted, and placed in an additional file with the<br>extension .zip.encrypted.                                                                                                                                                                                                                                                                                                                                                                |

## **ACE Input Files**

Each file category (other than the project file) can hold an arbitrary number of files. Files can be added to (or removed from) any of these categories as desired. Clicking any **Add** button pops up a file selection dialog which defaults to the correct file extensions for filtering and allows choosing one or more files to be added to the associated file list.

#### (i) Note

Be aware that every file selection dialog also allows setting the file extension filter to "\*.\*", allowing any filename to be chosen.

Selecting one or more files from a file list category enables the associated **Remove** button which, when clicked, removes the selected files from the list.

| CE input files                                                                                                                                                                                                                            |                      |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
| etlists, constraints, acxprj project files, acxip IP files, and any other files that act as inputs to ACE. Many of th<br>Irpose as synthesis output files.                                                                                | nese might serve a d |
| ☑ Include project file (*.acxprj)                                                                                                                                                                                                         |                      |
| C:\-example- \projects\rel-v8.3\quickstart_example\quickstart_example.acxprj                                                                                                                                                              | Browse               |
| ✓ Include netlist source files                                                                                                                                                                                                            |                      |
| C:\src\win1\rel-v8.3\doc\examples\quickstart\AC7t1500ES0\quickstart.vma                                                                                                                                                                   | Add<br>Remov         |
| ✓ Include constraint files                                                                                                                                                                                                                |                      |
| C:\src\win1\rel-v8.3\doc\examples\quickstart\AC7t1500ES0\quickstart.pdc<br>C:\src\win1\rel-v8.3\doc\examples\quickstart\AC7t1500ES0\quickstart.sdc<br>C:\src\win1\rel-v8.3\doc\examples\quickstart\AC7t1500ES0\quickstart_ioring_util.xml | Add<br>Remov         |
| ✓ Include acxip files                                                                                                                                                                                                                     |                      |
|                                                                                                                                                                                                                                           | Add<br>Remov         |
| ☑ Include other                                                                                                                                                                                                                           |                      |
|                                                                                                                                                                                                                                           | Add                  |

## Figure 83 • ACE Input Files Dialog Example

### Table 88 · SecureShare Input File Categories

| File Category                   | Description                                                                                                                                      |
|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Project file<br>(*.acxprj)      | Defaults to the .acxprj file for the active project.                                                                                             |
| Netlist source files            | Defaults to all the netlist source files (*.v, *.vm, *.vma, *.sv, *.vhdl) found within the active project.                                       |
| Constraint files <sup>(1)</sup> | Defaults to all the enabled constraint files (*.hex, *.pdc, *.prt, *.scf, *.sdc, *.xml) for the active implementation within the active project. |
| *.acxipfiles                    | Defaults to all of the .acxip files found within the active project.                                                                             |
| Other                           | Defaults to empty. Allows the addition of any other arbitrary ACE input files which are not covered by the earlier categories.                   |

### i Table Notes

1. Constraint files within the active project which are not part of the active implementation are not included by default.

## **ACE Output Files**

Similar to input files, each output file category (other than the project file) can hold an arbitrary number of files. Add files to (or remove files from) any of these categories as desired. Clicking any **Add** button pops up a file selection dialog which defaults to the correct file extensions for filtering and allows choosing one or more files to be added to the associated file list.

### (i) Note

Be aware that every file selection dialog also allows setting the file extension filter to "\*.\*", allowing any filename to be chosen.

Selecting one or more files from a file list category enables the associated **Remove** button which, when clicked, removes the selected files from the list.

| C\Users\-example \acknowlinkting diagnosticslog<br>C\Users\-example \acknowlinkting diagnosticslog<br>C\Users\-example \acknowlinkting diagnosticslog<br>C\Users\-example \acknowlinkting diagnosticslog<br>C\Users\-example \acknowlinkting diagnosticslog<br>C\Users\-example \project\kel+&3\quicktart_example\impl_\Veport\quicktart_checker_post_importlog<br>C\-example \project\kel+&3\quicktart_example\impl_\Veport\quicktart_checker_post_preparelog<br>C\-example \project\kel+&3\quicktart_example\impl_\Veport\quicktart_checker_post_preparelog<br>C\-example \project\kel+&3\quicktart_example\impl_\Veport\quicktart_checker_post_prepared.txt<br>C\-example \project\kel+&3\quicktart_example\impl_\Veport\quicktart_checker_post_prepared.txt<br>C\-example \project\kel+&3\quicktart_example\impl_\Veport\quicktart_checker_post_prepared.txt<br>C\-example \project\kel+&3\quicktart_example\impl_\Veport\quicktart_recondition_post_elaboratelog<br>C\-example \project\kel+&3\quicktart_example\impl_\Veport\quicktart_recondition_post_elaboratelog<br>C\-example \project\kel+&3\quicktart_example\impl_\Veport\quicktart_timing_prepared_C2.pdsV, 0C.cv<br>C\-example \project\kel+&3\quicktart_example\impl_\Veport\quicktart_timing_prepared_C2.pdsV, 0C.cv<br>C\-example \project\kel+&3\quicktart_example\impl_\Veport\quicktart_timing_prepared_C2.pdsV, 0C.cv<br>C\-example \project\kel+&3\quicktart_example\impl_\Veport\quicktart_timing_prepared_C2.pdsV, 0C.cv<br>C\-example \project\kel+&3\quicktart_example\impl_\Vueport\quicktart_timing_prepared_C2.pdsV, 0C.cv<br>C\-example \project\kel+&3\quicktart_example\impl_\Vueport\quicktart_timing_prepared_C2.pdsV, 0C.cv<br>C\-example \project\kel+&3\quicktart_example\impl_\Vueport\quicktart_tread<br>C\-example \project\kel+&3\quicktart_example\impl_\Vueport\quicktart_tread<br>C\-example \project\kel+&3\quicktart_example\impl_\Vueport\quicktart_tread<br>C\-example \project\kel+&3\quicktart_example\impl_\Vueport\quicktart_recodb<br>C\-example \project\kel+&3\quicktart_example\impl_\Vuept\tats_max.lib<br>C\-example \project\kel+&3\quicktart_example\impl_\Vuepu                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| C(Users)-example - Lachronix/fm diagnosticslog       Re         C(-example - Lopojects/el-48.3/quickstart_example/impl_1/veports/quickstart_checker_post_prepared.txt       Re         C(-example - Lopojects/el-48.3/quickstart_example/impl_1/veports/quickstart_inefile_prepared.txt       Re         C(-example - Lopojects/el-48.3/quickstart_example/impl_1/veports/quickstart_recondition_post_elaborate.log       Re         C(-example - Lopojects/el-48.3/quickstart_example/impl_1/veports/quickstart_recondition_post_elaborate.log       Re         C(-example - Lopojects/el-48.3/quickstart_example/impl_1/veports/quickstart_timing_prepared_20.0p85/v_OC.txt       Re         C(-example - Lopojects/el-48.3/quickstart_example/impl_1/veports/quickstart_timing_prepared_20.0p85/v_OC.txt       Re         C(-example - Lopojects/el-48.3/quickstart_example/impl_1/quickstart_timing_prepared_20.0p85/v_OC.txt       Re         C(-example - Lopojects/el-48.3/quickstart_example/impl_1/quickstart_placed_higheffort.acxdb       Re         C(-example - Lopojects/el-48.3/quickstart_example/impl_1/quickstart_placed_higheffort.acxdb       Re         C(-example - Lopojects/el-48.3/quickstart_example/impl_1/quickstart_prepared_him1       Re         C(                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\log\impl.log                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Ad  |
| C(\Users\-example- \achronix\workspace_8.3\e4_2018_12\metadata\log C(\Users\-example- \achronix\workspace_8.3\e4_2018_12\metadata\log C(\users\-example- \achronix\workspace_8.3\e4_2018_12\metadata\log C(\users\-example- \achronix\\users\-example-\achronix\\users\-example-\achronix\\users\-example-\achronix\\users\-example-\achronix\\users\-example-\achronix\\users\-example-\achronix\\users\-example-\achronix\\users\-example-\achronix\\users\-example-\achronix\\users\-example-\achronix\\users\-example-\achronix\-example-\achronix\\users\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-example-\achronix\-ex                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| Cl-example         \projects\rel+v8.3\quickstart_example\impl_\reports\quickstart_checker_post_prepare.log         Ac           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\reports\quickstart_clocks_prepared.tml         Rel           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\reports\quickstart_clocks_prepared.tml         Rel           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\reports\quickstart_recondition_post_elaborate.log         Rel           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\reports\quickstart_recondition_post_elaborate.log         Cl-example           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\reports\quickstart_recondition_post_elaborate.log         Cl-example           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\reports\quickstart_recondition_post_elaborate.log         Cl-example           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\reports\quickstart_itaring_prepared.22.0p85V OC.tml         Cl-example           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\reports\quickstart_utilization_prepared.tml         Cl-example           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\ruports\quickstart_prepared.axdb         Rel           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\ruports\quickstart_prepared.axdb         Rel           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\ruports\quicks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Re  |
| Cl-example         \projects\rel+v8.3\quickstart_example\impl_\reports\quickstart_checker_post_prepare.log         Ac           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\reports\quickstart_clocks_prepared.tml         Rel           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\reports\quickstart_clocks_prepared.tml         Rel           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\reports\quickstart_recondition_post_elaborate.log         Rel           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\reports\quickstart_recondition_post_elaborate.log         Cl-example           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\reports\quickstart_recondition_post_elaborate.log         Cl-example           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\reports\quickstart_recondition_post_elaborate.log         Cl-example           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\reports\quickstart_itaring_prepared.22.0p85V OC.tml         Cl-example           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\reports\quickstart_utilization_prepared.tml         Cl-example           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\ruports\quickstart_prepared.axdb         Rel           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\ruports\quickstart_prepared.axdb         Rel           Cl-example         \projects\rel+v8.3\quickstart_example\impl_\ruports\quicks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |
| C.+example - projects/el-&3.quickstart_example/impl_Tyeports/quickstart_clocks_prepared.thtml C.+example - projects/el-&3.quickstart_example/impl_Tyeports/quickstart_clocks_prepared.tht C.+example - projects/el-&3.quickstart_example/impl_Tyeports/quickstart_clocks_prepared.tht C.+example - projects/el-&3.quickstart_example/impl_Tyeports/quickstart_recondition_post_elaborate.log C.+example - projects/el-&3.quickstart_example/impl_Tyeports/quickstart_timing_prepared_C2_0p85V_OC.txt C.+example - projects/el-&3.quickstart_example/impl_Tyeports/quickstart_timing_prepared.C2_0p85V_OC.txt C.+example - projects/el-&3.quickstart_example/impl_Tyeports/quickstart_utilization_prepared.txt C.+example - projects/el-&3.quickstart_example/impl_Tyeports/quickstart_utilization_prepared.txt C.+example - projects/el-&3.quickstart_example/impl_Tyeports/quickstart_utilization_prepared.txt C.+example - projects/el-&3.quickstart_example/impl_Tyeports/quickstart_utilization_prepared.txt C.+example - projects/el-&3.quickstart_example/impl_Tyeports/quickstart_geneared.zxdb C.+example - projects/el-&3.quickstart_example/impl_Tyepared_intial.acxdb C.+example - projects/el-&3.quickstart_example/impl_Tyeuty/soc_maxilb C.+exam                                                                               | Include reports                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| C.+example - kprojects/el-%3.quickstar, example/impl_Tveports/quickstar_clocks_prepared.html C.+example - kprojects/el-%3.quickstar, example/impl_Tveports/quickstar_linefile_prepared.html C.+example - kprojects/el-%3.quickstar, example/impl_Tveports/quickstar_linefile_prepared.html C.+example - kprojects/el-%3.quickstar, example/impl_Tveports/quickstar_linefile_prepared.html C.+example - kprojects/el-%3.quickstar, example/impl_Tveports/quickstar_recondition_post_laborate.log C.+example - kprojects/el-%3.quickstar, example/impl_Tveports/quickstar_recondition_post_laborate.log C.+example - kprojects/el-%3.quickstar, example/impl_Tveports/quickstar_timing_prepared.C2.Qp85V_OC.html C.+example - kprojects/el-%3.quickstar, example/impl_Tveports/quickstar, timing_prepared.C2.Qp85V_OC.html C.+example - kprojects/el-%3.quickstar, example/impl_Tveports/quickstar, timing_prepared.C2.Qp85V_OC.html C.+example - kprojects/el-%3.quickstar, example/impl_Tveports/quickstar, tutilization_prepared.html C.+example - kprojects/el-%3.quickstar, example/impl_Tveports/quickstar, tutilization_prepared.txt C.+example - kprojects/el-%3.quickstar, example/impl_Tveports/quickstar_tutilization_prepared.txt C.+example - kprojects/el-%3.quickstar, example/impl_Tveports/quickstar_tutilization_prepared.txt C.+example - kprojects/el-%3.quickstar, example/impl_Tveports/quickstar_tutilization_prepared.txt C.+example - kprojects/el-%3.quickstar, example/impl_Tveports/quickstar_prepared acxdb C.+example - kprojects/el-%3.quickstar, example/impl_Tveports/quickstar_prepared acxdb C.+example - kprojects/el-%3.quickstar, example/impl_Tveports/quickstar_prepared acxdb C.+example - kprojects/el-%3.quickstar_example/impl_Tveports/quickstar_prepared acxdb C.+example - kprojects/el-%3.quickstar_example/impl_Tveports/quickstar_prepared acxdb C.+example - kprojects/el-%3.quickstar_example/impl_Tveports/quickstar_croadb C.+example - kprojects/el-%3.quickstar_example/impl_Tveports/quickstar_prepared acxdb C.+example - kprojects/el-%3.quickstar_example/impl_Tvepo                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Ad  |
| C_vexample _ \projects/vel-v83\quickstart_example\impl_Tveports\quickstart_lockE_prepared.txt<br>C_vexample _ \projects/vel-v83\quickstart_example\impl_Tveports\quickstart_lockE_prepared.txt<br>C_vexample _ \projects/vel-v83\quickstart_example\impl_Tveports\quickstart_prepared.txt<br>C_vexample _ \projects/vel-v83\quickstart_example\impl_Tveports\quickstart_prepared.txt<br>C_vexample _ \projects/vel-v83\quickstart_example\impl_Tveports\quickstart_recondition_post_inbortlog<br>C_vexample _ \projects/vel-v83\quickstart_example\impl_Tveports\quickstart_recondition_post_inbortlog<br>C_vexample _ \projects/vel-v83\quickstart_example\impl_Tveports\quickstart_recondition_post_inbortlog<br>C_vexample _ \projects/vel-v83\quickstart_example\impl_Tveports\quickstart_tecondition_post_inbortlog<br>C_vexample _ \projects/vel-v83\quickstart_example\impl_Tveports\quickstart_timing_prepared_C2_0p85V_OC.txt<br>C_vexample _ \projects/vel-v83\quickstart_example\impl_Tveports\quickstart_tuilization_prepared.txt<br>C_vexample _ \projects/vel-v83\quickstart_example\impl_Tveports\quickstart_tuilization_prepared.txt<br>C_vexample _ \projects/vel-v83\quickstart_example\impl_Tquickstart_placed_acxdb<br>C_vexample _ \projects/vel-v83\quickstart_example\impl_Tquickstart_prepared_intialacxdb<br>C_vexample _ \projects/vel-v83\quickstart_example\impl_Tquickstart_prepared_intialacxdb<br>C_vexample _ \projects/vel-v83\quickstart_example\impl_Tquickstart_prepared_intialacxdb<br>C_vexample _ \projects/vel-v83\quickstart_example\impl_Tquickstart_prepared_intialacxdb<br>C_vexample _ \projects/vel-v83\quickstart_example\impl_Toutput/fxspec.adb<br>C_vexample _ \pro          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Re  |
| Cexample-\projects/vel-v83\quickstart_example\impl_Tveports\quickstart_lensprepared.txt<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tveports\quickstart_pros_prepared.txt<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tveports\quickstart_recondition_post_elaboratelog<br>C.+example-\projects/vel-v83\quickstart_example\impl_Tveports\quickstart_recondition_post_most_most_most_most_most_most_most_m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Re  |
| Cexample- \projects/vel-v83\quickstart_example\impl_Tveports\quickstart_pins_prepared.txtl<br>Cexample- \projects/vel-v83\quickstart_example\impl_Tveports\quickstart_recondition_post_importlog<br>Cexample- \projects/vel-v83\quickstart_example\impl_Tveports\quickstart_recondition_post_importlog<br>Cexample- \projects/vel-v83\quickstart_example\impl_Tveports\quickstart_recondition_post_importlog<br>Cexample- \projects/vel-v83\quickstart_example\impl_Tveports\quickstart_recondition_post_importlog<br>Cexample- \projects/vel-v83\quickstart_example\impl_Tveports\quickstart_timing_prepared_C2_0p85V_OC.txt<br>Cexample- \projects/vel-v83\quickstart_example\impl_Tveports\quickstart_timing_prepared_C2_0p85V_OC.txt<br>Cexample- \projects/vel-v83\quickstart_example\impl_Tveports\quickstart_tuilization_prepared.txt<br>Cexample- \projects/vel-v83\quickstart_example\impl_Tveports\quickstart_utilization_prepared.txt<br>Cexample- \projects/vel-v83\quickstart_example\impl_Tquickstart_placed.acxdb<br>Cexample- \projects/vel-v83\quickstart_example\impl_Tquickstart_placed_interfort.acxdb<br>Cexample- \projects/vel-v83\quickstart_example\impl_Tquickstart_prepared.acxdb<br>Cexample- \projects/vel-v83\quickstart_example\impl_Tquickstart_prepared.acxdb                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| Cexample-\projects/vel-v83\quickstart_example\impl_Tveports\quickstart_pros_prepared.xt<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tveports\quickstart_recondition_post_elaborate.log<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tveports\quickstart_recondition_pre_flatenlog<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tveports\quickstart_recondition_pre_flatenlog<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tveports\quickstart_recondition_pre_flatenlog<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tveports\quickstart_timing_prepared_C2_0085V_OC.thrd<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tveports\quickstart_tuilization_prepared.thrd<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tveports\quickstart_utilization_prepared.thrd<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tquickstart_placed.acxdb<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tquickstart_placed.doweffort.acxdb<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tquickstart_prepared_acxdb<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tquickstart_prepared_acxdb<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tquickstart_prepared_acxdb<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tquickstart_prepared_acxdb<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tquickstart_prepared_acxdb<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tquickstart_prepared_acxdb<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tquickstart_prepared_acxdb<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tquickstart_prepared_acxdb<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tquickstart_prepared_acxdb<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tquickstart_prepared_acxdb<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tquickstart_prepared_acxdb<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tquickstart_prepared_acxdb<br>Cexample-\projects/vel-v83\quickstart_example\impl_Tquickstart_prepared_acxdb<br>Cexample-\projects/vel-v83\quickstart_examp                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| Cl-example \projects/vel-v8.3\quickstart_example\impl_Tveports\quickstart_recondition_post_import.log Cl-example \projects/vel-v8.3\quickstart_example\impl_Tveports\quickstart_recondition_pre_TattenJog Cl-example \projects/vel-v8.3\quickstart_example\impl_Tveports\quickstart_recondition_pre_TattenJog Cl-example \projects/vel-v8.3\quickstart_example\impl_Tveports\quickstart_recondition_pre_TattenJog Cl-example \projects/vel-v8.3\quickstart_example\impl_Tveports\quickstart_tresomple \projects/vel-v8.3\quickstart_example\impl_Tveports\quickstart_utilization_prepared_C2.0p85V_OC.txt Cl-example \projects/vel-v8.3\quickstart_example\impl_Tveports\quickstart_utilization_prepared.txt Cl-example \projects/vel-v8.3\quickstart_example\impl_Tveports\quickstart_utilization_prepared.txt Cl-example \projects/vel-v8.3\quickstart_example\impl_T\quickstart_placed.acxdb Cl-example \projects/vel-v8.3\quickstart_example\impl_T\quickstart_placed.acxdb Cl-example \projects/vel-v8.3\quickstart_example\impl_T\quickstart_prepared_acxdb Cl-example \projects/vel-v8.3\quickstart_example\impl_T\quickstart_prepared_acxdb Cl-example \projects/vel-v8.3\quickstart_example\impl_T\quickstart_prepared_acxdb Cl-example \projects/vel-v8.3\quickstart_example\impl_T\quickstart_prepared_acxdb Cl-example \projects/vel-v8.3\quickstart_example\impl_T\quickstart_prepared_acxdb Cl-example \projects/vel-v8.3\quickstart_example\impl_T\quickstart_prepared_acxdb Cl-example \projects/vel-v8.3\quickstart_example\impl_T\quickstart_routed.acxdb Cl-example \projects/vel-v8.3\quickstart_example\i                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| Cexample - \projects\rel-v8.3\quickstart_example\impl_Tveports\quickstart_recondition_post_importlog Cexample - \projects\rel-v8.3\quickstart_example\impl_Tveports\quickstart_timing_prepared_C2_0p85V_0C.csv Cexample - \projects\rel-v8.3\quickstart_example\impl_Tveports\quickstart_timing_prepared_C2_0p85V_0C.txt Cexample - \projects\rel-v8.3\quickstart_example\impl_Tveports\quickstart_timing_prepared_C2_0p85V_0C.txt Cexample - \projects\rel-v8.3\quickstart_example\impl_Tveports\quickstart_timing_prepared_C2_0p85V_0C.txt Cexample - \projects\rel-v8.3\quickstart_example\impl_Tveports\quickstart_tuilization_prepared.txt Cexample - \projects\rel-v8.3\quickstart_example\impl_Tveports\quickstart_placed_acxdb Cexample - \projects\rel-v8.3\quickstart_example\impl_T\quickstart_placed_oxdb Cexample - \projects\rel-v8.3\quickstart_example\impl_Tvepared.cz.db Cexample - \projects\rel-v8.3\quickstart_example\impl_Tvquickstart_placed_oxdb Cexample - \projects\rel-v8.3\quickstart_example\impl_Tvquickstart_prepared.cxdb Cexample - \projects\rel-v8.3\quickstart_example\impl_Tvquickstart_prepared.acxdb Cexample - \projects\rel-v8.3\quickstart_example\impl_Tvquickstart_prepared.acxdb Cexample - \projects\rel-v8.3\quickstart_example\impl_Tvquickstart_prepared.cxdb Cexample - \projects\rel-v8.3\quickstart_example\impl_Tvquickstart_routed.acxdb Cexample - \projects\rel-v8.3\quickstart_example\impl_Tvquickstart_routed.acxdb Cexample - \projects\rel-v8.3\quickstart_example\impl_Tvquickstart_routed.acxdb Cexample - \projects\rel-v8.3\quickstart_example\impl_Tvquickstart_routed.acxdb Cexample                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| C:\-example \projects\vel-v8.3\quickstart_example\impl_1\veports\quickstart_timing_prepared_C2_0p85V_0C.html<br>C:\-example \projects\vel-v8.3\quickstart_example\impl_1\veports\quickstart_timing_prepared_C2_0p85V_0C.html<br>C:\-example \projects\vel-v8.3\quickstart_example\impl_1\veports\quickstart_timing_prepared_C2_0p85V_0C.html<br>C:\-example \projects\vel-v8.3\quickstart_example\impl_1\veports\quickstart_timing_prepared_C2_0p85V_0C.html<br>C:\-example \projects\vel-v8.3\quickstart_example\impl_1\veports\quickstart_utilization_prepared.html<br>C:\-example \projects\vel-v8.3\quickstart_example\impl_1\quickstart_placed_acxdb<br>C:\-example \projects\vel-v8.3\quickstart_example\impl_1\quickstart_placed_acxdb<br>C:\-example \projects\vel-v8.3\quickstart_example\impl_1\quickstart_placed_oxdb<br>C:\-example \projects\vel-v8.3\quickstart_example\impl_1\quickstart_prepared_acxdb<br>C:\-example \projects\vel-v8.3\quickstart_example\impl_1\quickstart_prepared_intial.acxdb<br>C:\-example \projects\vel-v8.3\quickstart_example\impl_1\quickstart_prepared_intial.acxdb<br>C:\-example \projects\vel-v8.3\quickstart_example\impl_1\quickstart_routed_acxdb<br>C:\-example \projects\vel-v8.3\          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| C:\-example \projects\rel-v8.3\quickstart_example\impl_Treports\quickstart_timing_prepared_C2_0p85V_0C.htnl<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_Treports\quickstart_timing_prepared_C2_0p85V_0C.htnl<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_Treports\quickstart_utilization_prepared.html<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_Treports\quickstart_utilization_prepared.html<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_Treports\quickstart_placed.acxdb<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_Treports\quickstart_placed.acxdb<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_Trepared.acxdb<br>C:\-example \projects\rel-v8.3\quickstart_example\im |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| C:\-example \projects\rel-v8.3\quickstart_example\impl_1\reports\quickstart_utilization_prepared_C2_0p85V_0C.txt<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\reports\quickstart_utilization_prepared_html<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\reports\quickstart_utilization_prepared_txt<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\quickstart_placed_loweffort.acxdb<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\quickstart_placed_loweffort.acxdb<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared_acxdb<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared_acxdb<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared_inital.acxdb<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\quickstart_routed.acxdb<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\quickstart_routed.acxdb<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\quickstart_routed.acxdb<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\quickstart_routed.acxdb<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\output\fastc_min.lib<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_analysis.txt<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_optimize_ptars.log<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_6.log<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_6.log<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_6.log<br>C:\-example \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| C:\-example \projects\rel-v8.3\quickstart_example\impl_1\reports\quickstart_utilization_prepared.html C:\-example \projects\rel-v8.3\quickstart_example\impl_1\quickstart_utilization_prepared.html C:\-example \projects\rel-v8.3\quickstart_example\impl_1\quickstart_placed.acxdb C:\-example \projects\rel-v8.3\quickstart_example\impl_1\quickstart_placed.acxdb C:\-example \projects\rel-v8.3\quickstart_example\impl_1\quickstart_placed.acxdb C:\-example \projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared.acxdb C:\-example \projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib C:\-example \projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib C:\-example \projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib C:\-example \projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib C:\-example \projects\rel-v8.3\quickstart_example\impl_1\debuq\quickstart_condition_optimize_pranslog C:\-example \projects\rel-v8.3\quickstart_example\impl_1\debuq\quickstart_recondition_optimize_maslog C:\-example \projects\rel-v8.3\quickstart_example\impl_1\debuq\quickstart_recondition_optimize_maslog C:\-example \projects\rel-v8.3\quickstart_example\impl_1\debuq\quickstart_recondition_optimize_maslog C:\-example \projects\rel-v8.3\quickstart_example\impl_1\debuq\quickstart_recondition_post_man.log C:\-example \projects\rel-v8.3\quickstart_example\impl_1\debuq\quickstart_recondition_post_map.log C:\-example \projects\rel                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | . I |
| C(-example- \projects\rel-v8.3\quickstart_example\impl_1\quickstart_placed.axdb<br>C(-example- \projects\rel-v8.3\quickstart_example\impl_1\quickstart_placed_nigheffort.axdb<br>C(-example- \projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared.axdb<br>C(-example- \projects\rel-v8.3\quickstart_example\impl_1\quipt\fastc_max.lib<br>C(-example- \projects\rel-v8.3\quickstart_example\impl_1\quipt\fastc_max.lib<br>C(-example- \projects\rel-v8.3\quickstart_example\impl_1\quipt\fastc_max.lib<br>C(-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_analysis.txt<br>C(-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_analysis.txt<br>C(-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_optimize_mas.log<br>C(-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_optimize_mas.log<br>C(-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_optimize_mas.log<br>C(-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_optimize_mas.log<br>C(-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_opt_map.log<br>C(-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_opt_map.log<br>C(-example- \projec                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_placed_acxdb       Ac         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_placed_loweffort.acxdb       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared_acxdb       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared_acxdb       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared_initial.acxdb       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_routed.acxdb       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_analysis.btt       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_potimize_prams.log       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_potimize_prams.log       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_potimize_prams.log<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_placed_acxdb       Ac         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_placed_loweffort.acxdb       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared_acxdb       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared_acxdb       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared_initial.acxdb       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_routed.acxdb       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_analysis.btt       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_potimize_prams.log       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_potimize_prams.log       Re         C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_potimize_prams.log<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_placed_higheffort.acxdb C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_placed_loweffort.acxdb C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared_acxdb C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared_initial.acxdb C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared_initial.acxdb C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_routed.acxdb C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_routed.acxdb C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fsuc_max.lib C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fsuc_max.lib C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fsuc_max.lib C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fsuc_max.lib C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_analysis.btt C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_econdition_potimize_pars.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_potimize_mas.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log                                                                                | ⊡ Include acxdb files                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     |
| C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_placed_loweffort.acxdb<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_placed_loweffort.acxdb<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared_acxdb<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared_acxdb<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared_acxdb<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared_acxdb<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\slowc_max.lib<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\slowc_max.lib<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_analysis.txt<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_merg_attribute.pdc<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_optimize_prans.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_3.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_3.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_rempre.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Ad  |
| C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared.acxdb C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared.acxdb C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared.acxdb C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_prepared_initial.acxdb C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_routed.acxdb C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\slowc_max.lib C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\slowc_max.lib C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_analysis.tt C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_optimize_brans.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_3.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_3.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_6.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log C\-example-\projects\rel-v8.3\quicksta                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| C\-example-\projects\rel-v8.3\quickstart_example\impl_1\quickstart_routed.acxdb C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_min.lib C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_min.lib C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_min.lib C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_min.lib C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fsysec.adb C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fsysec.adb C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\slowc_max.lib C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_analysis.tt C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_endtion_optimize_brans.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_optimize_brans.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_map.log C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_renvert_9.g C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_renvert_9.g C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_renvert_9.g C\-example-\projects\rel-v8.3\quickstart_exam                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Re  |
| C\-example \projects\rel-v8.3\quickstart_example\impl_1\quickstart_routed.acxdb  Include output files  C\-example \projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib C\-example \projects\rel-v8.3\quickstart_example\impl_1\output\fastc_min.lib C\-example \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_max.lib C\-example \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_max.lib C\-example \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_max.lib C\-example \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_max.lib C\-example \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib Include debug files  C\-example \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_directed_retiming.log C\-example \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_optimize_mas.log C\-example \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_pot_fanout_8.log C\-example \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_pot_fanout_8.log C\-example \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_8.log C\-example \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_8.log C\-example \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_8.log C\-example \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_8.log C\-example \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_8.log C\-example \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_8.log C\-example \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_renap.log C\-example \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log C\-example \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log C\-example \projects\rel-v8.3\quickstart_example\impl_1\debug\qu                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| Include output files         C:-example- \projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib         C:-example- \projects\rel-v8.3\quickstart_example\impl_1\output\fastc_min.lib         C:-example- \projects\rel-v8.3\quickstart_example\impl_1\output\fsstc_max.lib         C:-example- \projects\rel-v8.3\quickstart_example\impl_1\output\fsstc_max.lib         C:-example- \projects\rel-v8.3\quickstart_example\impl_1\output\fsstc_max.lib         C:-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_max.lib         C:-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib         Include debug files         C:-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_analysis.txt         C:-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_condition_optimize_max.log         C:-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_potimize_max.log         C:-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_potimize_max.log         C:-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_3.log         C:-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_6.log         C:-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_map.log         C:-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log         C:-example- \projects\rel-v8.3\quickstart_exampl                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| C\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\fy_spec.adb<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\fy_spec.adb<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_max.lib<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_max.lib<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_max.lib<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib<br>Include debug files<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_directed_retiming.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_optimize_brams.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_optimize_brams.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_pot_fanout_3.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_3.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_6.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_map.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remite_1.log<br>C\-example- \projects\rel-v8.3\quick                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_min.lib<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fsspec.adb<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\slowc_max.lib<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib<br>Include debug files<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_analysis.btt<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_directed_retiming.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_condition_optimize_brams.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_optimize_brams.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_pot_fanout_3.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_3.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_6.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_6.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_map.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remire_1.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_rewire_1.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recindition_post_rewire_1                                     | ✓ Include output files                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |
| C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_min.lib<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fastc_min.lib<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fsuc_max.lib<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fsuc_max.lib<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fsuc_max.lib<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\output\fsuc_max.lib<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_analysis.txt<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_directed_retiming.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_optimize_mas.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_potimize_mlps.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_3.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_6.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_6.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_repare.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remire_1.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_rewire_1.log<br>C\-example-\projects\rel-v8.3\quickstart_example\impl_1\debug                                      | C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\fastc_max.lib                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Ad  |
| C\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_max.lib<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\otepuq\quickstart_analysis.txt<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_analysis.txt<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_merge_attribute.pdc<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_optimize_brams.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_optimize_mlps.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_3.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_map.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_map.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_map.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_map.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_map.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remin_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remin_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remin_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remin_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example                                       | C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\fastc_min.lib                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |
| C\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib<br>☐ Include debug files<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_analysis.txt<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_directed_retiming.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_brams.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_4.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_4.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_4.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_4.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_man.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_man.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_man.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Re  |
| Include debug files           C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_analysis.btt         Act           C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_directed_retiming.log         Ret           C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_mp_merge_attribute.pdc         Ret           C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_optimize_brams.log         Ret           C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_optimize_mlps.log         C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_3.log           C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log         C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_6.log           C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_map.log         C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log           C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log         C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log           C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log         C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remip.log           C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remire                                                                                                                                                                                                                                                                                                                                                                                                                               | C:\-example- \projects\rel-v8.3\guickstart example\impl 1\output\slowc max.lib                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |
| C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_analysis.txt<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_directed_retiming.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_brams.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_potimize_mlps.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_3.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_4.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_6.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remip.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remip.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_analysis.txt<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_directed_retiming.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_brams.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_potimize_mlps.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_3.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_4.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_6.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remip.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remip.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_directed_retiming.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_merge_attribute.pdc<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_optimize_brams.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_3.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_6.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_man.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_man.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remitor.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remitor.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remitor.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_verify_log<br>C\-example- \pro                                       | C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |
| C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_brams.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_3.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_4.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_6.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_6.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_revire_info.tcl<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_verify.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_verify_guidefile                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |
| C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_3.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_3.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_4.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_6.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_6.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_prepare.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remin_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remin_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remin_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_revire_info.tcl<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_verify.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_verify_guidefile                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib<br>☐ Include debug files<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_analysis.txt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Ad  |
| C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_3.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_map.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remin.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_remire_info.tcl<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_verify_guidefile                                                                                                                                                                                                                                                    | C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib<br>Include debug files<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_analysis.txt<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_directed_retiming.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_mlp_merge_attribute.pdc                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |     |
| C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_4.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_6.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_revire_info.tcl<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_verify.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_verify_guidefile                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib<br>Include debug files<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_analysis.txt<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_directed_retiming.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_mlp_merge_attribute.pdc<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_brams.log                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     |
| C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_6.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_map.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_rewrite_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_rewrite_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_rewrite_info.tcl<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_verify.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_verify.log                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib<br>Include debug files<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_analysis.txt<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_directed_retiming.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_mlp_merge_attribute.pdc<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_brams.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_mlps.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_mlps.log                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     |
| C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_prepare.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_remire_info.tcl<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_verify.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_verify_guidefile                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib<br>Include debug files<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_analysis.txt<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_directed_retiming.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_merge_attribute.pdc<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_brams.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_mlps.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_mlps.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_3.log                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |
| C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_prepare.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_rewire_info.tcl<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_verify.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_verify_guidefile                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib<br>Include debug files<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_analysis.txt<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_directed_retiming.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_mlp_merge_attribute.pdc<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_mans.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_mlps.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_pot_fanout_3.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_pot_fanout_4.log                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_rewire_info.tcl<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_rewire_info.tcl<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_verify.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_verify.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_verify.guidefile                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib<br>Include debug files<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_analysis.txt<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_directed_retiming.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_optimize_brams.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_optimize_brams.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_pot_fianout_3.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\debug\quickstart_recondition_post_fanout_4.log                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |
| C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewrite_1.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_rewire_info.tcl<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_verify.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_verify.guidefile                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib<br>Include debug files<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_analysis.txt<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_mlp_merge_attribute.pdc<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_brams.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_potimize_brams.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_potimize_brams.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_3.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_4.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_6.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_6.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_6.log                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |     |
| C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewrite_1.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_rewrire_info.tcl<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_verify.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_verify_guidefile                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib<br>Include debug files<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_directed_retiming.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_directed_retiming.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_brams.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_potimize_mlps.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_pots_fanout_3.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_4.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_4.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_4.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_6.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_man_0.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_man_0.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_man_0.log                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |
| C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_verify.log<br>C\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_verify_guidefile                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib<br>Include debug files<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_analysis.txt<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_erondition_optimize_brams.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_brams.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_brams.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_pot_franout_3.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_3.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_4.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_6.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_6.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     |
| C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_verify_guidefile                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib<br>Include debug files<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_analysis.txt<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_ercondition_optimize_mans.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_mans.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_mans.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_3.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_3.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_4.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_6.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_renap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_renap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_renap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_renap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_renap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_renap.log                                                                                                                                                                                       |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib<br>Include debug files<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_analysis.txt<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_directed_retiming.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_brans.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_pottimize_mlps.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_3.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_4.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_4.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_4.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remire_1.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remire_1.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quick |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib<br>Include debug files<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_analysis.txt<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_directed_retiming.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_brams.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_potimize_mlps.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_3.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_3.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_6.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_renap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\qui |     |
| - Include other                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib<br>Include debug files<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_analysis.txt<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_directed_retiming.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_brams.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_potimize_mlps.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_3.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_3.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_6.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_renap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\qui | Ad  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\output\slowc_min.lib<br>Include debug files<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_analysis.txt<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_directed_retiming.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_optimize_brams.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_potimize_mlps.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_3.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_3.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_fanout_6.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_map.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_renap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_remap.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\quickstart_recondition_post_rewire_1.log<br>C:\-example- \projects\rel-v8.3\quickstart_example\impl_1\.debug\qui |     |

Figure 84 • ACE Output Files Dialog Example

| File category | Description                                                                                                                                                                                                                                                                                                                                                       |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Log files     | <ul> <li>Defaults to a list of all the files found within the active implementation log subdirectory which might include several multiprocess logs, plus: <ul> <li>Any detected GUI log files</li> <li>The latest ACE session log file</li> <li>The latest ACE rlm_diagnostics.log file to help track down any ACE license-related issues.</li> </ul> </li> </ul> |
| Reports       | Defaults to a list of all files found within the active implementation reports subdirectory, plus the latest Multiprocess Summary Report for the active project.                                                                                                                                                                                                  |
| *.acxdb files | Defaults to a list of all . acxdb files found within the active implementation directory.                                                                                                                                                                                                                                                                         |
| Output files  | Defaults to a list of all files found within the active implementation output subdirectory.                                                                                                                                                                                                                                                                       |
| Debug files   | Defaults to a list of all files found within the active implementation . debug subdirectory.                                                                                                                                                                                                                                                                      |
| Other         | Defaults to empty. Allows adding any other arbitrary ACE-related output files which are not covered by the earlier categories.                                                                                                                                                                                                                                    |

 Table 89 · SecureShare Input File Categories

## **Create Implementation Dialog**

The Create Implementation dialog is used to create a new implementation in the selected project. After indicating a new name for the implementation and whether to copy option values from the active implementation, click **Finish** to create the implementation in the selected project.

| Create a New Implementation                                                                                                                             |        |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--|--|--|
| Implementation Creation                                                                                                                                 |        |  |  |  |
| Each implementation of a project holds a set of options and output files.<br>Multiple implementations can be used to experiment with different options. |        |  |  |  |
| New Implementation Name:                                                                                                                                |        |  |  |  |
| impl_2                                                                                                                                                  |        |  |  |  |
| Copy option values from Active Implementation                                                                                                           |        |  |  |  |
|                                                                                                                                                         |        |  |  |  |
|                                                                                                                                                         |        |  |  |  |
| 7 Finish                                                                                                                                                | Cancel |  |  |  |

Figure 85 • Create Implementation Dialog Example

### Table 90 · Create Implementation Dialog Fields

| Field                                            | Default   | Description                                                                                                                                                                                                                                                 |
|--------------------------------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| New Implementation Name                          | impl_     | The name of the new project implementation to be<br>created. This name must be unique among existing<br>implementations in the selected project. The new<br>name is used to create a new directory under the<br>project directory for the selected project. |
| Copy Option Values from Active<br>Implementation | Unchecked | If this field is checked, option values from the current<br>Active Implementation are copied into the new<br>implementation.                                                                                                                                |

# **Create Placement Region Dialog**

This wizard dialog appears after a drag-and-drop to define a rectangular area in the **Floorplanner view** (page 45) while the Placement Region tool is active. This dialog allows naming the new Placement Region, and defining its bounds.

See also: Creating a New Placement Region (page 395).

| Oreate Place                                                                                                                                         | ment Region       | — |       | ×  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|---|-------|----|--|
| Create Placem                                                                                                                                        | ent Region        |   |       |    |  |
| You can create placement regions in the Core and constrain instances to them later<br>via drag and drop or TCL commands.                             |                   |   |       |    |  |
| Region Name                                                                                                                                          | region_1          |   |       |    |  |
| Is Partial Rec                                                                                                                                       | onfiguration Zone |   |       |    |  |
| Region Alignment <ul> <li>None</li> <li>Snap to Tile Boundaries</li> <li>Snap to Fabric Clusters</li> <li>Snap to Clock Region Boundaries</li> </ul> |                   |   |       |    |  |
| Region Type<br>Inclusive<br>Keep out<br>Soft                                                                                                         |                   |   |       |    |  |
| □ Include Rout                                                                                                                                       | ing               |   |       |    |  |
| Subtile Grid C                                                                                                                                       | oordinates        |   |       |    |  |
| X1 Coordinate                                                                                                                                        | 26                |   |       |    |  |
| Y1 Coordinate                                                                                                                                        | 90                |   |       |    |  |
| X2 Coordinate                                                                                                                                        | · 79              |   |       |    |  |
| Y2 Coordinate                                                                                                                                        | 129               |   |       |    |  |
|                                                                                                                                                      |                   |   |       |    |  |
| 0                                                                                                                                                    | <u>F</u> inish    |   | Cance | el |  |

### Figure 86 • Create Placement Region Dialog Example

### Table 91 Create Placement Region Dialog Options

| Option          | Description                                                                                                                                          |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Region Name     | The name for the new Placement region. ACE pre-populates this field with a default incrementing value.                                               |
| Include Routing | Treats the region as a routing constraint as well as a placement constraint, keeping all routing wires and instances inside the region boundary box. |

| Option                                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|---------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Is Partial Reconfiguration<br>Zone                | Indicates the region is intended to be used for partial reconfiguration.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| Region Alignment                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| None                                              | No snapping.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| Snap to Tile<br>Boundaries <sup>(1)</sup>         | If selected, ACE creates a Placement region that encompasses all tiles selected within the drag-and-drop rectangle.                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| Snap to Fabric Clusters <sup>(2)</sup>            | If selected, ACE creates a Placement region that encompasses all fabric clusters within the drag-and-drop rectangle.                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| Snap to Clock Region<br>Boundaries <sup>(3)</sup> | If selected, ACE creates a Placement region that encompasses all Clock regions which contain any of the selected tiles.                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| Region Type                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| Inclusive                                         | Instances added to the region are placed within the region bounding box. Permits instances to be placed inside the region even if they do not belong to the region.                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| Keep out                                          | Prevents any instances from being placed inside the region. No instances may be added to a Keep Out region.                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| Soft                                              | Instances added to the region are pulled toward the region center during placement, but instances are permitted to overflow the bounds of the soft region. Soft Placement regions are rendered as ellipses in the Floorplanner View (page 45), and the center of the ellipse acts as a center-of-gravity for placement. Soft regions do not limit the contained number of constrained instances, nor do they have a true count of contained sites of each resource. See Placement Regions and Placement Region Constraints (page 394) for more details. |  |  |
| Subtile Grid Coordinates                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| X1 Coordinate                                     | The upper-left X coordinate within the subtile grid, corresponds to the left edge.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| Y1 Coordinate                                     | The upper-left Y coordinate within the subtile grid, corresponds to the top edge.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| X2 Coordinate                                     | The lower-right X coordinate within the subtile grid, corresponds to the right edge.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| Y2 Coordinate                                     | The lower-right Y coordinate within the subtile grid, corresponds to the bottom edge.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |

#### Table Notes

1. Since Placement regions can only contain entire sites (no partial sites), the Placement region can potentially grow larger than the outline rectangle.

2. In this mode, since Placement regions can only contain entire fabric clusters (no partial fabric clusters), the Placement region almost certainly grows larger than the outline rectangle.

3. If selected, ACE creates a Placement region that encompasses all Clock regions which contain any of the selected tiles.

### (i) Note

When using Subtile grid coordinates, the 0,0 coordinate maps to the upper-left of the Core+Boundary in the Floorplanner view. The exact coordinates of the lower-right corner coordinate limits of the Core+Boundary vary by device.

## **Create Project Dialog**

The Create Project dialog helps create a new project in the Workbench. After indicating a name and location for the project, click **Finish** to create the project.

| 🖸 Create a New Pr                                               | oject                                      |        |
|-----------------------------------------------------------------|--------------------------------------------|--------|
| Project Creation<br>A project represents a<br>and flow outputs. | collection of source files, flow settings, |        |
| Project Directory:<br>Project name:<br>Implementation name:     | C:/test_projects/test12<br>test12          | Browse |
| 0                                                               | Finish                                     | Cancel |

Figure 87 • Create Project Dialog Example

| Table 92 • Create Project Dialog Fields | Table 92 | Create Pro | oject Dialog | <b>Fields</b> |
|-----------------------------------------|----------|------------|--------------|---------------|
|-----------------------------------------|----------|------------|--------------|---------------|

| Field               | Description                                                                                                                                                |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Project Directory   | The location in the file system where the project is created. Either type the new location or browse to select a file system location for the new project. |
| Project Name        | The name of the new project to be created. This is the base name of the .acxprj file created in the project directory.                                     |
| Implementation Name | The name of the new implementation to be created with the project.<br>Leaving this blank causes a name to be chosen automatically.                         |

## Generate I/O Ring Design Files Dialog

The Generate I/O Ring Design Files dialog selects the directory into which all the customized I/O ring design files are output, including:

- Complete package ball pin assignment, power, and utilization reports
- Pin placements PDC, Verilog wrappers, and port lists for the Core user design
- The full I/O ring bitstream, which is automatically combined with the Core user design bitstream in ACE at the end of the normal place-and-route flow for the Core user design
- · Customized I/O ring simulation files, including Verilog wrappers for the top-level and I/O ring configuration data

The files generated are based upon the I/O Ring IP Configuration (.acxip) files in the active ACE project created via the active IP Configuration editor (page 9). See also: Creating an IP Configuration (page 335) and I/O Designer Toolkit Views (page 62).

| O Generate IO Ring Design Files                                                                                                                |  | ×    |      |
|------------------------------------------------------------------------------------------------------------------------------------------------|--|------|------|
| IO Ring File Generation Configuration                                                                                                          |  |      |      |
| This wizard allows you to generate IO Ring design files into a specified directory,<br>and optionally add the generated files to your project. |  |      |      |
| O Use Default Output Path From Project Options                                                                                                 |  |      |      |
| ● Use Custom Output Path                                                                                                                       |  |      |      |
| Directory: D:/build/configs/proj_1/ioring_design                                                                                               |  | Br   | owse |
|                                                                                                                                                |  |      |      |
| ⑦ Finish                                                                                                                                       |  | Cano | cel  |

Figure 88 • Generate I/O Ring Design Files Dialog Example

| Field                                           | Default  | Description                                                                                                                                                                                                                                                                                                                                             |
|-------------------------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Use Default Output Path From<br>Project Options | Selected | When selected, the I/O ring design file output<br>path is configured in your ACE Project Options<br>using the<br>use_default_ioring_design_generati<br>on_path and<br>ioring_design_generation_path<br>project options. When selected, the <b>Directory</b><br>path is grayed out and shows the file path as<br>configured in your ACE project options. |

| Field                  | Default                                                                  | Description                                                                                                                                                                                                                            |
|------------------------|--------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Use Custom Output Path | Not Selected                                                             | When selected, the I/O ring design file output<br>path can be customized by setting the<br><b>Directory</b> path. The ACE project option settings<br>are ignored in this case.                                                         |
| Directory              | <active_ace_project_di<br>r&gt;/ioring_design</active_ace_project_di<br> | Selects the target directory path for the I/O ring design files when generated.                                                                                                                                                        |
| Add to active project  | Selected                                                                 | When selected, the necessary generated I/O<br>ring design files (e.g., PDC pin placement<br>constraints, Verilog wrappers, and SDC files for<br>the core user design logic) are automatically<br>added to the active ACE project file. |

## Generate IP Design Files Dialog

The Generate IP Design Files dialog creates the necessary RTL models, timing constraints and bitstream files for configuring embedded core IP. The files generated are based upon the configuration (.acxip) file created via the active core IP Configuration editor (page 9).

See also: Creating an IP Configuration (page 335).

| O Generate IP Design Files                                                                                                     |        |
|--------------------------------------------------------------------------------------------------------------------------------|--------|
| Speedster16t LRAM FIFO Design File Generation<br>The following design files can be generated for the<br>Speedster16t LRAM FIFO |        |
| RTL Models                                                                                                                     |        |
| <ul> <li>✓ H:/new_lram_fifo_1.v</li> <li>✓ VHDL Model</li> </ul>                                                               | Browse |
| H:/new_lram_fifo_1.vhd                                                                                                         | Browse |
|                                                                                                                                |        |
|                                                                                                                                |        |
| ⑦ <u>Finish</u>                                                                                                                | Cancel |

Figure 89 • Generate IP Design Files Dialog Example

#### (i) Note

Each IP Configuration editor has its own set of output files specific to the type of core IP being configured. For example, some types of IP require PDC or SDC constraints files, while other types of IP do not. The dialog fields presented are dynamic, and change according to the needs of the core IP being generated.

The following table of dialog fields describes the common output files for most types of core IP. The fields presented for each individual core IP are typically a subset of the fields listed.

#### Table 94 · Generate IP Design Files Dialog Fields

| Field                        | Default    | Description                                                        |
|------------------------------|------------|--------------------------------------------------------------------|
| RTL Models                   |            |                                                                    |
| Verilog Model <sup>(1)</sup> | Selected   | Selects whether to generate a Verilog model for the configuration. |
| VHDL Model <sup>(1)(2)</sup> | Deselected | Selects whether to generate a VHDL model for the configuration.    |

| Field                                   | Default           | Description                                                                                                                             |
|-----------------------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Timing Constraint                       | ts                |                                                                                                                                         |
| SDC<br>Constraints <sup>(1)</sup>       | Selected          | Selects whether to generate an SDC constraints file for the configuration.                                                              |
| Placement<br>Constraints <sup>(1)</sup> | Selected          | Selects whether to generate a placement constraints file for the configuration.                                                         |
| Table Notes                             | <u></u>           |                                                                                                                                         |
| 1. The default                          | file path is disp | layed under the option. An alternate path can be selected via the <b>Browse</b> button.                                                 |
|                                         |                   | lel is a simple wrapper around the Verilog RTL model, when using the VHDL RTL model, the Verilog RTL model<br>I included in the design. |

### Load Acxdb Dialog

After cancelling the Flow (page 235) in the Flow view (page 55), the Load Acxdb dialog allows restoring the database of the active implementation to the previously saved state found in the .acxdb archive file. This restoration should be performed after canceling a running flow to prevent leaving the database in a partially processed state.

After populating the **Acxdb File** field with the desired archive file, which defaults to the .acxdb file with the most recent timestamp, click **Finish** to restore the implementation to the state preserved in the file. To avoid loading a file and to proceed with the database in the current, possibly incomplete flow state, click **Cancel**.

#### (i) Note

When canceling the flow, this dialog only appears if the run is cancelled after the **Run Prepare** stage is complete.

| Evaluation Load Acxdb                                                                                                                                                  |   | o x    |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--------|
| Load Acxdb file: proj_4->impl_1                                                                                                                                        |   |        |
| Since the flow is cancelled, the state of the database for the Active Implementation may be restored<br>from an Acxdb Archive File. Choose "Cancel" to skip this step. |   |        |
| Acxdb file                                                                                                                                                             |   |        |
| /ace_projects/project1/impl1/impl1_pewpared.acxdb                                                                                                                      | ~ | Browse |
|                                                                                                                                                                        |   |        |
|                                                                                                                                                                        |   |        |
|                                                                                                                                                                        |   |        |
| ⑦ Cancel                                                                                                                                                               |   | Finish |
|                                                                                                                                                                        |   |        |

#### Figure 90 · Load Acxdb Dialog Example

### Table 95 Load Acxdb Dialog Fields

| Field      | Default                                                                    | Description                                                                                                                                                                                                                                                                                                                                                                               |
|------------|----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Acxdb File | The latest archive file file found in the active implementation directory. | The file path to the desired .acxdb archive file,<br>which is used to restore the implementation to an<br>earlier saved state. Enter the desired path directly<br>into this field. A drop-down list provides easy<br>access to all archive files in the default directory for<br>the active implementation. The <b>Browse</b> button<br>allows graphically navigating to alternate files. |

### Load Project Dialog

The Load Project Dialog allows browsing to find an existing project file to load into the Workbench. After selecting the project file and choosing to activate an implementation, click **Finish** to load the project.

| O Load Project                                                                                                                        |               |
|---------------------------------------------------------------------------------------------------------------------------------------|---------------|
| Load Project<br>Previous ACE Projects may be loaded from Acxprj files                                                                 |               |
| Project File C:/test_projects/nda_alcatel_crc/nda_alcatel_i  Browse Activate an Implementation Active Implementation Impl Name impl_1 | Clear History |
| ? Finish                                                                                                                              | Cancel        |

#### Figure 91 • Load Project Dialog Example

#### Table 96 • Load Project Dialog Fields

| Field                         | Description                                                                                                                                                                                                                                                                                                    |  |
|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Project File                  | The path to the ACE Project File (.acxprj). Either type the new location or browse to select a path to the project file. A history of previously loaded projects can be accessed via the drop-down list. This previous project history may be cleared at any time by clicking the <b>Clear History</b> button. |  |
| Activate an<br>Implementation | Check to activate an implementation upon loading the project. If another project is already loaded, this field can be cleared to preserve the current active implementation in the ACE session.                                                                                                                |  |
| Impl Name                     | The name of the implementation to activate after loading the project. A drop-down list allows selecting from any implementation defined within the specified project file.                                                                                                                                     |  |

### New IP Configuration Dialog

The New IP Configuration Dialog helps create a new IP configuration (.acxip) file. After indicating a name and location for the configuration file, click **Finish** to create the file and open the relevant IP Configuration editor (page 9). See also: **Creating a New IP Configuration** (page 335).

| O Create a New IP Configu                                                                                                                                    | uration                                                |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|--|--|
| New IP Configuration<br>This wizard allows you to create a new IP Configuration file on the file<br>system, open it for editing, and add it to your project. |                                                        |  |  |
| Available IP<br>A Speedster16t<br>BRAM<br>DSP FIR Filter<br>DSP64<br>FIFO<br>LRAM<br>LRAM FIFO<br>ROM<br>Shift Register                                      | Description<br>Speedster16t BRAM wrapper generator.    |  |  |
| Directory:                                                                                                                                                   | C:/Users/example/Documents/acx/hs1.1/quickstart Browse |  |  |
| File name:<br>☑ Add to active project                                                                                                                        | new_1.acxip                                            |  |  |
| 0                                                                                                                                                            | <u>F</u> inish Cancel                                  |  |  |

Figure 92 • New IP Configuration Dialog Example

#### (i) Note

The displayed IP Libraries and IP types are dynamic and change based on which technology libraries and devices are installed and licensed. The screenshots and example descriptions in this section do not necessarily reflect the IP types of the actual device being used.

#### New IP Configuration Dialog Fields

| Field                    | Default                                        | Description                                                                                                                                                                                                                  |
|--------------------------|------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Available IP             | - Lists the available IP blocks by FPGA family |                                                                                                                                                                                                                              |
| Description              | -                                              | Provides a description of the IP block.                                                                                                                                                                                      |
| Directory                | Current active<br>project directory            | The location in the file system where the<br>configuration file is created. Either type the new<br>location or browse to select a file system location for<br>the new configuration.                                         |
| File Name <sup>(1)</sup> | newacxip                                       | The name of the new configuration file to be created.<br>The file name (without the .acxip suffix) also<br>becomes the module name in the generated IP.                                                                      |
|                          |                                                | This check box allows the IP configuration file to be<br>added to the current project (this option is only<br>available if a project is active).                                                                             |
| Add to active project    | Enabled                                        | If unchecked, the IP configuration file is created at<br>the chosen path but not automatically added to any<br>project. Because it is not a member of a project, the<br>new .acxip file is not visible in the Projects view. |

#### **Table Notes**

1. Names that collide with Achronix reserved module names are prohibited.

### Plot SerDes Diagram Dialog

The Plot SerDes Diagram dialog appears after selecting **Plot SerDes Diagram** from the option menu when rightclicking a SerDes Lane in the **I/O Layout Diagram view** (page 68). The dialog allows plotting a diagram (Eye plot, Histogram, or Bathtub) for the selected SerDes RX lane using the built-in capture hardware.

#### (i) Note

This tool requires the free Matlab runtime executable to be installed in addition to ACE with an open JTAG connection in your ACE session to access the SerDes logic on the chip.

See also: Plotting SerDes Receiver Diagrams Using JTAG (page 476).

| Plot a Serdes Rx E                | Diagram using JTAG                                                                    |  |      | $\times$ |
|-----------------------------------|---------------------------------------------------------------------------------------|--|------|----------|
| Serdes Diagram Plot Configuration |                                                                                       |  |      |          |
| Using an existing ope             | en JTAG connection, capture and plot internal Rx diagrams from the chosen SerDes lane |  |      |          |
| IP Block Name:                    | SERDES_LN_11                                                                          |  |      |          |
| JTAG Device ID:                   | \$jtag_id                                                                             |  |      |          |
| Number of Samples:                | 500                                                                                   |  |      |          |
| Capture Point:                    | FFE                                                                                   |  | ~    |          |
| Diagram Type:                     | Eye Plot                                                                              |  | ~    |          |
| Figure Name:                      | SERDES_LN_11 Rx Plot                                                                  |  |      |          |
| Figure Number:                    | 1                                                                                     |  |      |          |
| Capture Data File:                | D:/proj_7/impl_1/output/SERDES_LN_11_diagram.txt                                      |  | В    | rowse    |
|                                   |                                                                                       |  |      |          |
|                                   |                                                                                       |  |      |          |
| 0                                 | Finish                                                                                |  | Cano | cel      |

### Figure 93 • Plot SerDes Diagram Dialog Example

### Table 97 • Plot SerDes Diagram Dialog Fields

| Option            | Description                                                                                                                                                                                                                                                                    |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IP Block Name     | The name of the SerDes IP block selected from the right-click option menu in the I/O Layout Diagram view.                                                                                                                                                                      |
| JTAG Device ID    | The ID of the connected JTAG device (an FTDI USB chip or a Bitporter2 pod). This ID can be specified with a hard-coded string such as "AC12345" or with a Tcl variable.                                                                                                        |
| Number of Samples | The number of samples to capture in the SerDes RX capture hardware. The default for an eye plot is 500 samples. Over JTAG, this requires approximately 10 minutes to read back and plot. More samples produces a more accurate diagram, while less samples can reduce runtime. |
| Capture Point     | Selects the internal SerDes block from which to capture data.                                                                                                                                                                                                                  |
| Diagram Type      | Select an eye plot, histogram, or bathtub plot.                                                                                                                                                                                                                                |

| Option            | Description                                                                                                                                                                                                               |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Figure Name       | Specifies a label to appear on the generated diagram image.                                                                                                                                                               |
| Figure Number     | Specifies a figure number label to appear on the generated diagram image.                                                                                                                                                 |
| Capture Data File | Enter the file path to the diagram capture data retrieved from the SerDes hardware via JTAG. Click <b>Browse</b> to graphically select the file. This file can be used to plot multiple diagram types from the same data. |

### MATLAB SerDes Eye Plot Y-axis Unit Formula

ACE 9.2+ uses MATLAB Runtime 2021b (9.11) for the SerDes eye plot. With this update, the Y-axis units are updated from voltage (V) to the more accurate digital codes (codes). Full scale is +/-128. To convert from codes to voltage, assume the FFE and DFE gain is 1 and the ADC is 8-bit with a full scale of 0.55V. Thus, the conversion from codes to voltage is:

estimate\_voltage = codes × (0.55 / 256)

### **Restore Implementation Dialog**

The Restore Implementation dialog restores the database state of the active implementation from a .acxdb archive file. After indicating the path to the archive file from which to restore the implementation, click **Finish** to restore the active implementation.

| O Restore Implementation                                                                                               |
|------------------------------------------------------------------------------------------------------------------------|
| Restore Implementation: serdes10g_quad_unrel_test1->impl_1                                                             |
| The state of the database for the Active Implementation<br>may be restored from an Axcdb Archive File.                 |
| Acxdb file C:/test_projects/serdes10g_quad_unrel_test1/impl_1/serdes10g_quad_unrel_test1_prepared.acxdb  Browse Browse |
| Finish Cancel                                                                                                          |

#### Figure 94 • Restore Implementation Dialog Example

### Table 98 · Restore Implementation Dialog Fields

| Field      | Default    | Description                                                                                                                                                      |
|------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Acxdb File | directory/ | The path to the .acxdb archive file from which to restore the implementation. A drop-down list provides easy access to all other archive files in the directory. |

### Save Implementation Dialog

The Save Implementation dialog saves the database state of the active implementation to an .acxdb archive file. After indicating the path to the file in which to save the implementation, and whether to include the log file, click **Finish** to save the active implementation.

| O Save Implementation                                                                                                                                        |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Save Implementation: serdes10g_quad_unrel_test1->impl_1<br>The state of the database for the Active Implementation<br>may be saved to an Axcdb Archive File. |  |  |  |
| Acxdb file C:/test_projects/serdes10g_quad_unrel_test1/impl_1/impl_1.acxdb    Browse  Save log information (Recommended)                                     |  |  |  |
| 7 Finish Cancel                                                                                                                                              |  |  |  |

#### Figure 95 • Save Implementation Dialog Example

#### (i) Note

Implementations may only be saved after the Run Prepare flow step has been completed. Prior to that, there is no meaningful content in the database to save.

| Table 99 | Save Implementation Dialog Fields |  |
|----------|-----------------------------------|--|
|----------|-----------------------------------|--|

| Field                | Default | Description                                                                                                   |
|----------------------|---------|---------------------------------------------------------------------------------------------------------------|
| Acxdb File           | .acxdb  | The path to .acxdb archive file in which the implementation is saved.                                         |
| Save Log Information | On      | If this field is checked, the log file for the current active implementation is included in the archive file. |

# Save Placement Dialog

The Save Placement dialog saves the current placement to pre-placement constraints file(s). After selecting the appropriate options one page one, click **Next** and continue on page two. Click **Finish** to save the placement. This dialog can be triggered from the **Floorplanner view** (page 45), the **Search view** (page 133), and the **Selection view** (page 137).

| Save Pre-Placement Data (on example.local) □ ×                                                         |
|--------------------------------------------------------------------------------------------------------|
| Save Pre-Placement Data: Files                                                                         |
| The current placement data may be saved to disk and optionally<br>added to your project for later use. |
| Save I/O Pin Placement Use Default Location for I/O Pin Placement file                                 |
| ./io_preplacement.pdc                                                                                  |
| Browse<br>✓ Save Core Instance Placement                                                               |
| Use Default Location for Core Placement file                                                           |
| ./core_preplacement.pdc                                                                                |
| Browse  Automatically Add to Project                                                                   |
|                                                                                                        |
| O           Cancel         Finish                                                                      |

### Figure 96 • Save Placement Page One Dialog Example

| 🧿 Sav                                         | e Pre-Placement Data                           | (on example.local) |        |  |
|-----------------------------------------------|------------------------------------------------|--------------------|--------|--|
| Save Pre-Placemen                             | t Data: Options                                |                    |        |  |
| The current placemen<br>added to your project | t data may be saved to di<br>for later use.    | sk and optionally  |        |  |
| _                                             | nstraints<br>ment Only<br>Saved Instances/Pins |                    |        |  |
| Save Specific List of Instances               |                                                |                    |        |  |
| [get_selection]                               |                                                |                    |        |  |
|                                               |                                                |                    |        |  |
| 0                                             | < Back Nex                                     | t > Cancel         | Finish |  |

Figure 97 • Save Placement Page Two Dialog Example

### Table 100 Save Placement Dialog Fields

| Field                                              | Default | Description                                                                                                                           |  |
|----------------------------------------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------|--|
| Save I/O Pin Placement                             | Enabled | Indicates whether placement of instances in the<br>Boundary ring should be saved.                                                     |  |
| Use Default Location for I/O Pin<br>Placement File | Enabled | Specifies using the default I/O pin placement file path.                                                                              |  |
| (Text Box)                                         | (blank) | Specify the I/O pin placement file path if the above option is disabled.                                                              |  |
| Save Core Instance Placement                       | Enabled | Indicates whether placement of instances in the core fabric should be saved.                                                          |  |
| Use Default Location for Core<br>Placement File    | Enabled | Specifies using the default core placement file path.                                                                                 |  |
| (Text Box)                                         | (blank) | Specify the core placement file path if the above option is disabled.                                                                 |  |
| Automatically Add to Project                       | Enabled | Controls whether the output placement files are<br>automatically added to the current project as pre-<br>placement constraints files. |  |

| Field                                     | Default    | Description                                                                                                                                                                                                                                         |
|-------------------------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Create Boundary Pins                      | Enabled    | Indicates whether the placement of boundary pin instances should be saved.                                                                                                                                                                          |
| Output Region Constraints                 | Enabled    | Controls whether Placement regions and Placement region constraints (page 394) are exported to the PDC file.                                                                                                                                        |
| Save Fixed Placement Only $^{(1)}$        | Enabled    | Controls whether only the current fixed-placement<br>constraints are saved to the output files. If set, all<br>other placement information (such as that generated<br>by the placer) is ignored.                                                    |
| Fix Placement of Saved Instances/<br>Pins | Enabled    | Forces all saved placements to be "fixed" placement, to allow lock down of all placed instances.                                                                                                                                                    |
| Save Specific List of Instances           | Contextual | Enabled by default when created from the Search<br>view (page 133) or Selection view (page 137). Disabled by<br>default when created from the Floorplanner<br>view (page 45).                                                                       |
| (Text Box)                                | (blank)    | Enter a Tcl list of instance names, or a Tcl statement<br>that returns a list of instance names. This list is then<br>used (instead of all instances in the design) in<br>combination with the other dialog settings when<br>choosing what to save. |

### **Table Notes**

1. It is recommended to always use this option when saving pre-placement constraints.

### Save Placement Regions Dialog

The Save Placement Regions Dialog appears after selecting the **Save Placement Regions** action in the Placement Regions view. This dialog allows saving placement region definitions, including the instance constraints for those placement regions.

See also: Saving Placement Region Constraints (page 400).

| O Save Placement Regions                                            |                                                   |
|---------------------------------------------------------------------|---------------------------------------------------|
| Save Placement Regions Data                                         |                                                   |
| The current placement regions m<br>optionally added to your project |                                                   |
| Output File<br>Save All Regions                                     | /examples/quickstart/placement_regions.pdc Browse |
| Save Specified Region<br>Region Name                                |                                                   |
| Automatically Add to Project                                        |                                                   |
|                                                                     |                                                   |
| 0                                                                   | <u>Finish</u> Cancel                              |

### Figure 98 • Save Placement Regions Dialog Example

| Option                       | Description                                                                                                                                                        |  |  |
|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Output File                  | The full path to the .pdc file containing the region definitions and constraints.                                                                                  |  |  |
| Save all Regions             | Saves the data for all regions listed in the Placement Regions view.                                                                                               |  |  |
| Save Specified Region        | Saves the data for a single region specified by <b>Region Name</b> .                                                                                               |  |  |
| Region Name                  | The name of the Placement Region to be saved. This field is disabled unless <b>Save Specified Region</b> is selected.                                              |  |  |
| Automatically Add to Project | When selected, if the <b>Output File</b> is not already a member of the constraints for the active project, the file is added to the project as a constraint file. |  |  |

# Search Filter Builder Dialog

The Search Filter Builder dialog allows building simple or compound search filters for the Search view (page 133) (the dialog is accessed from the ... button in the **Filters** row of the Search view).

Search filters find objects in the design based upon properties other than object name. Simple filters may be combined into a compound filter by joining them with Boolean operators. See Filter Properties (page 264) for a table of the available filter properties with descriptions.

| O Seach Filter Builder                                                                                                                                                |     | X   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|
| Search Filter Builder<br>This wizard allows you to build up your find command<br>filter using the available options below.                                            |     |     |
| Filter @clock_domain=clka &&                                                                                                                                          |     |     |
| Operators <ul> <li>AND</li> <li>OR</li> <li>EQUAL</li> </ul> Insert Operator                                                                                          |     |     |
| Filters                                                                                                                                                               |     |     |
| Name       @region       Description         Comparison       =       The @region filter allows you to the instances, nets, paths, and pins be placement region name. |     | *   |
| Values region_1 -                                                                                                                                                     |     |     |
| Insert Filter                                                                                                                                                         |     | *   |
|                                                                                                                                                                       |     |     |
| <u> </u>                                                                                                                                                              | Can | cel |

Figure 99 • Search Filter Builder Dialog Example

#### Table 102 Search Filter Builder Dialog Options

| Option | Description                                                                                                                                           |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Filter | The filter string itself. Type directly into this field, or populate this field by using the <b>Insert Operator</b> and <b>Insert Filter</b> buttons. |

| Option          | Description                                                                                                                                                                                                                                                                                                                           |  |  |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Operators       |                                                                                                                                                                                                                                                                                                                                       |  |  |
| AND             | Select this radio button to join two filters into a compound filter where both sub-filters must be true.                                                                                                                                                                                                                              |  |  |
| OR              | Select this radio button to join two filters into a compound filter where either sub-filter is true.                                                                                                                                                                                                                                  |  |  |
| EQUAL           | Select this radio button to join two filters into a compound filter where the Boolean value of both sub-filters is identical.                                                                                                                                                                                                         |  |  |
| Insert Operator | Click this button to insert the selected Boolean operator into the <b>Filter</b> field at the current cursor position within that field.                                                                                                                                                                                              |  |  |
| Filters         |                                                                                                                                                                                                                                                                                                                                       |  |  |
| Name            | A combo box showing all choices of supported filter parameter names.<br>The value of this field affects the content of the <b>Description</b> areas, as<br>well as the possible values for the <b>Comparison</b> , and <b>Values</b> options. For<br>list of all available types of filters, see <b>Filter Properties</b> (page 264). |  |  |
| Description     | Provides a textual description of the current filter parameter selected in the <b>Name</b> field. This field may also provide hints or details on how the <b>Comparison</b> or <b>Values</b> fields may be populated.                                                                                                                 |  |  |
| Comparison      | Selects from the set of possible comparisons relevant to the selected filter parameter <b>Name</b> . The contents of this combo box change according to the current <b>Name</b> selection.                                                                                                                                            |  |  |
| Values          | Enter the desired value(s) to compare against. For some filter parameter <b>Name</b> values, the combo box may contain possible values. The contents of this combo box change according to the current <b>Name</b> selection.                                                                                                         |  |  |
| Insert Filter   | Click this button to insert the selected filter specification into the <b>Filter</b> field at the current cursor position within that field.                                                                                                                                                                                          |  |  |
| Finish          | Click this button to close the dialog, copying the current value of the <b>Filter</b> text field into the <b>Filters</b> field of the Search view.                                                                                                                                                                                    |  |  |
| Cancel          | Click this button to close the dialog without changing the current value of the <b>Filters</b> field of the Search view.                                                                                                                                                                                                              |  |  |

# Toolbars

There are three kinds of toolbars in the Workbench (page 6):

- **Main** sometimes called the Workbench toolbar, is displayed at the top of the Workbench window directly beneath the menu bar. The contents of this toolbar change based on the active perspective. Items in the toolbar might be enabled or disabled based on the state of either the active view (page 16) or editor (page 9). Sections of the main toolbar can be rearranged using the mouse.
- **View** individual view toolbars, which appear in the title bar of a view (page 16). Actions in a view toolbar apply only to the view in which they appear. Some view toolbars include a Menu button, shown as an inverted triangle, which contains additional actions for that view.
- **Trim** minimizing a view/editor tab stack also produces a toolbar in the trim at the outer edge of the workbench window (a Trim Stack). This bar contains an icon for each of the views in the stack and/or a single icon for each stack of editors. Clicking one of these icons results in the view/editor being displayed as an overlay onto the workbench window.

In all cases, when the cursor is positioned over a toolbar button, a tooltip describing its function appears.

# Preferences

The Preferences dialog sets user preferences. Click the desired page title to view its content and make changes.

The dialog pages may be searched using the filter function. To filter by matching the page title, simply type the name of the page being sought in the "type filter text" box, and the available pages are listed below the text box. The filter also searches on keywords such as "appearance" and "text".

The history controls, ( ) Previous and ( ) Next, allow navigation through previously viewed pages. To step back or forward several pages at a time, click the desired control button to see a drop-down list of the most recently viewed preference pages.

The Preferences dialog can be found from the main workbench menu by selecting **Window** → **Preferences...**.

| Preferences                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                 | - 0                     | ×                                |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|-------------------------|----------------------------------|
| type filter text                                                                                                                                                                                                                                                                                                                                                       | Tcl Console View                                                                                                | <,                      | <ul> <li>↓</li> <li>∞</li> </ul> |
| Configure DCC Connection<br>Configure JTAG Connection<br>Critical Path Diagram View<br>Floorplanner View Colors and Layers<br>Floorplanner View Optimizations<br>General<br>Help<br>I/O Designer<br>Multiprocess<br>Netlist Browser<br>NoC Performance<br>Placement Regions<br>Project Management<br>Register Browser<br>Tcl Console View<br>User Advanced Preferences | See also: 'Colors and Fonts'.  Show Tcl feedback in italics  Beep when long running Tcl commands (over 5 second | nds) have completed exe | ecution                          |
|                                                                                                                                                                                                                                                                                                                                                                        | R                                                                                                               | Restore Defaults        | Apply                            |
|                                                                                                                                                                                                                                                                                                                                                                        | Ар                                                                                                              | ply and Close Ca        | ancel                            |

Figure 100 • Preferences Dialog Example

## Configure DCC Connection Preference Page

The Configure DCC Connection Preference page configures the **Preferences** (page 191) for the Demo Command and Control (DCC) connection, as used with the **HW Demo** (page 60) view.

See also: Configuring the DCC Connection (page 357) and Running the HW Demo (page 401).

| O Preferences                 |                                                                                    |
|-------------------------------|------------------------------------------------------------------------------------|
| type filter text              | Configure DCC Connection $\Leftrightarrow \bullet \bullet \bullet \bullet \bullet$ |
| Configure DCC Connection      |                                                                                    |
| Configure JTAG Connection     | Port Name COM3                                                                     |
| Critical Path Diagram View    |                                                                                    |
| Floorplanner View Colors and  |                                                                                    |
| Floorplanner View Optimizat 👻 |                                                                                    |
| 4 III >                       | Restore Defaults Apply                                                             |
|                               |                                                                                    |
|                               | OK Cancel                                                                          |
|                               |                                                                                    |

Figure 101 · Configure DCC Connection Preference Page Example

### Table 103 · Configure DCC Connection Preference Page Options

| Option    | Description                                                                                                                                                                                      |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port Name | Enter the serial port name used for the DCC connection. For further information about determining which serial port should be used, please see <b>Configuring the DCC Connection</b> (page 357). |

### **Configure JTAG Connection Preference Page**

The Configure JTAG Connection preference page configures which Bitporter2 or FTDI FT2232H or FT4232H device is used to communicate via JTAG to the desired device under test (the test board). The page also specifies where the Achronix device is found in the JTAG scan chain, which might potentially contain multiple Achronix and non-Achronix devices.

#### 👍 Warning!

Bitporter2 JTAG pods and test boards can be damaged if connected improperly. Always be aware of ESD safety concerns. Before attempting to use a USB JTAG connection, with or without a Bitporter2 pod, please consult the *JTAG Configuration User Guide* (UG004) at https://www.achronix.com/documentation/jtag-configuration-user-guide-ug004.

Multiple views use these configuration preferences, including the **Download view** (page 43), the **Snapshot Debugger** view (page 141), the **Register Browser view** (page 131), and the **HW Demo view** (page 60). Specialized functionality for some IP configuration editors might also use these JTAG preferences. Some Tcl commands may also use these JTAG preferences by default, though these can always be overridden with Tcl command arguments/flags.

The section Configuring the JTAG Connection (page 359) explains the proper use of all fields of this page in detail.

| Configure JTAG Connection $\bigcirc \bullet \bullet \circ \bigcirc \bullet$ |   |  |  |
|-----------------------------------------------------------------------------|---|--|--|
| These preferences are used to configure JTAG connections used by ACE.       |   |  |  |
| JTAG Device ID (jtag_id)                                                    |   |  |  |
| JTAG Scan Chain                                                             | ] |  |  |
| IR Bits Before Target FPGA Device                                           | 0 |  |  |
| IR Bits After Target FPGA Device                                            | 0 |  |  |
| Target FPGA Device Offset in Scan Chain                                     | 0 |  |  |

### Figure 102 · Configure JTAG Connection Preference Page Example

| Table 104 | • Configure | JTAG Interface | Preference Page Options |
|-----------|-------------|----------------|-------------------------|
|-----------|-------------|----------------|-------------------------|

| Option                                                    | Description                                                                                                                                                                                                                                         |  |
|-----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                                           | The name of the JTAG device which should be used for all ACE JTAG interactions with the chosen FPGA or eFPGA. If the name is not specified, auto-detection of JTAG devices is attempted.                                                            |  |
| JTAG Programmer Device Name <sup>(1)</sup>                | <ul> <li>Performance Tip</li> <li>Even if only one JTAG device is connected, specifying the JTAG device by name (instead of relying upon auto-detection) can save up to several seconds of initialization time on every JTAG connection.</li> </ul> |  |
| JTAG Scan Chain                                           |                                                                                                                                                                                                                                                     |  |
| IR Bits Before the Target FPGA Device $^{(2)}$            | Sets the (decimal) number of instruction register bits between the board JTAG TDI pin and the target device.                                                                                                                                        |  |
| IR Bits After the Target FPGA Device $^{\left( 2 ight) }$ | Sets the (decimal) number of instruction register bits between the target device and the board JTAG TDO pin.                                                                                                                                        |  |
| Target FPGA Device Offset in Scan Chain $^{(2)}$          | Sets the device count (in decimal) between the board JTAG TDI pin and target FPGA device.                                                                                                                                                           |  |



### Multi-device JTAG Scan Chain (IEEE 1149.1) Example

The following high-level diagram summarizes how ACE must be configured for JTAG daisy-chains. For an explanation of daisy-chained JTAG scan chains, visit https://en.wikipedia.org/wiki/Jtag#Daisy-chained\_JTAG\_.28IEEE\_1149.1.29.



#### Figure 103 • Example High-Level Diagram of a Multi-device JTAG Scan Chain

When multiple FPGA devices are attached to the same JTAG scan chain, the target FPGA device must be specified. The FPGA device closest to the Bitporter2 (more accurately, closest to the board JTAG TDI pin) has a target offset of 0.

Because different FPGA devices have different instruction register (IR) sizes, the total IR bit length before and after the target must be specified as well. Achronix devices have a JTAG instruction register size of 23 bits. Hence, in the above example diagram, if all devices were Achronix FPGA devices, there would be 23 IR bits before the target FPGA device, (23 IR bits within the target FPGA device,) and 46 IR bits after the target FPGA device.

# Note For a more thorough explanation regarding ACE multi-device JTAG scan chain configurations, refer to Configuring the JTAG Connection (page 359).

# Critical Path Diagram View Preference Page

The Critical Path Diagram View Preference Page configures the display **Preferences** (page 191) for the **Critical Path Diagram** (page 34) view.

| Critical Path Diagram View 🛛 🗢 👻 💌                                        |  |  |  |
|---------------------------------------------------------------------------|--|--|--|
| These preferences are used to configure the<br>Critical Path Diagram View |  |  |  |
| Labels:                                                                   |  |  |  |
| Outline:                                                                  |  |  |  |
| Instances:                                                                |  |  |  |
| Selected Instances:                                                       |  |  |  |
| Nets:                                                                     |  |  |  |
| Selected Nets:                                                            |  |  |  |
| Restore <u>D</u> efaults <u>Apply</u>                                     |  |  |  |
| OK Cancel                                                                 |  |  |  |

Figure 104 • Critical Path Diagram View Preference Page Example

### Table 105 · Critical Path Diagram View Preference Page Options

| Option             | Description                                                                                                    |  |
|--------------------|----------------------------------------------------------------------------------------------------------------|--|
| Labels             | Configures the color of the label text printed for graph nodes and arrows in the diagram.                      |  |
| Outline            | Configures the color of the outline of the graph nodes in the diagram.                                         |  |
| Instances          | Configures the background color of graph nodes in the diagram.                                                 |  |
| Selected Instances | Configures the background color of graph nodes representing instances in the ACE Selection Set in the diagram. |  |
| Nets               | Configures the color of the arrows in the diagram.                                                             |  |

| Option           | Description                                                                                                                                                                                                                                                                                                                  |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Selected Nets    | Configures the color of arrows representing nets in the ACE Selection Set in the diagram.                                                                                                                                                                                                                                    |
| Restore Defaults | Returns all preferences on this page to their ACE default values.                                                                                                                                                                                                                                                            |
| Арріу            | Immediately applies any configuration changes on this page to the<br>current diagram in the <b>Critical Path Diagram view</b> (page 34). These config<br>values are also saved and are used in all future ACE sessions. The<br>Preferences dialog stays open to allow other preference configuration<br>changes, if desired. |
| ок               | Immediately applies any preference configuration changes (including on<br>other preference pages). These config values are also saved and are used<br>in all future ACE sessions.                                                                                                                                            |
| Cancel           | Discards any preference configuration changes made since the dialog was opened (or since the last time the <b>Apply</b> button was clicked in the dialog, whichever was most recent).                                                                                                                                        |

## Cross Probe Preference Page

The Cross Probe Preference Page configures the **Preferences** (page 191) for establishing a successful connection with the Synplify Pro GUI. See also: **Opening Synplify in ACE** (page 575).

| Preferences                                        |                                        | — 🗆 X                  |
|----------------------------------------------------|----------------------------------------|------------------------|
| type filter text                                   | Cross Probe                            |                        |
| Configure DCC Connect A<br>Configure JTAG Connect  | Identify your Synplify resources here. |                        |
| Critical Path Diagram Vie<br>Cross Probe           | ACE Project proj_3                     |                        |
| Floorplanner View Color<br>Floorplanner View Optin |                                        |                        |
| > General<br>Help                                  | Launch-to-talk delay (secs) 5          |                        |
| I/O Designer                                       |                                        | Restore Defaults Apply |
| < >                                                |                                        |                        |
|                                                    |                                        | Apply and Close Cancel |

Figure 105 • Cross Probe Preference Page Example

| Option                      | Description                                                                           |
|-----------------------------|---------------------------------------------------------------------------------------|
| Launch-to-talk delay (secs) | How long ACE should wait between launching Synplify Pro and attempting to talk to it. |

## Floorplanner View Colors and Layers Preference Page

The Floorplanner View Colors and Layer Preference page configures the colors of multiple layers (and states within the layers) for the Floorplanner view (page 45). Additionally, options are provided allowing a degree of control over the display priorities of the possible Instance states (page 262) and Net/Route highlighting vs. selection. For more about Highlighting, see Highlighting Objects in the Floorplanner View (page 342). For more about Selection, see the Selection view (page 137).

| type filter text                                                                                                                                                           | Floorplanner View C                                                                                             | olors and L                                         | ayers                          | ⇔▼⇔▼ :           |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|--------------------------------|------------------|
| Configure DCC Connection<br>Configure JTAG Connection<br>Critical Path Diagram View<br>Floorplanner View Colors and Layers<br>Floorplanner View Optimizations<br>> General | These preferences are us<br>View<br>See also: <sup>C</sup> <u>Colors and Fo</u><br>Grab focus on mouse          | nts'.                                               | re the presentation details in | the Floorplanner |
| Help<br>I/O Designer                                                                                                                                                       | Drag Scrolling                                                                                                  |                                                     |                                |                  |
| Multiprocess                                                                                                                                                               | Drag scroll margin size                                                                                         | 100                                                 |                                |                  |
| Netlist Browser                                                                                                                                                            | Drag scroll speed                                                                                               | 50                                                  |                                |                  |
| Tcl Console View<br>User Advanced Preferences                                                                                                                              | Show Overassignine<br>Show Fixed Color of<br>Show Locked Color of<br>Show Site Borders o<br>Always Show Highlig | Instances with<br>on Instances w<br>n Placed Instar | ith Locked Placement<br>nces   |                  |
|                                                                                                                                                                            | Nets/Routes                                                                                                     |                                                     |                                |                  |
|                                                                                                                                                                            | Route Rendering Mode                                                                                            | Actual                                              | Route                          | ~                |
|                                                                                                                                                                            | Always Show Highlig                                                                                             |                                                     |                                |                  |
|                                                                                                                                                                            | Show Selected Nets                                                                                              |                                                     | nlighted Nets                  |                  |
|                                                                                                                                                                            | Thickness of Highlighte                                                                                         | d Nets 1                                            | -                              |                  |
|                                                                                                                                                                            | Thickness of Selected N                                                                                         | ets 2                                               |                                |                  |
|                                                                                                                                                                            |                                                                                                                 |                                                     | Restore Defaults               | Apply            |
|                                                                                                                                                                            |                                                                                                                 |                                                     | Testore Berdales               | Арріу            |

#### Figure 106 • Floorplanner View Colors and Layers Dialog

The meanings of the various **Instance states** (page 262) are defined elsewhere. While Instances can have multiple states at once, they can only show a single state at a time, thus there is some ability to alter the display priority of the various Instance states.

Similarly, the display of the Floorplanner Nets/Routes layers can be adjusted. (Both clock and non-clock nets are affected identically by these settings.)

#### Table 107 · Instances and Nets/Routes Preferences

| Preference                                                                     | Description                                                                                                                                                                                                                                                           |
|--------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Instances                                                                      |                                                                                                                                                                                                                                                                       |
| Grab focus on mouse-over                                                       | If enabled, the Floorplanner view grabs focus whenever the cursor moves into the view.                                                                                                                                                                                |
| Drag scroll margin size                                                        | The size, in pixels, of the "drag scroll margins." Defines how close the cursor must get to an edge of the Floorplanner view to start drag scrolling.                                                                                                                 |
| Drag scroll speed                                                              | Defines How far, in pixels, the view moves on each drag scroll.                                                                                                                                                                                                       |
| Show Highlight Color of Instances on top of<br>Overassigned/Fixed/Locked Color | When enabled, the Instance Highlight color has a higher priority than all other Instance states except Selection.                                                                                                                                                     |
| Show Overassignment Color on Instances with<br>Site Overassignment Errors      | Allows toggling whether site over-assignment errors are displayed visually on the Floorplanner view.                                                                                                                                                                  |
| Show Fixed Color on Instances with Fixed<br>Placement                          | If disabled, both fixed placement and non-fixed placement instances are shown in the same color, grey by default.                                                                                                                                                     |
| Show Locked Color on Instances with Locked<br>Placement                        | If disabled, locked and non-locked instances are shown with the same color.                                                                                                                                                                                           |
| Show Site Borders on Placed Instances $^{(1)}$                                 | If enabled, all placed instances are rendered with the site<br>border color as an outline around the instance. If disabled,<br>placed instances are rendered without a site border.                                                                                   |
| Always Show Highlighted Instances                                              | If enabled, highlighted instances are always displayed, even if<br>their layer (Instances/Selected Instances) is otherwise<br>disabled. If disabled, highlighted instances are only displayed<br>when their layer ( <b>Instances/Selected Instances</b> ) is enabled. |
| Nets/Routes                                                                    |                                                                                                                                                                                                                                                                       |

| Preference                                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Route Rendering Mode                          | Allows altering how Non-clock Routes and Clock Routes are<br>drawn (when the Non-clock Routes or Clock Routes layers are<br>enabled, respectively, in the Floorplanner palette). Choices are<br>Actual Route and 1 Corner.<br>• Actual Route mode draws a single<br>straight line from wire sources to wire sinks for each route<br>segment.<br>• I Corner mode draws two lines for<br>each wire: from each wire source, draws a vertical line to<br>the wire sink Y coordinate, then a horizontal line to the<br>wire sink; no diagonal lines are used, which speeds<br>rendering in complex designs. |
| Always Show Highlighted Nets                  | If enabled, Highlighted nets are always displayed, even if their<br>layer (Clock Routes or Non-clock Routes) is otherwise disabled.<br>If disabled, Highlighted nets are only displayed when their layer<br>(Clock Routes or Non-clock Routes) is enabled.                                                                                                                                                                                                                                                                                                                                             |
| Always Show Selected Nets                     | If enabled, Selected nets are always displayed, even if their<br>layer (Clock Routes or Non-clock Routes) is otherwise disabled.<br>If disabled, Selected nets are only displayed when their layer<br>(Clock Routes or Non-clock Routes) is enabled.                                                                                                                                                                                                                                                                                                                                                   |
| Show Selected Nets on Top of Highlighted Nets | Allows changing whether the Selection or Highlight color takes priority, and is painted "on top" of the other state during rendering.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Thickness of Highlighted Nets                 | The highlight color of a net is rendered this many pixels wide.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Thickness of Selected Nets                    | The selection color of a net is rendered this many pixels wide.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

#### **Table Notes**

1. **Caution:** When **Show Site Borders on Placed Instances** is enabled while the view is extremely zoomed out, the site border render color might actually hide the placement state color. Thus, this preference is disabled by default.

### (i) Note

- The **1** Corner route drawing mode is significantly faster (up to 5×) than the **Actual Route** drawing mode, but it can make individual routes harder to differentiate from each other. When Floorplanner performance is a concern, use **1** Corner mode when possible, and only switch to **Actual Route** mode when needed.
- It is possible to show both the selection and highlight state of a single net simultaneously. Simply ensure the higher priority (top) state has a narrower thickness than the lower priority (bottom) state, and the bottom state color is rendered as a "halo" effect around the top state color.
- Having the "Always Show..." preferences enabled might be most useful in designs with massive numbers of nets/routes. Both the Clock and Non-clock route layers can be disabled, and then Select or Highlight the interesting routes, and only the Selected and/or Highlighted routes are displayed, without the distractions of the less-interesting routes cluttering up the view.

| Preferences      | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | o x       |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| type filter text | Colors and Fonts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ⇔ ▼ ⇔ ▼ ∦ |
|                  | Colors and Fonts         Colors and Fonts (font, size, type, ? = any character, * = any string) :         type filter text <ul> <li>@ Floorplanner View</li> <li>Background Color</li> <li># Floorplanner Font (set to default: Dialog Font)</li> <li># Flyines</li> <li>Instances, fixed placement</li> <li>Instances, placed</li> <li>Instances, placement error (set to default: Error color, default)</li> <li>Nets</li> <li>Routing Status - Open Pins (set to default: Warning color, default)</li> <li>Selected Disects</li> <li>Selected Instances</li> <li>Selected Pins</li> <li>Selected Sites</li> </ul> Description:   Preview: No preview available. |           |
|                  | Restore Defaults                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Арріу     |
|                  | Apply and Close                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Cancel    |

Figure 107 · Colors and Fonts | Floorplanner View section

### Table 108• Color Preferences

| Color Preference            | Description                                                                                                                                                                                                                                                                                  |
|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Background Color            | Used to render the background of the device.                                                                                                                                                                                                                                                 |
| Instances, placed           | Represents instances with default (Soft) placement.                                                                                                                                                                                                                                          |
| Instances, fixed placement  | Represents instances with Fixed placement.                                                                                                                                                                                                                                                   |
| Instances, locked placement | Represents instances with Locked placement.                                                                                                                                                                                                                                                  |
| Instances, placement error  | Represents an instance that shares a site assignment with another<br>instance. Since a site can only legally contain a single instance, this is<br>an error state.                                                                                                                           |
| Nets                        | Represents all net Routes for both clock and non-clock nets.                                                                                                                                                                                                                                 |
| Flylines                    | Flylines are only rendered for Selected Instances, and only when the Layer called <b>Selected Instance Flylines</b> is enabled. These are straight single-segment lines directly connecting a net source instance and sink instance, where either the source or sink is a Selected Instance. |
| Selected Instances          | Represents any Instance that is a member of the Selection Set (and is thus also visible in the <b>Selection View</b> (page 137)).                                                                                                                                                            |
| Selected Nets               | Represents any Net that is a member of the Selection Set (and is thus also visible in the Selection View).                                                                                                                                                                                   |
| Selected Pins               | Represents any Pin that is a member of the Selection Set (and is thus also visible in the Selection View).                                                                                                                                                                                   |
| Selected Paths              | Represents any Path that is a member of the Selection Set (and is thus also visible in the Selection View).                                                                                                                                                                                  |
| Selected Sites              | Represents any Site that is a member of the Selection Set (and is thus also visible in the Selection View).                                                                                                                                                                                  |
| Routing Status – Open Pins  | Represents Open Pins, the endpoints of Open Connections (which are<br>the unrouted portions of a net). Open Pin squares are only visible<br>when enabled in the Layers section of the Floorplanner view Palette.                                                                             |
| Routing Status – Overflows  | Represents Overflow pins, a rare routing error state. Overflow<br>diamonds on pins are only visible when enabled in the Layers section<br>of the Floorplanner view Palette.                                                                                                                  |

# Floorplanner View Optimizations Preference Page

The Floorplanner View Optimizations Preference page configures rendering optimizations for the **Floorplanner** view (page 45). The following Floorplanner View Optimizations page example includes default values for Windows:

| Floorplanner View Optimizations                                                                                                                                                                                                                                                                                           | ← ▼ ⇒ ▼                    |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|--|--|--|
| These preferences are used to configure the Floorplanner View's performance optimizations.<br>(Windows users should be especially careful when changing these options, since some<br>combinations can make the application appear non-responsive to the Windows OS, which can then<br>cause an infinite repainting loop.) |                            |  |  |  |
| The Floorplanner will choose different optimizations based upon the comple                                                                                                                                                                                                                                                | xity of the active design. |  |  |  |
| The complexity of a design is currently measured by the total number of rout                                                                                                                                                                                                                                              | ting segments.             |  |  |  |
| Optimization settings which may vary with design complexity                                                                                                                                                                                                                                                               |                            |  |  |  |
| High                                                                                                                                                                                                                                                                                                                      | Med Low                    |  |  |  |
| When panning, show only background layer:                                                                                                                                                                                                                                                                                 |                            |  |  |  |
| Enable incremental rendering:                                                                                                                                                                                                                                                                                             |                            |  |  |  |
| Show intermediate render stages:                                                                                                                                                                                                                                                                                          |                            |  |  |  |
| Render large areas as smaller tiled areas                                                                                                                                                                                                                                                                                 |                            |  |  |  |
| Max re-quartering recursion: 2                                                                                                                                                                                                                                                                                            | 2 1                        |  |  |  |
| Max unsegmented area: 100                                                                                                                                                                                                                                                                                                 | 400 800                    |  |  |  |
| Reduce overdraw with route preprocessing and caching:                                                                                                                                                                                                                                                                     |                            |  |  |  |
| Max zoom level to be preprocessed/cached: 5                                                                                                                                                                                                                                                                               | 5 5                        |  |  |  |
| Current Design's Complexity: N/A (Please activate a project/implementation)                                                                                                                                                                                                                                               | )                          |  |  |  |
| Settings used for all complexities                                                                                                                                                                                                                                                                                        |                            |  |  |  |
| Route segment count complexity cutoff, High/Med: 5000000                                                                                                                                                                                                                                                                  |                            |  |  |  |
| Route segment count complexity cutoff, Med/Low: 500000                                                                                                                                                                                                                                                                    |                            |  |  |  |
| Nets processed per incremental render work unit: 25000                                                                                                                                                                                                                                                                    |                            |  |  |  |
| Route segments processed per incremental render work unit: 50000                                                                                                                                                                                                                                                          |                            |  |  |  |
| Enable polyline rendering (Early Access): 📝                                                                                                                                                                                                                                                                               |                            |  |  |  |
| Enable temp collection route rendering:                                                                                                                                                                                                                                                                                   |                            |  |  |  |
| Force faster classic rendering APIs when possible:                                                                                                                                                                                                                                                                        |                            |  |  |  |
|                                                                                                                                                                                                                                                                                                                           |                            |  |  |  |
| Restore Def                                                                                                                                                                                                                                                                                                               | aults Apply                |  |  |  |

Figure 108 • Floorplanner View Optimizations Preference Page Example

Designs on modern FPGAs are continuing to increase in complexity. To maintain acceptable Floorplanner performance, highly complex designs require significant rendering optimizations. The set of preferences on this page allows advanced users, FAEs, and tech support to adjust the Floorplanner optimization settings in rare cases when it proves necessary.

ACE tracks three levels of design complexity (High, Med, and Low) and, by default, enables or disables individual optimization settings based upon the design complexity. Because drawing the routing has the most significant impact upon Floorplanner render performance, design complexity is measured in terms of the route segment count. The cutoffs between complexity levels are user configurable.

#### i Note

By default, all optimization features are disabled for the simplest designs. As design complexity increases, more optimizations are enabled by default. Some optimizations have overhead, and actually hinder render performance on small designs — for this reason, all optimizations are typically disabled for the simplest (Low complexity) designs.

The current (active) design Floorplanner complexity is always reported in this preference page as **Current Design's Complexity:** (near the middle of the page). This detail helps to determine which column of optimization settings impacts the rendering of the current design in the Floorplanner. Be aware that the route segment count used to compute the design complexity only includes route segments of routed nets. The same design often reports a Low complexity before it is routed, and a High complexity after routing is complete.

| Option                                       | Technical Description                                                                                                                                                                                                                                                                                                                                                                            | Usability Notes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Optimization settings which may vary wi      | Optimization settings which may vary with design complexity                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| When panning, show only background<br>layer: | Reduces the amount of rendering performed<br>while panning / scrolling; the detailed render<br>only occurs after panning / scrolling is<br>completed.                                                                                                                                                                                                                                            | Enable this if panning / scrolling the Floorplanner feels too slow.                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| Enable incremental rendering:                | The render work is broken up into small chunks<br>within each render layer and performed<br>asynchronously, instead of performing the entire<br>render of all layers at once. Because the work<br>chunks are performed asynchronously, the<br>application has a chance to respond to<br>subsequent mouse and keyboard input earlier,<br>instead of waiting for the entire render to<br>complete. | If enabled, each Floorplanner render is slightly<br>(5% to 10%) slower overall, but the Floorplanner<br>Perspective becomes significantly more<br>responsive to mouse and keyboard actions.<br>Obsolete renders might then be interrupted<br>(allowing faster renders when quickly changing<br>zoom levels with the mouse wheel, for example).<br>In some cases (for example, if a great deal of<br>Floorplanner panning/scrolling occurs), there<br>might be noticeable rendering latency/lag. |  |  |  |
| Show intermediate render stages:             | When renders are slow, it can be frustrating to<br>stare at an empty grey/black window waiting for<br>something to change. When this setting is<br>enabled, the user can observe as render layers<br>are built up into the final rendered image.                                                                                                                                                 | Provides more frequent visual feedback during<br>rendering, (so it can feel faster, because<br>something is visibly happening,) but renders are<br>actually slightly slower overall.                                                                                                                                                                                                                                                                                                            |  |  |  |

#### Table 109• Optimization Settings

| Option                                                            | Technical Description                                                                                                                                                                                                                                                                                                                                   | Usability Notes                                                                                                                                                                                                                                                                                                                                     |  |
|-------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Render large areas as smaller tiled<br>areas:                     | The total render area, if greater than the <b>Max</b><br><b>unsegmented area</b> , are broken into quadrants<br>which are rendered individually. Rendered areas<br>are checked for (re-)quartering up to <b>Max re-</b><br><b>quartering recursion</b> times. Because the<br>quadrant area is smaller, it completes rendering<br>faster than the whole. | Large render areas are each broken into four<br>smaller chunks for increased visual feedback.<br>Enabling this increases total render times, but it<br>might feel faster, because something is visibly<br>happening.                                                                                                                                |  |
| Max re-quartering recursion:                                      | The maximum number of times a render area<br>may be broken into smaller (and smaller) pieces.<br>Only relevant when <b>Render large areas as</b><br>smaller tiled areas is enabled.                                                                                                                                                                     | Relevant at the outermost zoom levels.<br>Increasing this value might increase total render<br>times, but can provide more frequent visual<br>feedback.                                                                                                                                                                                             |  |
| • Max unsegmented area:                                           | Areas larger than this are broken into smaller<br>chunks up to <b>Max re-quartering recursion</b><br>times.<br>Only relevant when <b>Render large areas as</b><br><b>smaller tiled areas</b> is enabled.                                                                                                                                                | Relevant at the outermost zoom levels.<br>Decreasing this can increase total render times,<br>but can provide more frequent visual feedback.                                                                                                                                                                                                        |  |
| Reduce overdraw with route preprocessing and caching:             | Significantly improves render speeds by reducing<br>route line overdraw via culling. Routing data is<br>pre-processed and cached at multiple zoom<br>levels when the routing data is loaded/updated.<br>Due to memory constraints, only the outermost<br>zoom levels may be cached.                                                                     | By pre-processing routes at multiple zoom levels<br>when the routes are loaded, we reduce the<br>number of route lines we draw over preexisting<br>routes lines of the same color. This slightly<br>increases the memory footprint and load times,<br>but significantly reduces render times for large<br>designs (when overdraw is most frequent). |  |
| <ul> <li>Max zoom level to be<br/>preprocessed/cached:</li> </ul> | 0=zoomed all the way out, 1=zoomed in one step, etc.                                                                                                                                                                                                                                                                                                    | This number must be kept small to avoid running<br>out of memory. (Floorplanner route render cache<br>sizes can more than double at each increasing<br>zoom level.)                                                                                                                                                                                 |  |
| Settings used for all complexities                                |                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                     |  |
| Route segment count complexity<br>cutoff, High/Med:               | Designs with a route segment count greater than<br>this number use the optimization settings for<br>High complexity designs (the first column of<br>checkboxes/fields).                                                                                                                                                                                 | _                                                                                                                                                                                                                                                                                                                                                   |  |
| Route segment count complexity<br>cutoff, Med/Low:                | Designs with a route segment count less than (or<br>equal to) this number use the optimization<br>settings for Low complexity designs (the third<br>column of checkboxes/fields).                                                                                                                                                                       | _                                                                                                                                                                                                                                                                                                                                                   |  |
| Nets processed per incremental render<br>work unit:               | The number of nets to process per discrete work<br>unit when rendering the routing layers. Used<br>when the current zoom is NOT in the route<br>overdraw reduction cache.<br>Only relevant when <b>Enable incremental</b><br><b>rendering</b> is on.                                                                                                    | Increasing this number might very slightly<br>improve rendering performance, but decrease<br>the frequency of visual feedback.                                                                                                                                                                                                                      |  |

| Option                                                        | Technical Description                                                                                                                                                                                                                                                                                                                         | Usability Notes                                                                                                                                                                                                                                              |
|---------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Route segments processed per<br>incremental render work unit: | The number of route segments to process per<br>discrete work unit when rendering cached route<br>segments. Used when the current zoom is in the<br>route overdraw reduction cache.<br>Only relevant when both <b>Enable incremental</b><br><b>rendering</b> and <b>Reduce overdraw with route</b><br><b>preprocessing and caching</b> are on. | Increasing this number might very slightly<br>improve rendering performance, but decrease<br>the frequency of visual feedback.                                                                                                                               |
| Enable polyline rendering<br>(Early Access) <sup>(1)</sup>    | _                                                                                                                                                                                                                                                                                                                                             | Polyline rendering of the routes is a known major<br>Floorplanner performance advantage in<br>Windows, but only minor advantages were seen<br>in tested Linux configurations. The advantages<br>are most noticeable in the largest designs.                  |
| Enable temp collection<br>route rendering: <sup>(2)</sup>     | _                                                                                                                                                                                                                                                                                                                                             | Might slow rendering when using route overdraw reduction cache, but other route rendering might speed up slightly.                                                                                                                                           |
| Force faster classic rendering APIs<br>when possible:         | -                                                                                                                                                                                                                                                                                                                                             | The classic rendering APIs are significantly faster<br>in all tested cases, but might produce slightly<br>cruder visual output due to a lack of anti-aliasing<br>(The modern/advanced render APIs are still<br>automatically used when absolutely required.) |

#### **Table Notes**

1. **Caution: Enable polyline rendering** is new, Early Access functionality. While Achronix found no negative stability or performance impacts when testing this optimization, customer hardware and software have a wider variety of configurations than in our test labs. If any new performance or stability issues are observed in the GUI, please contact Achronix Technical Support. Achronix notes the specifics of your configuration (to reproduce and correct the problem), and might then suggest disabling this new polyline rendering functionality to determine if performance or stability improves.

2. Caution: Enable temp collection route rendering requires significantly more ACE GUI memory when enabled!

#### (i) Note

#### **Technical Note for Windows Users**

The Windows operating system requires that applications check-in every five seconds, or the application is deemed non-responsive. Non-responsive applications are given a figurative kick-in-the-pants by Windows, and asked to repaint the screen. When the screen paint itself is taking more than five seconds, as might happen with poor Floorplanner Optimization settings, an application can be forced into an effective infinite-loop of paint requests from the operating system.

If a Windows user ever notices ACE being called non-responsive by Windows (check the application title bar), ACE has most likely entered this looped painting state. To escape, change back to the Project perspective (or any other perspective without the Floorplanner view visible), then on this Floorplanner View Optimizations Preference page, ensure that incremental rendering and tiled rendering are both enabled for the current design complexity level. If both are already enabled, please call Achronix Technical Support for guidance on further Floorplanner optimization adjustments.

#### A Warning!

Disabling optimizations that are enabled by default is not recommended.

## I/O Designer Preference Page

The I/O Designer Preference page contains a number of preferences for the I/O Designer views.

| Preferences                                                                                                                                                                                                                                                    |                                                                                                                                                                      |                          |                    |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|--------------------|
| type filter text                                                                                                                                                                                                                                               | I/O Designer                                                                                                                                                         |                          | <b>⟨→ ・</b> ⊲⟩ • 《 |
| Configure DCC Connection<br>Configure JTAG Connection<br>Critical Path Diagram View<br>Floorplanner View Colors an<br>Floorplanner View Optimiza<br>General<br>Help<br>I/O Designer<br>Multiprocess<br>Netlist Browser<br>NoC Performance<br>Placement Regions | Configurable options for the I/O Designer vi<br>Layout Diagram Font: Segoe UI-reg<br>Valid Placement Color<br>Invalid Placement Color<br>Highlighted Placement Color | abcABC C                 | <u>C</u> hange     |
| Project Management<br>Register Browser<br>Tcl Console View                                                                                                                                                                                                     | External file poll interval (secs) 5                                                                                                                                 |                          |                    |
| User Advanced Preferences                                                                                                                                                                                                                                      |                                                                                                                                                                      |                          |                    |
|                                                                                                                                                                                                                                                                |                                                                                                                                                                      | Restore <u>D</u> efaults | <u>A</u> pply      |
|                                                                                                                                                                                                                                                                | Α                                                                                                                                                                    | Apply and Close          | Cancel             |

### Figure 109 • I/O Designer Preference Page Example

### Table 110 • I/O Designer Preferences Options

| Option                | Description                                        |  |
|-----------------------|----------------------------------------------------|--|
| Layout Diagram Font   | The font used on shapes in the I/O Layout diagram. |  |
| Valid Placement Color | The color used for sites with valid placements.    |  |

| Option                             | Description                                                            |  |
|------------------------------------|------------------------------------------------------------------------|--|
| Invalid Placement Color            | The color used for sites with invalid placements.                      |  |
| Highlighted Placement Color        | The color used to highlight the currently selected site.               |  |
| Show active editor highlight       | Toggles whether the currently selected site is drawn with a highlight. |  |
| External file poll interval (secs) | Specifies how often IP files are checked for external modification.    |  |

# IP Diagram Color and Font Preferences Section

While there is no longer a single preference page dedicated only to IP Diagram Preferences, there are still a number of color and font preferences related to the IP Diagram view (page 71) which are available for user manipulation, now located under **General**  $\rightarrow$  **Appearance**  $\rightarrow$  **Colors and Fonts** in the preference tree under the **IP Diagram View** branch.

| Preferences                                                                                                                                                                                                         |                                                                                                                    |   |                                                                   |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|---|-------------------------------------------------------------------|
| type filter text                                                                                                                                                                                                    | Colors and Fonts                                                                                                   |   | ⟨⊐ ▼ ⊲⟩ ▼ ∞                                                       |
| Configure DCC Conne<br>Configure JTAG Conni<br>Critical Path Diagram<br>Floorplanner View Co<br>Floorplanner View Oy<br>General<br>Appearance<br>Colors and Fon<br>Editors<br>Link Handlers<br>Quick Search<br>Help | Colors and Fonts Colors and Eonts (font, size, type, ? = any character, * = any string) :  type filter text        | ^ | Edit<br>Use System Font<br>Reset<br>Edit Default<br>Go to Default |
| Heip<br>I/O Designer<br>Multiprocess<br>Netlist Browser<br>NoC Performance<br>Placement Regions<br>Project Management<br>Tcl Console View<br>User Advanced Prefer                                                   | Foreground color, wanning (set to default: Foreground color, diagram, default)     Foreground color, wrapper     A | ~ | Expand All                                                        |
| < >                                                                                                                                                                                                                 | Restore Defau<br>Apply and Clos                                                                                    | _ | Apply<br>Cancel                                                   |

Figure 110  $\,\cdot$  IP Diagram Preferences Found on the Colors and Fonts Page

| Table 111 | • IP Diagram | <b>Color and Font</b> | Preference Options |
|-----------|--------------|-----------------------|--------------------|
|-----------|--------------|-----------------------|--------------------|

| Option                         | Description                                                                                                                     |
|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| Background Color               | The default background color for the entire diagram.                                                                            |
| Background Color, errors       | Text representing IP Options with errors have their backgrounds painted this color.                                             |
| Background Color, warnings     | Text representing IP Options with warnings have their backgrounds painted this color.                                           |
| Foreground Color               | The color used for enabled logic blocks and signals (and their textual labels).                                                 |
| Foreground Color when disabled | The color used for disabled logic blocks and signals (and their textual labels).                                                |
| Foreground Color, alternate    | The color used to highlight portions of the diagram.                                                                            |
| Foreground Color, errors       | Text representing IP Options with errors have their foregrounds painted this color.                                             |
| Foreground Color, warnings     | Text representing IP Options with warnings have their foregrounds painted this color.                                           |
| Foreground Color, wrapper      | For core IP, the color used to represent the IP RTL wrapper itself.<br>Everything enclosed by this color is within the wrapper. |
| IP Diagram Font, normal        | The font used for all diagram text except the logic block titles.                                                               |
| IP Diagram Font, title         | The font used to title logic blocks in the diagram.                                                                             |

# Multiprocess: Configure Custom Job Submission Tool Preference Page

The Multiprocess: Configure Custom Job Submission Tool Preference Page allows configuring the ACE **Multiprocess View** (page 75) to submit Multiprocess jobs to a third-party cloud/grid/job submission system using a command-line tool. As a useful example, by default, ACE is configured to use an Oracle Grid Engine derivative via the qsub command (see https://en.wikipedia.org/wiki/Oracle\_Grid\_Engine). Be aware that the Oracle Grid Engine qsub arguments are not 100% compatible with the qsub standard (documented at http://pubs.opengroup.org/ onlinepubs/9699919799/utilities/qsub.html).

| Configurable<br>ubmission s                         |                                                                                     | cess View b | ehavior when using                                                                        | third-party job |
|-----------------------------------------------------|-------------------------------------------------------------------------------------|-------------|-------------------------------------------------------------------------------------------|-----------------|
|                                                     | on Executable (requi                                                                |             |                                                                                           | Browse          |
| ob Submissi                                         | on Executable (requi                                                                | rea):       | lsnp                                                                                      | Browse          |
| Vorking Dire                                        | ctory Argument (opt                                                                 | ional):     | wd                                                                                        |                 |
| ob Name Ar                                          | gument (optional):                                                                  | -           | N                                                                                         |                 |
| ob Submissi                                         | on Log Argument (o                                                                  | ptional):   | 0                                                                                         |                 |
| All other job                                       | submission commar                                                                   | dline optio | ns:                                                                                       |                 |
| Argument                                            | Value (optional)                                                                    |             |                                                                                           | New             |
| -sync                                               | y                                                                                   |             |                                                                                           |                 |
| -j                                                  | y                                                                                   |             |                                                                                           | Edit            |
| -b                                                  | у                                                                                   |             |                                                                                           | Remove          |
| -q                                                  | **@@linux64                                                                         |             |                                                                                           |                 |
| -v                                                  | RLM_LICENSE                                                                         |             |                                                                                           | Up              |
| -1                                                  | mem_free=8G                                                                         |             |                                                                                           | Down            |
| <jobname><br/>mem_free=8<br/>D:\output\20</jobname> | nplWorkingDir> -o -<br>-sync y -j y -b y -q *<br>G,h_vmem=12G<br>13\win5_main_64\sy | *@@linux64  | 0UobSubmissionLog3<br>- v RLM_LICENSE -I<br>4\acx.exe -b -script_<br>lePath> -print_progr | file            |
| Allowed seco                                        | nds of NFS write late                                                               | ency:       | Restore Defaults                                                                          | Apply           |
|                                                     |                                                                                     |             |                                                                                           |                 |

## Figure 111 • Multiprocess: Configure Custom Job Submission Tool Preference Page Example

When the third-party job submission system support is enabled, ACE calls the specified executable, using the specified command-line arguments, to submit ACE Multiprocess jobs.

See Configuring ACE to use an External Job Submission System (page 310) for more information.

#### A Warning!

#### Debugging job submission configurations:

- If the job submission system is properly configured on the host machine (meaning it is possible to successfully submit non-ACE jobs from the command-line) and ACE is still unable to successfully submit jobs, please contact Achronix technical support.
- **DO NOT** copy the text of the attempted command and manually attempt to submit from the command-line.

# Netlist Browser Preference Page

The Netlist Browser preference page contains a number of preferences for the Netlist Browser view.

| Preferences                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                    |              | ×           |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|--------------|-------------|
| type filter text                                                                                                                                                                                                                                                                                                                                          | Netlist Browser                                                                                                                    | ⇒ - ב        | <b>→</b> 00 |
| Configure DCC Connection<br>Configure JTAG Connection<br>Critical Path Diagram View<br>Floorplanner View Colors an<br>Floorplanner View Optimiza<br>General<br>Help<br>I/O Designer<br>Multiprocess<br>Netlist Browser<br>NoC Performance<br>Placement Regions<br>Project Management<br>Register Browser<br>Tcl Console View<br>User Advanced Preferences | <ul> <li>Double-clicks update the Properties view</li> <li>Warn before applying context-menu actions to large selection</li> </ul> | 15           |             |
|                                                                                                                                                                                                                                                                                                                                                           | Restore <u>D</u> efaults                                                                                                           | <u>A</u> ppl | у           |
|                                                                                                                                                                                                                                                                                                                                                           | Apply and Close                                                                                                                    | Cancel       |             |

Figure 112 • Netlist Browser Preference Page Example

### Table 112 · Netlist Browser Preferences Options

| Option                                                        | Description                                                                                                                                                                     |
|---------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Double-clicks update the Properties view                      | Toggles whether double-clicking an item in the Netlist browser view shows that item in the Properties view.                                                                     |
| Warn before applying context-menu actions to large selections | Applying actions to very large selections can take a very long time. Toggling this option causes a warning message to appear before an action is run against a large selection. |

# NoC Performance View Preference Page

The NoC Performance view preference page offers preferences related to the 2D NoC Performance view.

| Preferences                                                                                                                                                                                                                                                        |                                        | —                |                 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|------------------|-----------------|
| type filter text                                                                                                                                                                                                                                                   | NoC Performance                        |                  | <b>⟨→ -</b> → 8 |
| Configure DCC Connection<br>Configure JTAG Connection<br>Critical Path Diagram View                                                                                                                                                                                | See also: ' <u>Colors and Fonts</u> '. |                  |                 |
| Floorplanner View Colors an<br>Floorplanner View Optimiza<br>General<br>Help<br>I/O Designer<br>Multiprocess<br>Netlist Browser<br>NoC Performance<br>Placement Regions<br>Project Management<br>Register Browser<br>Tcl Console View<br>User Advanced Preferences | Log File Browse Path                   |                  | Change          |
|                                                                                                                                                                                                                                                                    |                                        | Restore Defaults | Apply           |
|                                                                                                                                                                                                                                                                    |                                        | Apply and Close  | Cancel          |

## Figure 113 • NoC Performance View Preference Page

#### Table 113 · NoC Performance View Preferences

| Preference           | Description                                                                                                                                                                                   |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Log File Browse Path | By default, browsing for simulation log files starts in whatever directory<br>was last browsed. Setting the log file directory path causes browsing to<br>always start at the specified path. |
|                      |                                                                                                                                                                                               |

| Preterences                                                                                                                                                                                                                                                                                                |                                                                                                                              |           |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|-----------|
| type filter text                                                                                                                                                                                                                                                                                           | Colors and Fonts                                                                                                             | ← - ⇒ * 8 |
| type filter text<br>Configure DCC Connection<br>Configure JTAG Connection<br>Critical Path Diagram View<br>Floorplanner View Colors an<br>Floorplanner View Optimiza<br>General<br>Colors and Fonts<br>Editors<br>Link Handlers<br>Quick Search<br>Help<br>I/O Designer<br>Multiprocess<br>Netlist Browser | Colors and Fonts Colors and Fonts (font, size, type, ? = any character, * = any string type filter text                      |           |
| Netlist Browser<br>NoC Performance<br>Placement Regions<br>Project Management<br>Id Console View<br>User Advanced Preferences                                                                                                                                                                              | Throughput:3: Low Time Slice View: Notes Time Slice View: Stats Description: Preview: No preview available. Restore Defaults | Apply     |
|                                                                                                                                                                                                                                                                                                            | Apply and Close                                                                                                              | Cancel    |

Figure 114 • Colors and Fonts | NoC Performance View Section

### Table 114 · Color Preferences

| Color Preference             | Description                                                                    |
|------------------------------|--------------------------------------------------------------------------------|
| Blockage:1:Low               | Selects the color to render shapes with "low" blockage.                        |
| Blockage:2:Medium            | Selects the color to render shapes with "medium" blockage.                     |
| Blockage:3:High              | Selects the color to render shapes with "high" blockage.                       |
| Data Flow Arrows             | Selects the color to render "data flow direction" arrows.                      |
| Filtered Control Background  | Color for the background of "filtered" controls in the NoC<br>Performance view |
| Filtered Control Foreground  | Color for the foreground of "filtered" controls in the NoC<br>Performance view |
| NoC Performance Diagram font | Selects the font used to label diagram shapes.                                 |
| Noc Time Slice view font     | Selects the font used to render text in the NoC Time Slice view                |
| Throughput:1:High            | Selects the color to render shapes with "high" throughput.                     |
| Throughput:2:Medium          | Selects the color to render shapes with "medium" throughput.                   |
| Throughput:3:Low             | Selects the color to render shapes with "low" throughput.                      |
| Time Slice view: Notes       | Selects the color to render "notes" in the Time Slice view.                    |
| Time Slice view: Stats       | Selects the color to render "stats" in the Time Slice view.                    |

# Other Colors and Fonts Preference Page

The Other Colors and Fonts Preference Page allows setting many of the fonts, colors and components used by ACE. The page is accessed by selecting **General**  $\rightarrow$  **Appearance**  $\rightarrow$  **Other Colors and Fonts**.

| Other Colors and Fonts                                                                                                                                                                                                                                                                              |                          | <b>⇔</b> • ⇔ •                                        |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-------------------------------------------------------|
| Colors and <u>Fonts</u> (? = any character, * = any string):                                                                                                                                                                                                                                        |                          |                                                       |
| type filter text                                                                                                                                                                                                                                                                                    |                          |                                                       |
| <ul> <li>Basic</li> <li>Active hyperlink text color</li> <li>Aa Banner Font</li> <li>Content Assist background color</li> <li>Content Assist foreground color</li> <li>Counter color</li> <li>Decoration color</li> <li>Aa Dialog Font</li> <li>Error text color</li> <li>Aa Header Font</li> </ul> |                          | Edit Use System Font Reset Edit Default Go to Default |
| Description:                                                                                                                                                                                                                                                                                        | *                        |                                                       |
| The dialog font is the font for widgets in dialogs.<br>Previe <u>w</u> :                                                                                                                                                                                                                            |                          |                                                       |
| Segoe UI 8<br>The quick brown fox jumps over the lazy dog.                                                                                                                                                                                                                                          |                          |                                                       |
|                                                                                                                                                                                                                                                                                                     | Restore <u>D</u> efaults | Apply                                                 |
|                                                                                                                                                                                                                                                                                                     | ОК                       | Cancel                                                |

Figure 115 • Other Colors and Fonts Preference Page Example

A tree is used to navigate among and show a short preview of the various colors and fonts. The current face (but not size) of any font is previewed in its label. Colors are previewed in the icon associated with its label. Additionally, some categories (Workbench in particular) provide a more detailed preview of their contributions (shown below the description area, if available).

- Font settings can be changed either by selecting the font from the list and clicking **Use System Font** to use the operating system font, or by clicking **Edit** to open up a font selection dialog. **Reset** can be used to return to the default value.
- Color settings can be changed by clicking **Edit** to the right of the tree area when a color is selected. **Reset** can be used to return to the default value.
- The **Colors and Fonts** text field can be used to filter the contents. Simply type in an entry and any matching results remain in the tree view.
- The **Description:** and **Preview:** sections provide details when the Workbench colors and font settings are selected.

# Placement Regions Preference Page

The Placement Regions Preference Page determines how Placement Regions (page 394) are handled in the Placement Regions view (page 114) and the Floorplanner view (page 45) (when the Floorplanner Placement Region Tool is active).

| Placement Regions 🛛 😓 👻 💌                                                                                                         |  |
|-----------------------------------------------------------------------------------------------------------------------------------|--|
| <ul> <li>Placement Region Boundary Alignment</li> <li>Snap to Clock Region Boundaries</li> <li>Snap to Tile Boundaries</li> </ul> |  |
| Drag and Drop Actions<br>Add only flops to the constraint<br>Include constants in the constraint                                  |  |
| Restore Defaults Apply                                                                                                            |  |
| OK Cancel                                                                                                                         |  |

Figure 116 • Placement Regions Preference Page Example

### Table 115 Placement Region Preferences

| Option                              | Description                                                                                                                                                                                                                                                           |  |
|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Placement Region Boundary Alignment |                                                                                                                                                                                                                                                                       |  |
| Snap to Clock Region Boundaries     | When creating, resizing, or moving Placement Regions, the Placement<br>Region boundaries are forced to align with Clock Region Boundaries.<br>Use this for a simple, coarse-grained approach to Placement Regions.<br>This setting is recommended for most use cases. |  |
| Snap to Tile Boundaries             | When creating, resizing, or moving Placement Regions, the Placement<br>Region boundaries are forced to align with Tile Boundaries, for a very<br>fine-grained region. This setting is only recommended for advanced<br>users.                                         |  |
| Drag and Drop Actions               |                                                                                                                                                                                                                                                                       |  |

| Option                                       | Description                                                                                                                                                                                             |
|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Add only flops to the constraint             | When using drag-and-drop to assign Placement Region Constraints,<br>this setting ensures only flops are assigned to the region constraint.<br>All other dropped items are excluded from the constraint. |
| Include constants in the constraint $^{(1)}$ | When using drag-and-drop to assign Placement Region Constraints, this setting includes constants in the constraint.                                                                                     |
| Table Notes                                  |                                                                                                                                                                                                         |

1. The Include constants in the constraint setting is ignored if Add only flops to the constraint is enabled.

# Project Management Preference Page

The Project Management Preference Page sets the behavior of Editors (page 9) and Reports (page 244).

| Preferences                                                                        |                                                                       | - 🗆 X                                |
|------------------------------------------------------------------------------------|-----------------------------------------------------------------------|--------------------------------------|
| type filter text                                                                   | Project Management                                                    | <p *="" -="" 8<="" th="" ⇒=""></p>   |
| Configure DCC Connection<br>Configure JTAG Connection                              | See ' <u>Colors and Fonts</u> ' to configure the font.                |                                      |
| Critical Path Diagram View<br>Floorplanner View Colors an                          | Close editors on active Implementation change                         | Always ~                             |
| Floorplanner View Optimiza <sup>.</sup><br>> General                               | Open Multiprocess summary on active Project change                    | Always ~                             |
| Help                                                                               | Open reports on active Implementation change                          | Always ~                             |
| I/O Designer<br>Multiprocess                                                       | Only open most-recent report of a given type                          | Always ~                             |
| Netlist Browser<br>NoC Performance                                                 | Save changed editors from the active project before running the flow  | Ask in a pop-up message $\checkmark$ |
| Placement Regions<br>Project Management<br>Tcl Console View                        | Flow State Persistence Mode                                           | Project ~                            |
| Ici Console View<br>User Advanced Preferences                                      | ☐ 'Reload Project' overwrites unsaved local project changes automatic | cally                                |
|                                                                                    | ☑ Enable background checking for project source file changes during   | the flow                             |
| ${oxed V}$ Hide the pop-up dialog when project source files change during the flow |                                                                       | e flow                               |
|                                                                                    | Project source file change background checking frequency (seconds)    | 3                                    |
|                                                                                    | Group reports by type                                                 |                                      |
|                                                                                    | ☑ Only show ACE HTML reports                                          |                                      |
|                                                                                    | $\ensuremath{\boxdot}$ Only show the most recent report               |                                      |
| < >>                                                                               | Rest                                                                  | ore Defaults Apply                   |
|                                                                                    | Apply                                                                 | and Close Cancel                     |

Figure 117 • Project Management Preference Page Example

| Option                                                                     | Description                                                                                                                                                |
|----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| See also:                                                                  | Link to Colors and Fonts preferences allowing choice of the font used in the Projects view.                                                                |
| Close editors on active implementation change                              | Can be used to automatically close open editors when the active implementation changes.                                                                    |
| Open Multiprocess summary on active project change                         | Can be used to automatically open the Multiprocess summary report when the active project changes.                                                         |
| Open reports on active implementation change                               | Can be used to automatically open implementation-specific reports when the active implementation changes.                                                  |
| Only open most-recent report of a given type                               | Can be used to automatically open only the most-recent report of a given type.                                                                             |
| Save changed editors from the active project before running the flow       | Can be used to automatically save all open editors before running the flow.                                                                                |
| Flow State Persistence Mode                                                | Choose whether or not the enabled/disabled flow step state<br>is persisted across ACE sessions per Session, per Project, or<br>is Disabled (not persisted) |
| Reload Project overwrites unsaved local project changes automatically      | Can be used to automatically overwrite unsaved local project<br>changes when Reload Project is used (without a confirmation<br>prompt).                    |
| Enable background checking for project source file changes during the flow | If enabled, project source files are periodically polled in the background to look for any changes made outside of ACE.                                    |
| Hide the pop-up dialog when project source files change during the flow    | If enabled, source file change notification is suppressed until the flow has finished running.                                                             |
| Project source file change background checking frequency (seconds)         | Determines how often to poll for background source file changes.                                                                                           |
| Group reports by type                                                      | If enabled, reports are grouped into subfolders in the Projects view tree.                                                                                 |
| Only show HTML reports                                                     | If enabled, only HTML reports are shown in the Projects view tree.                                                                                         |
| Only show the most recent report                                           | If enabled, only the most recent report is shown in any subfolder in the Projects view tree.                                                               |

# Tcl Console View Preference Page

The Tcl Console View Preference Page contains settings that alter the behavior and/or presentation of information in the Tcl Console View (page 146).

| Preferences                                                                                                                                                                                                                                                                                                                                          |                                        |               |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|---------------|
| type filter text                                                                                                                                                                                                                                                                                                                                     | Tcl Console View                       | ← ▼ ⇒ ▼ §     |
| Configure DCC Connection<br>Configure JTAG Connection<br>Critical Path Diagram View<br>Floorplanner View Colors and Layers<br>Floorplanner View Optimizations<br>> General<br>Help<br>I/O Designer<br>Multiprocess<br>Netlist Browser<br>NoC Performance<br>Placement Regions<br>Project Management<br>Tcl Console View<br>User Advanced Preferences | See also: ' <u>Colors and Fonts</u> '. |               |
|                                                                                                                                                                                                                                                                                                                                                      | Restore <u>D</u> efaults               | <u>A</u> pply |
|                                                                                                                                                                                                                                                                                                                                                      | Apply and Close                        | Cancel        |

## Figure 118 • Tcl Console View Preference Page Example345px345px640

#### Table 117 • Tcl Console View Preferences

| Option                       | Description                                                                               |
|------------------------------|-------------------------------------------------------------------------------------------|
| See also: 'Colors and Fonts' | Link to Colors and Fonts Preferences allowing choice of the font used in the Tcl Console. |

| Option                                                                           | Description                                                                                                                                |
|----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Beep when long running Tcl commands<br>(over 5 seconds) have completed execution | Enabling this option provides audible feedback (the default system beep/bell sound) upon completion of long-running commands.              |
| Show Console when an error is logged                                             | When enabled, any time an error is logged, the Tcl Console will be shown, even if it was minimized, or beneath another view in a tab stack |
| Toggle info messages                                                             | Toggles the visibility of info messages in the Tcl Console's readout area                                                                  |
| Toggle warning messages                                                          | Toggles the visibility of warning messages in the Tcl Console's readout area                                                               |
| Tcl Console back buffer size                                                     | Defines the maximum number of lines shown in the Tcl Console's readout area. Lowering this value will decrease memory usage.               |

# Text Editors Preference Page

The Text Editors Preference Page sets the behavior and appearance of the text editor.

| Text Editors                                                                       | ⇔ • ⇔ • •                          |  |  |
|------------------------------------------------------------------------------------|------------------------------------|--|--|
| See <u>'Colors and Fonts'</u> to configure the font.                               |                                    |  |  |
| Undo history size:                                                                 | 200                                |  |  |
| Displayed tab width:                                                               | 4                                  |  |  |
| 📝 Insert spaces for tabs                                                           |                                    |  |  |
| Highlight current line                                                             |                                    |  |  |
| Show print margin                                                                  |                                    |  |  |
| Print margin column:                                                               | 80                                 |  |  |
| Show line numbers                                                                  |                                    |  |  |
| Show range indicator                                                               |                                    |  |  |
| Show whitespace characters (                                                       | (configure visibility)             |  |  |
| Show affordance in hover on                                                        | how to make it sticky              |  |  |
| When mouse moved into hover:                                                       | Enrich after delay 🔹               |  |  |
| Enable drag and drop of text                                                       |                                    |  |  |
| 🔽 Warn before editing a derived                                                    | Warn before editing a derived file |  |  |
| Smart caret positioning at line                                                    | e start and end                    |  |  |
| Appearance color options:                                                          |                                    |  |  |
| Line number foreground                                                             | Color:                             |  |  |
| Current line highlight<br>Print margin                                             |                                    |  |  |
| Find scope<br>Selection foreground color                                           |                                    |  |  |
| Selection background color                                                         |                                    |  |  |
| Background color<br>Foreground color                                               |                                    |  |  |
| Hyperlink                                                                          |                                    |  |  |
|                                                                                    |                                    |  |  |
| More colors can be configured on the <u>'Colors and Fonts'</u><br>preference page. |                                    |  |  |
| Restore De                                                                         | faults Apply                       |  |  |
| ОК                                                                                 | Cancel                             |  |  |

Figure 119 • Text Editors Preference Page Example

## Table 118 Text Editor Options

| Option                                         | Default            | Description                                                                                                            |
|------------------------------------------------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| Undo history size                              | 200                | Sets the number of undo events in the history queue.                                                                   |
| Display tab width                              | 4                  | Sets the editor tab width in spaces.                                                                                   |
| Insert spaces for tabs                         | Deselected         | Enables insertion of spaces in place of tab characters.                                                                |
| Highlighting current line                      | Selected           | Enables/disables the highlighting of the current line. The highlight color is set in <b>Appearance color options</b> . |
| Show print margin                              | Deselected         | Selects whether the print margin is visible.                                                                           |
| Print margin column                            | 80                 | Sets the print margin column position.                                                                                 |
| Show line numbers                              | Selected           | Enables/disables the display of line numbers in the Editor view.                                                       |
| Show range indicator                           | Selected           | Enables the display of range indicators in the text editor.                                                            |
| Show whitespace characters                     | Deselected         | Enables the display of whitespace characters<br>(·) in text editors.                                                   |
| Show affordance in hover on how to make sticky | Selected           | Enable the affordance (visual clue) in the hover text and make it sticky.                                              |
| When mouse moved into hover                    | Enrich after delay | Sets the hover display mode.                                                                                           |
| Enable drag and drop of text                   | Selected           | Enables/disables the ability to drag and drop selected text.                                                           |
| Warn before editing a derived file             | Selected           | Enables warning if a derived file is going to be edited.                                                               |
| Smart caret position at line start and end     | Selected           | Controls whether the editor automatically positions the caret and the start or end of a line.                          |
| Appearance color options                       | Various            | Sets custom colors for various aspects of the text editor.                                                             |

# **Quick Diff Preference Page**

The Quick Diff Preference Page, enables the Quick Diff option and configures its appearance. The page is accessed via **Text Editors**  $\rightarrow$  **Quick Diff**.

| Quick Diff                                                                   |                                      |
|------------------------------------------------------------------------------|--------------------------------------|
| Enable quick diff                                                            |                                      |
| Show differences in overvie                                                  | w ruler                              |
| Colors<br>Changes:<br>Additions:<br>Deletions:<br>Use this reference source: |                                      |
| Version on Disk                                                              | •                                    |
| Note: Changing the reference                                                 | source does not update open editors. |
|                                                                              | Restore Defaults Apply               |
|                                                                              | OK Cancel                            |

Figure 120 • Quick Diff Preference Page Example

| Table 119 | • Quick | Diff | Preference | Page |
|-----------|---------|------|------------|------|
|-----------|---------|------|------------|------|

| Option                             | Default                                             | Description                                               |
|------------------------------------|-----------------------------------------------------|-----------------------------------------------------------|
| Enable quick diff                  | Selected                                            | Enables/disables the quick diff option.                   |
| Show differences in overview ruler | Deselected Shows differences in the overview ruler. |                                                           |
| Colors                             |                                                     |                                                           |
| Changes                            | _                                                   | Sets the color used to indicate changes. $^{(1)}$         |
| Additions                          | _                                                   | Sets the color used to indicate additions. $^{(1)}$       |
| Deletions                          | _                                                   | Sets the color used to indicate deletions. <sup>(1)</sup> |
|                                    |                                                     |                                                           |

| Option Default                                      |                       | Description                                                                                                                                                                                             |  |
|-----------------------------------------------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Use this reference source Version on disk           |                       | This option sets which reference to use as the base for generating quick diff comparisons.<br>Options are:<br><b>Version on Disk</b> : Current file is compared against the last saved version on disk. |  |
| Table Notes           1. The button to the right of | the option allows cha | nges to the display color (refer to "Changing Color Coding").                                                                                                                                           |  |

# Projects

Projects represent the collection of Source Files (page 226), flow options, IP configuration files, and output files for a particular design.

# Project File

Projects are persisted in .acxprj project files created automatically by the tool whenever a project is saved. A project file is actually just a Tcl script supporting only a defined subset of Tcl commands. Project files can be edited manually and then loaded into the tool to use as a script or for running regressions.

### (i) Note

When ACE loads a project file, it locks that file to prohibit other ACE sessions from loading the same file. This prevents project data corruption, which could occur if two sessions attempt to work with the same project at the same time.

In the GUI, loaded project file contents are displayed in a tree structure in the **Projects View** (page 120). Project file contents may also be viewed in a **Text Editor** (page 10) in the GUI by double-clicking the project name in the Projects view (example file contents follow):

#### **Example Project file contents**

```
# quickstart_canary
# AUTOMATICALLY GENERATED FILE
# MAY BE OVERWRITTEN AT ANY TIME DURING USE OF TOOL
# Created by: ACE -- Achronix CAD Environment -- Version 10.0 -- Build xxxxxx- -- Date
2024-04-10 08:26
# Release Version: 0.X (Main)
set_project_option -project quickstart_canary -- partname "AC20SE16A0012R0"
set_project_option -project quickstart_canary -- package "CORE"
set_project_option -project quickstart_canary -- speed_grade "C2"
set_project_option -project quickstart_canary -- core_voltage "0.80"
set_project_option -project quickstart_canary -- junction_temperature "0"
set_project_option -project quickstart_canary flow_mode "evaluation"
set_project_option -project quickstart_canary hdl_include_path ""
set_project_option -project quickstart_canary use_default_project_output_path "1"
set_project_option -project quickstart_canary sim_flow "Default"
set_project_option -project quickstart_canary sim_tb_top_name "tb_quickstart"
set_project_option -project quickstart_canary sim_tool "Aldec Riviera"
set_project_option -project quickstart_canary bitstream_output_cpu "0"
set_project_option -project quickstart_canary bitstream_output_cpu_width "8"
# Synthesis RTL Files
add_project_source_files -rtl -project quickstart_canary {{./AC20SE16A0012R0/src/rtl/
counter.v}}
add_project_source_files -rtl -project quickstart_canary {{./AC20SE16A0012R0/src/rtl/
quickstart.v}}
# Synthesis Constraint Files
add_project_source_files -syn_constraint -project quickstart_canary {{./AC20SE16A0012R0/
src/constraints/quickstart.sdc}}
# Netlist Files
add_project_source_files -pnr_netlist -project quickstart_canary {{./impl_1/syn/rev_acx/
quickstart_canary_impl_1.vm}}
# PnR Constraint Files
add_project_source_files -pnr_constraint -project quickstart_canary {{./AC20SE16A0012R0/
src/constraints/quickstart.pdc}}
add_project_source_files -pnr_constraint -project quickstart_canary {{./AC20SE16A0012R0/
src/constraints/quickstart.sdc}}
```

```
# IP Settings Files
```

```
# Simulation Testbench Files
add_project_source_files -sim_tb -project quickstart_canary {{./AC20SE16A0012R0/src/tb/
tb_quickstart.v}}
# Implementations
# impl 1
create_impl -not_active -project quickstart_canary impl_1
set_impl_option -project quickstart_canary -impl impl_1 fanout_control "1"
set_impl_option -project quickstart_canary -impl impl_1 fanout_limit "95"
set_impl_option -project quickstart_canary -impl impl_1 syn_advanced_options ""
set_impl_option -project quickstart_canary -impl impl_1 syn_default_frequency "200"
set_impl_option -project quickstart_canary -impl impl_1 syn_fanout_limit "200"
set_impl_option -project quickstart_canary -impl impl_1 syn_retiming "1"
set_impl_option -project quickstart_canary -impl impl_1 syn_route_delay_model
"acx_custom_route_delay_3"
set_impl_option -project quickstart_canary -impl impl_1 syn_use_default_project "1"
enable_project_source_file -syn_constraint -project quickstart_canary -impl impl_1
"./../../Project Space Test/AC20SE16A0012R0/src/constraints/quickstart.sdc"
enable_project_source_file -pnr_netlist -project quickstart_canary -impl impl_1 "./
impl_1/syn/rev_acx/quickstart_canary_impl_1.vm"
disable_project_source_file -pnr_constraint -project quickstart_canary -impl impl_1
"./../../Project Space Test/AC20SE16A0012R0/src/constraints/quickstart.pdc"
enable_project_source_file -pnr_constraint -project quickstart_canary -impl impl_1
"./../../Project Space Test/AC20SE16A0012R0/src/constraints/quickstart.sdc"
set_active_impl "impl_1" -project "quickstart_canary"
# End of file
```

# Source Files

A project contains source files used as inputs to the ACE tools flow. There are 6 categories of source files:

- 1. IP Configuration Files
- 2. RTL Files
- 3. Synthesis Constraints files
- 4. Place and Route Constraints files
- 5. Place and Route Netlist Files
- 6. Simulation Testbench Files

In the GUI, source files may be browsed in the **Projects View** (page 120) and viewed or edited in the builtin **Editors** (page 9) by double clicking the file name in the Projects View, or by using the right-click context menus.



Figure 121 • Project Source Files in Projects View

ACE provides GUI support to ease configuration of the most complicated embedded IP in Achronix FPGAs. The ACXIP source data files used by the IP Configuration Editors (page 9) (files with the .acxip extension) may optionally be associated with a project. When associated with a project, these IP Configuration files may then be browsed in the Projects view (page 120) under the project IP folder, and the associated editor may be started by double clicking the file name in the Projects View.

There are 2 main categories of IP Configuration files:

- Soft IP macro configurations, which generate Verilog/SystemVerilog/VHDL modules that are instantiated in the user design RTL and mapped to the Core FPGA fabric. These IP Configuration tools are available for both Speedster FPGAs and Speedcore eFPGAs.
- 2. I/O Ring configurations, which generate a single configuration for the entire I/O Ring including the I/O Ring bitstream, pin assignments, etc. I/O Ring IP Configuration tools do not output any RTL modules to instantiate in the end user design. They provide a configuration outside the scope of the end user design RTL (which maps to the Core FPGA fabric). These IP Configuration tools are only available for Speedster FPGAs.

For more details, see Creating an IP Configuration (page 335), or one of the many IP Configuration Editors.

## **RTL Files**

The project source RTL (Verilog/SystemVerilog/VHDL) files represent the end user design logic, which is intended to be simulated, synthesized, placed and routed, and mapped to the Core FPGA fabric. The RTL files added to your ACE project should not include Simulation Testbench RTL files. The list of RTL files specified in the ACE project is used to generate the input file list to the Synthesis tool, and is also used in the file list for Simulation (in addition to the Simulation Testbench source files).

#### (i) Note

Adding RTL source files to your ACE project is optional if you plan to disable the Synthesis and Simulation flow steps and run Synthesis and Simulation outside of ACE. This will require you to manually add your synthesized gate level netlist to the ACE project as a Place and Route Netlist file.

## Synthesis Constraints Files

The project source Synthesis Constraint files are used as an input to the Synthesis tool. The file types supported by Synplify Pro are \*.sdc, \*.scf, and \*.fdc. The files added to the ACE project will be used when generating the underlying Synthesis tool project file.

Synthesis Constraint files which have been added to the ACE project can be enabled or disabled per Implementation (page 231). See also: enable\_project\_source\_file (page 635) and disable\_project\_source\_file (page 627)

#### (i) Note

Adding Synthesis Constraint source files to your ACE project is optional if you plan to disable the Synthesis flow steps and run Synthesis outside of ACE. This will require you to manually add your synthesized gate level netlist to the ACE project as a Place and Route Netlist file.

## **Place and Route Constraints Files**

Place and Route Constraints files are used to control certain aspects of the static timing analysis of the user design, placement of instances in the user design, design partitioning, reporting, and bitstream generation. The constraints file types are defined in the following table.

Place and Route Constraint files which have been added to the ACE project can be enabled or disabled per Implementation (page 231). See also: enable\_project\_source\_file (page 635) and disable\_project\_source\_file (page 627)

#### Table 120 • Place and Route Constraint File Types

| File Type   | Description                                                                                                                                                                                         |  |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| *.sdc,*.scf | Timing constraints files in SDC format. These files are read by the timer in ACE. All timing constraints must be placed in these files.                                                             |  |
| *.pdc       | Placement constraints files for ACE. ACE can support many functions in this type of file, including placement and insertion of boundary pins. No SDC timing constraints can be used in these files. |  |

| File Type | Description                                                                                                                                                                                                                                                                                    |  |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| *.prt     | Partition definition file for incremental compile and partition-based design with import/export capability in ACE. There should be only one *.prt file per project in ACE. This file is typically generated by Synplify and controls which partitions will be re-compiled in the next ACE run. |  |
| *.xml     | ACE reporting extensions files, used to augment the power, utilization, or other reports with information from the surrounding ASIC or I/O Ring.                                                                                                                                               |  |
| *.hex     | Hexadecimal-formatted bitstream extension files, used to augment the Core FPGA fabric bitstream with the bitstream for the surrounding ASIC or I/O Ring.                                                                                                                                       |  |

#### (i) Note

All \*.sdc, \*.scf, and \*.pdc constraints files are read in and executed in the order specified in the ACE project file. Constraints files that are added to the project first are executed first, and likewise, constraints files which are added to the project last are executed last. If there is any order dependency between commands in your constraints, please make sure to add the constraints files in the correct order for execution in ACE. See also: move\_project\_source\_file (page 670)

At a minimum, your design will need to include SDC timing constraints for all clocks, and PDC constraints for all boundary pin placements prior to generating a bitstream.

## **Place and Route Netlist Files**

In simple design flows, there is only 1 Place and Route Netlist file enabled for the active implementation: the synthesized gate-level Verilog netlist output of the Synthesis tool. If you are using the ACE Synthesis flow steps to generate the netlist, then you do not need to manually add the synthesized gate-level netlist to your ACE project. The Run Synthesis flow step will add it to your ACE project automatically upon successful design synthesis. If you are disabling the Synthesis flow steps and running Synthesis outside of ACE, then you will need to manually add the synthesized gate-level netlist to your ACE project.

In more complex design flows, there may be multiple Place and Route Netlist files enabled for the active implementation. For example, you might need to add some exported Partition blackbox netlist files, or encrypted gate level netlists for 3rd party IP cores.

Place and Route Netlist files which have been added to the ACE project can be enabled or disabled per Implementation (page 231). See also: enable\_project\_source\_file (page 635) and disable\_project\_source\_file (page 627)

When running the **Multiprocess** (page 307) flow with the Synthesis flow step enabled, multiple gate level netlists will be synthesized and added to the ACE project (one per Implementation). Keep in mind, that as you are updating your ACE project and dealing with multiple gate level netlists for the same design, you must have only 1 gate level netlist file "enabled" per implementation. Otherwise you will see duplicate module definition errors during the Run Prepare flow step.

#### (i) Note

All Place and Route Netlist files are parsed in the order specified in the ACE project file. Place and Route Netlist files that are added to the project first are parsed first, and likewise, Place and Route Netlist files which are added to the project last are parsed last. If there is any order dependency between Place and Route Netlist module definitions, please make sure to add the Place and Route Netlist files in the correct order for parsing in ACE. See also: move\_project\_source\_file (page 670)

At a minimum, your design will need to include SDC timing constraints for all clocks, and PDC constraints for all boundary pin placements prior to generating a bitstream.

## **Simulation Testbench Files**

The project source Simulation Testbench files represent the Testbench for the end user design logic, not the end user design logic itself (which must be added as RTL source files). The list of Simulation Testbench files specified in the ACE project is used to generate the file list for Simulation (in addition to the RTL source files). Simulation Testbench RTL files are always compiled after the RTL source files in the simulator.

Simulation Testbench files can include RTL (Verilog/SystemVerilog/VHDL) and any other file type supported by the simulator.

Filelist (or simulator command) files with the  $\star$ .f extension can be added to the ACE project, and will be passed to the simulator tool with the -f option.

Memory initialization files (mem\_init\_files), test vector files, or any other type of file referenced in the testbench or user design RTL may be added to the ACE project as Simulation Testbench files. When ACE runs the Simulation flow step, it first creates a new simulation run/output directory in <project\_output\_path>/<impl>/ <sim\_step>/<tool> (for example C:/test\_project/output/impl\_1/rtl/riviera). ACE will the generate the necessary simulator input files, and copy all the mem\_init\_files, test vector files, etc into the new simulator run directory. ACE will change working directories into this simulator run directory to run the simulation. This way, all the mem\_init\_files, test vector files, etc are available in the same local directory the simulator tool is running in, which avoids several relative file path issues.

#### i Note

Adding Simulation Testbench source files to your ACE project is optional if you plan to disable the Simulation flow steps and run Simulation outside of ACE.

# **Port Mapping Files**

The I/O Designer I/O Pin Assignment View (page 66) and I/O Core Pin Assignment View (page 66) provide the option to remap port names from the values used in the IP editors to the name desired for use in the user RTL (top-level port list). This action creates an "alias" to be used in all files created when the **Generate IORing Design Files** button in the IO Designer is clicked (or similarly, calling the generate\_ioring\_design\_files (page 641) Tcl command).

These remapped names are placed in the board.acxpm (remapped pin ports) and core.acxpm (remapped core pin ports) files, stored in the project directory (the directory containing the \*.acxprj Project file (page 224)). These files are later read when generating the design files and are not needed within the design/netlist, nor are they explicitly named in the \*.acxprj Project file (page 224).

These are simple text files, with the contents automatically managed by the I/O Pin Assignment View (page 66) and I/O Core Pin Assignment View (page 66). Each line in the port mapping file contains a key/value pair, of the form:

original\_port\_name=remapped\_name\_alias

See Creating an IP Configuration (page 335) for more details on handling IP configurations and the I/O Designer.

## Implementations

A **Project** (page 224) may have multiple implementations. Each implementation contains the set of flow options (also called implementation options) configuring the run of that project through the **Flow** (page 235), and the flow outputs for this particular configuration. With this capability, the same design (RTL/Netlist) can be implemented (run through the flow) with different sets of synthesis options, placement and routing optimizations, or even timing constraints, just by creating multiple implementations for the same project.

Each implementation is associated with an implementation output directory located under the Project Output Directory. The Project Output Directory is configurable with ACE project-level options, and can be set to:

- 1. The default (the project source directory where the ACE Project File (page 224) is located), or
- 2. A custom project output path

Implementation directories are named with the implementation name and contain flow output files. **Output Files** (page 233) are divided into three main sub-directories under the implementation directory: syn (for Synthesis output), pnr (for Place and Route output), and sim (for Simulator output). The output directories contain reports, log files, and output files that are intended to be consumed by other tools later in the flow, such as netlists for simulation or the FPGA bitstream for programming.

Implementation definitions are *not* individually saved to their own files. Instead they are stored as part of the **Project** File (page 224). In the GUI, project implementations can be browsed in the **Projects View** (page 120). Selecting an implementation activates (page 231) it and displays its implementation options in the **Options View** (page 100).

When an implementation has been run through the flow, the state of the database (netlist, constraints, placement, and routing data) may be saved to an .acxdb file (see Saving Implementations (page 301)). Implementations may later be restored from previously saved .acxdb files (see Restoring Implementations (page 301)).

# Active Project and Implementation

The **active** project is the project containing the **active** implementation in the current tool session. The active implementation is the project implementation on which flow and project management commands are operating. **Only one** implementation can be active at a time. The active state applies across all projects and only in the context of the current tool session.

In the ACE GUI, the active project name, active implementation name, and target device name are all shown on the ACE titlebar in the format "Project -> Implementation (Device)". Additionally, within the **Projects View** (page 120) tree, the active project and its active implementation are both shown in a bold font.

# **Project and Implementation Options**

There are 2 types of Options that can be configured for a given ACE project:

- 1. Project Options: see set\_project\_option (page 715) and get\_project\_option (page 656)
- 2. Implementation Options: see set\_impl\_option (page 712) and get\_impl\_option (page 648)

## **Project Options**

Project Options apply globally across all implementations within a Project. These options do not change from implementation to implementation, and typically govern the overall structure of the project and flow. Some examples are **Target Device**, **HDL Include Path**, and **Flow Mode**.

Project options may have parent-child dependencies with other Project Options or Implementation Options. When changing Project Options, keep in mind that changing a parent option, like **Target Device**, will cause downstream child options to be enabled/disabled, have their valid range of values updated, or may change the child option's value. To query whether a child option is currently enabled (usable) or disabled (hidden and not applicable), see: **get\_project\_option\_is\_supported\_and\_enabled** (page 657) and **get\_impl\_option\_is\_supported\_and\_enabled** (page 649).

If a change to a Project Option impacts a child Implementation option, that Implementation option will be updated for **all** Implementations in the project (not just the active implementation).

Both Project Options and Implementation Options are displayed in the Options View (page 100) .

## **Implementation Options**

There are a wide variety of configurable implementation options which alter the implementation of the end user design in Synthesis and Place and Route as it moves through the flow (page 235). The the most-commonly used option settings are displayed in the Options View (page 100) for the current Active Project and Implementation (page 231). Within the Options view, implementation options are grouped in categories, which loosely correlate to which flow step the option affects. Changing the value of an option causes the current results of its associated flow step (if any) to become invalid or cleared, and that flow step (and all later flow steps) must be rerun, making use of the newly-changed option.

An **Implementation Options Report** (page 258) of all available project and implementation options may be generated via the Tcl command **report\_impl\_options** (page 680). This command may also be used to compare the current options configuration of an implementation with the default values for all options.

The values of implementation options may be set with the Tcl command set\_impl\_option (page 712), or reset back to the default values with reset\_impl\_option (page 687).

# **Option Sets**

Because some implementation options have a large impact upon runtime, and because the QoR benefits of these implementation options may vary significantly by design (often a QoR gain, but sometimes a slight QoR loss), many of the performance-related implementation options are disabled by default for newly created projects and implementations.

Achronix QoR experts have compiled subsets of implementation options known to optimize a wide variety of design types based upon design details. These "option sets" are made available (with description) to users in the **Multiprocess View** (page 75), and through that view, may be used to generate new implementations with the indicated implementation options enabled.

Each Option Set shown in the Multiprocess View consists of override values for a small subset of all the implementation options. These overriding values are applied to newly generated implementations over the existing implementation option values inherited from a user-selected template implementation.

It is worth repeating that the Option Sets do not contain a complete assignment of all the implementation options. Each Option Set only contains a small subset of option values, which override the implementation options inherited from the template implementation. The overriding implementation options in each set are **subsets** of the entire set

of QoR oriented implementation options. They only change *some* of the implementation options, and all the rest of the values are inherited from the template implementation. The Option Sets only enable performance-related implementation options, and (currently) never disable any already-enabled implementation options. So each generated implementation starts with the exact same implementation options as the template implementation, and then just the few implementation options named in the Option Set description are overwritten with the described values.

Achronix broke up the Option Sets into small granular chunks because of QoR/runtime trade-offs. Some of the options have a large runtime cost, and on some designs, there is a minimal performance gain. Based upon the observed runtimes reported in the **Multiprocess Summary Report** (page 256), hours of runtime may be saved while only losing 0.01% frequency by using one Option Set over another Option Set as a design is iterated.

#### (i) Note

Currently, the Option Set overrides only *enable* optimization-oriented implementation options, not disable them. Thus, if the implementation options in the template implementation are already the same values as those in the Option Set, the results from the two implementations (the implementation generated from the Option Set, and the template implementation) are identical.

It is expected that among all the Option Sets, at least one can be found that provides the necessary QoR gain for an acceptable runtime impact, allowing the fastest possible design iteration. See the Multiprocess View (page 75) and Attempting Likely Optimizations Using Option Sets (page 392) for more information.

# **Output Files**

Output files are generated for project implementations (page 231) by running certain steps in the Flow (page 235). By default, output files are automatically written to the project implementation directory.

Each implementation is associated with an implementation output directory located under the Project Output Directory. The Project Output Directory is configurable with ACE project-level options, and can be set to:

- 1. The default (the project source directory where the ACE Project File (page 224) is located), or
- 2. A custom project output path

Implementation directories are named with the implementation name and contain flow output files. Output Files are divided into three main sub-directories under the implementation directory: syn (for Synthesis output), pnr (for Place and Route output), and sim (for Simulator output). The output directories contain reports, log files, and output files that are intended to be consumed by other tools later in the flow, such as netlists for simulation or the FPGA bitstream for programming.

In the GUI, output files can be browsed in the **Projects view** (page 120) under their implementation and viewed in the editor area by double clicking the file name in the Projects view.

## Log Files

A number of log files are automatically generated while ACE is running. They include the following:

- ACE Session Log
- Implementation Log
- Multiprocess Log
- SnapShot Log
- ACE GUI Log

- Synthesis Log
- Simulation Log

The contents of these logs are typically the series of Tcl commands and resulting return values occurring during the execution of ACE. Achronix support may sometimes request one or more of these log files to assist in requested support efforts.

#### ACE Session Log

Every time ACE is started, a new ACE session log is created in the directory <user\_home\_dir>/.achronix/. This file is named ace\_<date\_timestamp>.log, where <date\_timestamp> is <year>\_<month>\_<day>\_<hour>\_<minute>\_<second>, in 24-hour format. For example, if ACE was started in Linux with a username of example\_user, on January 11<sup>th</sup> of 2023 at 2:34:56 PM, the complete log file name would be:

```
/home/example_user/.achronix/ace_2023_01_11_14_34_56.log
```

ACE session log messages are also sent to the Tcl Console View (page 146). For more information, see Viewing the ACE Log File (page 334).

#### Implementation Log

In addition to the session log, each **project** (page 224) **implementation** (page 231) has a log maintained for the complete life of the implementation. All changes to the implementation, including running the Flow (page 235) for that implementation, are appended to the implementation log. This log is stored in the directory <project\_dir>/ <impl\_name>/pnr/log/impl.log.

#### Multiprocess Log

Unlike normal flow executions, implementation runs initiated from the **Multiprocess View** (page 75) do not have their log information appended to the ACE Session Log. The reason is because multiple processes would be appending info to the log file simultaneously, leaving log entries interleaved in an unreadable mess. Instead, each implementation executed in the background creates a new log file named multiprocessImpl.log in the log directory for that implementation, overwriting any prior multiprocess log created for that implementation. Each implementation executed via the Multiprocess View does still append information to its lifetime implementation log file.

When running Multiprocess with an external job submission system (i.e., the example GridEngine default configuration), two additional log files may be created:

- The jobExecution.log contains a raw (unfiltered) copy of the implementation log for that multiprocess session, plus any additional info that the user custom job submission system might choose to inject. This file only exists if the (optional) job submission logging functionality is configured appropriately.
- The jobScheduler.log is only used during Multiprocess Batch Mode (page 317) (when in GUI mode instead of batch mode, similar info is captured in the individual implementation feedback tabs within the Multiprocess View). This file captures the standard output and error streams from the job submission system itself. This log file is particularly useful when initially configuring ACE to work with the user job submission system as it captures submission configuration errors (such as typos in job queue names).

#### **Snapshot Log**

The Snapshot log file is discussed in Collecting Samples of the User Design (page 375).

### ACE GUI Log

On rare occasions, Achronix Support may request the ACE GUI Log. This log file may be found by selecting: **Help**  $\rightarrow$  **About Ace**  $\rightarrow$  **Installation Details**  $\rightarrow$  **Configuration**  $\rightarrow$  **View Error Log**, which opens the GUI log in a non-ACE text file editor or HTML browser. The editor/browser typically reports the full path of the opened file.

## Synthesis Log

When the Synthesis flow step is run, a separate synthesis log files is generated. This log is stored in the directory <project\_dir>/<impl\_name>/syn/rev\_acx/<project\_name>\_<impl\_name>.srr.

### Simulation Log

When the Simulation flow step is run, a separate simulation log files is generated. This log is stored in the directory <project\_dir>/<impl\_name>/sim/<project\_name>-<tool>-<sim\_step>.log.

# Flow

The flow is the set of steps that must be run to complete a design in ACE. These steps are listed, in order, within the Flow view (page 55). The current Flow Mode implementation option (selected in the Options view (page 100)) affects which Flow Steps may be executed.

A flow can only be run on a single **project** (page 224), and within that project a single **implementation** (page 231) at a time (these are the **active project and ilmplementation** (page 231)) during an interactive ACE session.

To run multiple implementations from the same project through the flow simultaneously, use the **Multiprocess** view (page 75).

To run multiple separate projects through the flow simultaneously, multiple sessions of ACE must be run.

The flow can be customized by creating custom flow steps (page 329).

Additional details may be found in the section, Running the Flow (page 305).

- Flow Steps (page 235)
  - IP Configuration Steps (page 238)
  - RTL Simulation Steps (page 238)
  - Synthesis Steps (page 238)
  - Place and Route Steps (page 239)
  - Design Completion Steps (page 241)
  - FPGA Programming Steps (page 242)
- Flow Status (page 243)
- Flow Mode (page 243)

# Flow Steps

The Flow (page 235) is composed of a series of flow steps, each representing a command operating on the design in the Active Project and Implementation (page 231). Some flow steps are required (such as preparing the design), and some are optional (such as writing out a netlist for simulation). The user must enable or disable any optional flow steps prior to running the flow (see: enable\_flow\_step (page 634) and disable\_flow\_step (page 626)).

Flow steps are order-dependent. The default order of flow steps is displayed in the ACE GUI Flow View (page 55), with flow steps grouped into categories for organizational purposes. Users can customize the flow to add user-defined flow steps (see: create\_flow\_step (page 621)).

The complete flow can be run from start to finish, executing all required and enabled optional flow steps in-order by simply clicking the **Run** ( >> ) toolbar button in the **Flow View** (page 55), or by call the **run** (page 690) command. Individual flow steps can by run by double-clicking on the flow step in the **Flow View** (page 55), or by calling the **run** (page 690) command with the -step <step\_id> option. Attempting to run a flow step out of order will cause one of the following behaviors:

- You are trying to run a flow step that is further down the flow from the last completed flow step, and there are
  incomplete flow steps in between. In this case, ACE will search back to the last completed flow step (or the
  beginning of the flow if no completed flow steps), then will walk forward down the list of flow steps in-order, and
  will automatically run any incomplete required (or enabled optional) pre-requisite flow steps. If all the prerequisite flow steps complete successfully, the flow step you specified with the -step <step\_id> option will
  be run last.
  - a. For example: Let's say you have run **Run Prepare** and it has completed successfully. **Run Prepare** was the last completed flow step. Now, you double-click on the **Run Route** flow step without first running the required **Run Place** flow step. All of the other optional flow steps in between are disabled. ACE will then automatically run the **Run Place** flow step, and if it is successful, will continue to to run the desired **Run Route** flow step.
- 2. You are trying to run a flow step that is further up the flow from the last completed flow step. This could be because you want to re-run a previously completed flow step, or because you want to enable a previous optional flow step and then go back and run it before moving on. In this case, ACE will clear the status (mark as Incomplete) of all the flow steps from the targeted flow step onward, and then will attempt to run the targeted flow step.
  - a. For example: Let's say you have completed running all the flow steps up through the **Run Route** flow step. The **Run Prepare**, **Run Place**, and **Run Route** flow steps are all marked as complete. But now you want to change your PDC constraints source file and re-run only **Run Prepare**. So you double-click on **Run Prepare** to run it. This will cause **Run Prepare**, **Run Place**, and **Run Route** to all be marked as Incomplete. Then ACE will start running the **Run Prepare** step and will stop after it finishes.

The implementation option for Flow Mode (page 243) (typically configured through the Options View (page 100)) affects which flow steps can be executed.

| Name                           | ID                                      |  |
|--------------------------------|-----------------------------------------|--|
| IP Configuration               | ip_configuration                        |  |
| - Generate All IP Design Files | <pre>generate_all_ip_design_files</pre> |  |
| RTL Simulation                 | rtl_simulation                          |  |
| - Run RTL Simulation           | run_simulation_rtl                      |  |
| Synthesis                      | synthesis                               |  |

#### Table 121 • Achronix Default Flow Steps and IDs

| Name                                                   | ID                    |  |
|--------------------------------------------------------|-----------------------|--|
| - Run Synthesis                                        | run_synthesis         |  |
| - Run Gate-level Netlist Simulation                    | run_simulation_gate   |  |
| Place and Route                                        | place_and_route       |  |
| - Run Prepare                                          | run_prepare           |  |
| - Run Place                                            | run_place             |  |
| <ul> <li>Run Post-Placement Timing Analysis</li> </ul> | report_timing_placed  |  |
| - Run Route                                            | run_route             |  |
| - Run Post-Route Timing Analysis                       | report_timing_routed  |  |
| - Generate Post-Route Simulation Netlist               | write_netlist_routed  |  |
| <ul> <li>Run Post-Route Netlist Simulation</li> </ul>  | run_simulation_routed |  |
| Design Completion                                      | design_completion     |  |
| <ul> <li>Post-Process Design</li> </ul>                | post_process          |  |
| - Run Final DRC Checks                                 | final_drc_checks      |  |
| <ul> <li>Run Sign-off Timing Analysis</li> </ul>       | report_timing_final   |  |
| - Generate Final Reports                               | write_reports_final   |  |
| - Generate Final Simulation Netlist                    | write_netlist_final   |  |
| <ul> <li>Run Final Netlist Simulation</li> </ul>       | run_simulation_final  |  |
| FPGA Programming                                       | fpga_program          |  |
| - Generate Bitstream                                   | write_bitstream       |  |
| <ul> <li>FPGA Download</li> </ul>                      | fpga_download         |  |



## **IP Configuration Steps**

### Generate All IP Design Files (Optional)

This is the first step in the flow, as it generates IP design files which may include RTL files that define IP modules for the user to instantiate in the end user design RTL. This step generates IP design files for each Core fabric Soft IP configuration (\*.acxip file) in the ACE project (both Speedcore eFPGAs and Speedster FPGAs), and also generates I/O Ring design files when applicable (for Speedster FPGAs). This step is not run by default when **Run Flow** is executed.

This flow step has the id generate\_all\_ip\_design\_files for Tcl commands.

## **RTL Simulation Steps**

### Run RTL Simulation (Optional)

This flow step runs RTL simulation using the configuration set in the ACE project options. There are 2 simulation flows: Default and Custom. Select Default to use the built-in simulation flow scripts. Select Custom to call your own custom simulation TCL proc, which is defined in your ACE\_INIT\_SCRIPT setup. The actual simulation is performed in a 3rd party simulator. The ACE default simulation flow generates simulation project files targeting the given simulation tool, passes in simulator command arguments, and runs the simulator using the testbench files provided by the end user in the ACE project. The simulator HDL include path and HDL Defines are set the the Project Options section of the ACE project options, which apply to both Synthesis and Simulation flow steps. This step is not run by default when **Run Flow** is executed.

This flow step has the id run\_simulation\_rtl for Tcl commands.

## Synthesis Steps

### Run Synthesis (Optional)

This flow step runs Synthesis using the configuration set in the ACE project options. There are 2 main synthesis flows:

- Using ACE as the master of the Synthesis project (the syn\_use\_default\_project project option is set to 1), or,
- 2. Using Synplify Pro as the master of the Sythesis project file outside of ACE (the syn\_use\_default\_project project option is set to 0) .

When the syn\_use\_default\_project project option is set to 1, the source Synthesis project file will be automatically generated from the ACE project settings and managed by ACE in the Project->Output->(impl)->syn directory. When this option is disabled, the user must specify the full file path to the synthesis project file, which then gets copied to the Project->Output->(impl)->syn directory when the run\_synthesis flow step is run.

The synthesis flow #1 is the simplest approach and is useful if you want a push-button way to run Synthesis from within ACE using a consolidated ACE project file that specifies the RTL and Synthesis Constraints source files.

The synthesis flow #2 is useful if you want to use the Synplify GUI to manage the Synplify project file and use it for interactive debug. In this flow, you do not need to specify RTL source files or Synthesis Constraints source files in your ACE project.

While the actual synthesis is performed in a 3rd party tool, the ACE synthesis flow step generates synthesis project files targeting the given synthesis tool, passes in synthesis options, and runs synthesis on the end user design in the ACE project. The simulator HDL include path and HDL Defines are set the the Project Options section of the ACE project options, which apply to both Synthesis and Simulation flow steps. This step is run by default when **Run Flow** is executed.

This flow step has the id run\_synthesis for Tcl commands.

### Run Gate-Level Netlist Simulation (Optional)

This flow step runs gate-level netlist simulation using the configuration set in the ACE project options. There are 2 simulation flows: Default and Custom. Select Default to use the built-in simulation flow scripts. Select Custom to call your own custom simulation TCL proc, which is defined in your ACE\_INIT\_SCRIPT setup. The actual simulation is performed in a 3rd party simulator. The ACE default simulation flow generates simulation project files targeting the given simulation tool, passes in simulator command arguments, and runs the simulator using the testbench files provided by the end user in the ACE project. The simulator HDL include path and HDL Defines are set the the Project Options section of the ACE project options, which apply to both Synthesis and Simulation flow steps. This step is not run by default when **Run Flow** is executed.

This flow step has the id run\_simulation\_gate for Tcl commands.

## **Place and Route Steps**

#### **Run Prepare**

The first flow step required for any design is Run Prepare. This step (in order):

- 1. Clears all previously loaded netlists and constraints.
- 2. Loads and compiles the device.
- 3. Loads all the design files for the active implementation into ACE.
- 4. Runs design checks.
- 5. Transmutes the design into an Achronix design.

The active project is saved to disk automatically when this step is successfully completed. In addition, this step automatically generates a pin assignment and an utilization report.

When the active implementation is prepared, the design is ready to be placed or analyzed for timing results. An encrypted Verilog netlist can also be generated for the prepared implementation for simulation. I/O pre-placement can also be performed when the design is prepared (see **Pre-Placing a Design** (page 345)).

This flow step has the id run\_prepare for Tcl commands.

### **Run Place**

After **Run Prepare** has successfully completed on an implementation, the **Run Place** step must be run in order to place the design. If place and route has already been run on this implementation, this step may be skipped, and the place and route data from the previous run may be loaded by using the **File**  $\rightarrow$  **Load Place and Route Data** menu option. When the design is successfully placed, the encrypted placement data is stored to disk and is ready to be loaded again later.

This flow step has the id run\_place for Tcl commands.

#### Run Post-Placement Timing Analysis (Optional)

After **Run Place** has successfully completed on an implementation, the **Run Post-Placement Timing Analysis** step can be run. This step generates and writes a timing report file for the placed design, without requiring all final DRC checks to pass. This timing report will only be run against the single active temperature corner, even if multiple temperature corner reporting has been requested. The generated report is automatically displayed in the editor area upon successful completion. This step is not run by default when **Run Flow** is executed.

This flow step has the id report\_timing\_placed for Tcl commands.

#### Run Route

After **Run Place** has successfully completed on an implementation, the **Run Route** step must be run in order to route the design. If place and route has already been run on this implementation, this step may be skipped, and the place and route data from the previous run may be loaded by using the **File**  $\rightarrow$  **Load Place and Route Data** menu option. When the design is successfully routed, the encrypted placement data is stored to disk and is ready to be loaded again later.

This flow step has the id run\_route for Tcl commands.

#### Run Post-Route Timing Analysis (Optional)

After **Run Place** and **Run Route** have successfully completed on an implementation, the **Run Post-Route Timing Analysis** step can be run. This step generates and writes a timing report file for the placed and routed design, without requiring all final DRC checks to pass. This timing report will only be run against the single active temperature corner, even if multiple temperature corner reporting has been requested. The generated report is automatically displayed in the editor area upon successful completion. This step is not run by default when **Run Flow** is executed.

This flow step has the id report\_timing\_routed for Tcl commands.

#### Generate Post-Route Simulation Netlist (Optional)

After **Run Route** has successfully completed on an implementation, the **Generate Post-Route Simulation Netlist** step can be run. This step generates and writes an encrypted, post-place-and-route Verilog simulation netlist file from the design. This netlist may be used to simulate the post-place-and-route design. This step is not run by default when **Run Flow** is executed.

This flow step has the id write\_netlist\_routed for Tcl commands.

10.1

## Run Post-Route Netlist Simulation (Optional)

This flow step runs post-route simulation using the configuration set in the ACE project options. There are 2 simulation flows: Default and Custom. Select Default to use the built-in simulation flow scripts. Select Custom to call your own custom simulation TCL proc, which is defined in your ACE\_INIT\_SCRIPT setup. The actual simulation is performed in a 3rd party simulator. The ACE default simulation flow generates simulation project files targeting the given simulation tool, passes in simulator command arguments, and runs the simulator using the testbench files provided by the end user in the ACE project. The simulator HDL include path and HDL Defines are set the the Project Options section of the ACE project options, which apply to both Synthesis and Simulation flow steps. This step is not run by default when **Run Flow** is executed.

This flow step has the id run\_simulation\_routed for Tcl commands.

## **Design Completion Steps**

#### 👍 Caution!

All Flow Steps (page 235) under the Design Completion category are skipped by default when the flow mode is set to **Evaluation**. See Flow Mode (page 243) for more details.

#### Post-Process Design

After **Run Place** and **Run Route** have successfully completed (or a . acxdb file containing place and route data has been loaded) on an implementation, the **Post-Process Design** step must be run. This step post-processes the design by inserting Achronix-specific technology (such as reset, compensation block, and vmode insertion) that relies on final placement and routing information. This step should not affect timing results.

This flow step has the id post\_process for Tcl commands.

#### **Run Final DRC Checks**

After **Post-Process Design** has successfully completed on an implementation, the **Run Final DRC Checks** step must be run. This step performs all final DRC checks in order to ensure that the bitstream, final timing, and final simulation netlist can be generated without errors. If a design fails final DRC checks, a **Post-Route** timing report can still be generated for experimental purposes. However, no bitstream may be generated to run the design on the hardware unless all final DRC checks pass.

This flow step has the id final\_drc\_checks for Tcl commands.

### Run Sign-off Timing Analysis (Optional)

After **Run Final DRC Checks** has successfully completed on an implementation, the **Run Sign-Off Timing Analysis** step can be run. This step generates and writes a final sign-off timing report file for the placed and routed design, after all final DRC checks have passed. Unlike earlier timing analysis flow steps, the timing report generated by this flow step may be run against all temperature corners if **Timing Across All Temperature Corners** (page 266) has been enabled. Each generated report is automatically displayed in the editor area upon successful completion. This step is run by default when **Run Flow** is executed (and the Flow Mode is not set to **Evaluation**).

This flow step has the id report\_timing\_final for Tcl commands.

## Generate Final Reports (Optional)

After **Run Final DRC Checks** has successfully completed on an implementation, the **Generate Final Reports** step can be run. This step generates various report files, including clocks, pins, power, etc. Implementation options are used to control which report files are generated. The generated report is automatically displayed in the editor area upon successful completion. This step is run by default when **Run Flow** is executed.

This flow step has the id write\_reports\_final for Tcl commands.

### Generate Final Simulation Netlist (Optional)

After **Run Final DRC Checks** has successfully completed on an implementation, the **Generate Final Simulation Netlist** step can be run. This step generates and writes an encrypted, post-place-and-route Verilog simulation netlist file from the final DRC-free design. This netlist may be used to simulate the post-place-and-route design. This step is not run by default when **Run Flow** is executed.

This flow step has the id write\_netlist\_final for Tcl commands.

### Run Final Netlist Simulation (Optional)

This flow step runs final netlist simulation using the configuration set in the ACE project options. There are 2 simulation flows: Default and Custom. Select Default to use the built-in simulation flow scripts. Select Custom to call your own custom simulation TCL proc, which is defined in your ACE\_INIT\_SCRIPT setup. The actual simulation is performed in a 3rd party simulator. The ACE default simulation flow generates simulation project files targeting the given simulation tool, passes in simulator command arguments, and runs the simulator using the testbench files provided by the end user in the ACE project. The simulator HDL include path and HDL Defines are set the the Project Options section of the ACE project options, which apply to both Synthesis and Simulation flow steps. This step is not run by default when **Run Flow** is executed.

This flow step has the id run\_simulation\_routed for Tcl commands.

## **FPGA Programming Steps**

#### A Caution!

The **Generate Bitstream** flow step fails if attempted in **Evaluation** flow mode. Additionally, all **Flow Steps** (page 235) under the FPGA Programming category are skipped by default when the flow mode is set to **Evaluation**. See **Flow Mode** (page 243) for more details.

#### Generate Bitstream

After a design is placed and routed, the **Generate Bitstream** step can be run. This step generates a bitstream (\*.hex file) for the current implementation based on the settings in the **Options view** (page 100) (see the Options settings for Bitstream Generation). This step is run by default when **Run Flow** is executed. The flow mode must be set to **Normal** (or **Strict**) before bitstream generation can complete successfully (while it typically produces much shorter flow runtimes, the **Evaluation** flow mode relaxes the DRCs too much to produce a reliable bitstream).

This flow step has the id write\_bitstream for Tcl commands.

## FPGA Download

After the bitstream is generated, it is ready for downloading to the FPGA via either the Achronix Bitporter 2 pod or an FTDI FT2232H (or FT4232H) device as specified under the Options view settings (see the Options settings for FPGA Download). This step is not run by default when **Run Flow** is executed.

This flow step has the id fpga\_download for Tcl commands.

A bitstream can also be downloaded to the FPGA via the Download view (page 43) (see Programming a Device using JTAG in the Download View (page 389))

After downloading the bitstream, the JTAG connection status is retained, meaning that if the JTAG connection is open prior to programming, it will stay open, and if the JTAG connection is closed prior to programming, it will close the connection when programming completes.

For more details, refer to the Configuration User Guide (UG004).

# Flow Status

Flow Steps (page 235) each have a status associated with them. The current status of each flow step for the Active Project and Implementation (page 231) can be seen in the GUI in the Flow View (page 55).

Each step can be in one of the following flow states:

| State                                        | Flow Category | Flow Step |
|----------------------------------------------|---------------|-----------|
| Incomplete                                   | θ             | ۸         |
| Running                                      | 0             | 0         |
| Complete                                     | θ             | ~         |
| Disabled                                     | θ             | ۸         |
| Error                                        | ×             | ×         |
| Complete (but out of sync with source files) | 1             | 1         |

#### Table 122 • Flow State Icons

Be aware that changing or **Configuring Project and Implementation Options** (page 303) which affect a flow step can cause the status of a flow step to be reset back to Incomplete.

See the concepts for the Flow (page 235) and Flow View (page 55), as well as the task for Running the Flow (page 305) for more details.

# Flow Mode

The flow mode is managed as an Implementation (page 231) Option, typically through the Options View (page 100).

The chosen flow mode determines which DRCs are executed at different points in the Flow (page 235), affects timing analysis, and in some configurations prohibits the final Flow Steps (page 235) from executing successfully.

- **Evaluation** this mode ignores non-fatal DRCs as long as possible, allows IO Virtualization, and to get a postroute timing report quickly, ignores missing SDC constraints and only runs timing against a single target temperature corner, even if timing across all corners has been requested. This mode allows iterating more quickly during preliminary or early design stages.
- Normal this flow mode enforces all DRC checks prior to generating a bitstream. Some checks are flagged as warnings early on in the flow to provide an opportunity to correct the problems (i.e., fixing the placement of I/ Os). These same checks may change to report an error during final DRC checks. This mode should be used when developing a real design for a product, and enables bitstream generation.
- Strict this mode is similar to Normal flow mode, but to reduce runtime, strictly enforces all DRC checks, erroring out as early in the flow as possible. This more restrictive mode should be used during the later, more mature design iterations.

When in **Evaluation** flow mode, the **Run Flow** and **Re-run Flow** actions in the **Flow View** (page 55) stop after the **Place** and **Route** flow step category is completed. By default, the flows steps under **Design Completion** and **FPGA Programming** are not run unless the implementation is in **Normal** or **Strict** flow mode.

#### (i) Note

UG070

The **Generate Bitstream** flow step fails if attempted while in **Evaluation** flow mode. Bitstream generation requires **Normal** or **Strict** flow mode, so that ACE may ensure all DRCs have passed.

Some examples of error checks in Strict flow mode, applicable to Speedcore devices, are as follows:

- 1. If any Speedcore boundary pins (IPIN/OPIN/CLK\_IPIN/CLK\_OPIN) are not explicitly instantiated in the user design RTL or PDC files, ACE errors out in the Run Prepare flow step.
- 2. If any Speedcore boundary pins (IPIN/OPIN/CLK\_IPIN/CLK\_OPIN) are not explicitly placed with "fixed" placement in the project PDC files, ACE errors out at the beginning of the Run Place flow step.

In other flow modes, these checks do not happen until Final DRC Checks prior to bitstream generation.

# Reports

ACE generates a number of reports to provide information on how user designs are being handled in the selected Achronix device. These reports are meant to assist in making design decisions.

Each of the listed reports is generated in HTML format by default, and with the noted Tcl command, each report can optionally (unless otherwise noted) be generated in plain text format, or in CSV format for easy import into spreadsheet programs. As soon as the reports are generated, they are opened for viewing within the ACE Editor area.

# **Utilization Report**

The Utilization Report shows a summary and details of the utilization of the device resources for the current design.

www.achronix.com

This report is automatically generated as part of the Run Prepare flow step (page 235).

To generate this report manually, see the **report\_utilization** (page 687) Tcl command.

# Pin Assignment Report

The Pin Assignment Report shows detailed information on each of the user design top-level ports, including placement and configuration details.

Typically, the report is automatically generated by the Flow (page 235) at multiple times (as part of the **Run Prepare**, **Run Place**, and **Post-Process Design flow steps** (page 235)).

To generate this report manually, see the report\_pins (page 683) Tcl command.

# **Clock Report**

The Clock Report shows all clocks used in the design, their frequencies/periods, their relationships, and their constraints. Related information regarding device Clock Regions is also included in the report.

The report is automatically generated by the Flow (page 235) at multiple stages of the flow.

To generate this report manually, see the report\_clocks (page 679) Tcl command.

# **Timing Report**

The Timing Report provides details on how well the current design is meeting timing on the selected device.

Timing analysis can be performed at several stages in the Flow (page 235), each stage generating a different report. If the report is generated before the design has been placed or routed, placement and/or routing will be estimated.

This report is automatically generated by the flow during any of the (optional) **Run ... Timing Analysis Flow Steps** (page 235).

To generate this report manually, see the run\_timing\_analysis (page 703) Tcl command.

If Timing Across All Temperature Corners (page 266) is enabled through the relevant implementation options, this will only affect the (final) timing report, generated during the **Run Sign-Off Timing Analysis** flow step, and only when the **Flow Mode** (page 243) is set to Normal or Strict mode. All other timing reports will only include a single temperature corner. When multiple corner reporting occurs, a separate timing report is generated for each corner, with the file name of the report noting the corner being reported.

Generating timing reports for multiple temperature corners is only possible when in the Normal or Strict flow modes, and only for the final (sign-off) timing analysis flow step. In all other cases, only a single temperature corner will be reported.

When multiple-corner reporting occurs, each corner will generate a separate report file, with the report file's name noting the corner being analyzed/reported.

See also: Multiprocess Summary Report (page 256)

# **Report Content**

The report contains a Summary section and a Details section.

The Summary section contains three tables. There is a table for Critical Setup (max) Timing Paths, one for Critical Hold (min) Timing Paths, and one for the resulting Clock Frequencies. Each summary section table contains a single row for each Clock/Group, showing the most critical path for that Clock/Group.

The Details section contains a configurable maximum number of critical setup paths and critical hold paths for each Clock/Group, and each of those critical paths includes a configurable maximum number of worst paths for the critical path endpoint.

The number of critical paths and worst paths are **Implementation Options** (page 0) configured in the **Options View** (page 100) under "Timing Analysis".

# **Routing Report**

The Routing Report collects a number of routing-related statistics and any related errors into an easily readable report format.

This report is automatically generated by the Flow (page 235) during the **Run Route** and **Post-Process Design flow** steps (page 235).

To generate this report manually, see the report\_routing (page 686) Tcl command.

# **Partitions Report**

The Partitions Report collects a number of partition-related statistics into an easily readable report format.

This report is automatically generated by the Flow (page 235) (and opened in the GUI) during the **Run Prepare** flow step (page 235) when Using Incremental Compilation (Partitions) (page 404).

To generate this report manually, see the **report\_partitions** (page 681) Tcl command.

# **Power Dissipation Report**

The Power Dissipation report shows an estimate for the amount of power, in Watts, dissipated by the current design on the selected Achronix device under normal operating conditions. This report is typically generated after placeand-route, and therefore includes the effects of all transistor and wiring parasitics in the power calculation. This is in contrast to the Speedster7t Power Estimator and Speedcore Power Estimator tools, which are used early in the design process, prior to actual design activity.

Total power dissipation is reported so that thermal requirements can be estimated for the user design. Total power is also broken down into several different categories, such as power dissipated for each power rail, for each cell type, and instance power vs. interconnect power. Therefore the report can also be used for the design and sizing of the power supplies, and the selection of hard IP blocks such as DDR4 vs. GDDR6.

This User Guide provides an example power dissipation report, with an explanation of each section of the report, as well as detailed information about how power dissipation is calculated, and how to generate the report.

# **Example Power Dissipation Report**

The Power Dissipation Report consists of eight sections, each of which presents the power dissipation from a different perspective.

- Report Header
- Power Summary
- Hard IP Power
- Dynamic Power Per Cell

- Power Per Rail
- Core Dynamic Power Details
- Core Dynamic Instance Power Details
- Core Dynamic Interconnect Power Details section

The following describes each section in more detail.

# Section: Report Header

This section, common to all ACE reports, provides information about how and when the report was generated. It can be seen that the design name is pcie\_gddr6\_ddr4\_vp\_demo\_top, which is a VectorPath<sup>®</sup> card demonstration design that configures the PCIe, GDDR6, and DDR4 interfaces. The operating conditions assumed for this report can also be seen: C2 speed grade, 0.85 volts, and 0 degrees Celsius.

# **Power Dissipation Report**

ACE -- Achronix CAD Environment -- Version 9.2 -- Build 463545 -- Date 2023-09-20 15:15 Design: pcie\_gddr6\_ddr4\_vp\_demo\_top - impl\_1 - pcie\_gddr6\_ddr4\_vp\_demo\_top Device: AC7t1500ES0 Generated on Wed Sep 20 15:28:29 PDT 2023 Host: bob.achronix.local

#### Disclaimer

This is an estimation, based on the design characteristics and frequencies specified below. Power consumption is reported as worst case across all operating modes, including bitstream programming and user mode. Actual power results may vary from the estimates.

#### Operating conditions: C2, 0 deg. C, 0.85 V (Core), Fast Corner

# Figure 122 • Example of Power Dissipation Report Header Section

# Section: Power Summary

This section reports the total power dissipation, which is about 82 Watts in the example design, and then breaks that total down into four major sub-categories:

- The relative contributions of dynamic (switching) vs. static (leakage) power to the total
- The relative contributions of core (programmable) logic power vs. hardened IP power, both static and dynamic
- The relative contributions of instance vs. interconnect power in the programmable core, not including clock power
- Dynamic clock network power, which includes clock interconnect and clock instances, such as clock gates, clock dividers, and clock switches

#### **Power Summary**

| Total Power:                 | 81.7951 W |
|------------------------------|-----------|
| Total Dynamic Power:         | 63.5311 W |
| Total Static Power:          | 18.2640 W |
| Core Dynamic Power:          | 0.7087 W  |
| Core Static Power:           | 1.5786 W  |
| Hard IP Dynamic Power:       | 62.8223 W |
| Hard IP Static Power:        | 16.6854 W |
| Dynamic Instance Power:      | 0.5354 W  |
| Dynamic Interconnect Power:  | 0.0848 W  |
| Dynamic Clock Network Power: | 0.0885 W  |

#### Figure 123 • Example of Power Dissipation Report Power Summary Section

### Section: Hard IP Power

This section reports details of the power contributed by each hard IP block in the design. The example design contains many of the available hard IP blocks, so the report contains many rows. For example, it can be seen that more than half of the total power dissipation in the design, which contains very little core logic, is used by the GDDR6 controller.

In order to include the power contribution of hard IP blocks, those IPs must have been configured in the IP **Configuration editors** (page 335), and the associated IP **Configuration Files** (page 226) must be included in their ACE project.

| CLKIO_NE:     | 0.4635 W  |
|---------------|-----------|
| CLKIO_NW:     | 0.5251 W  |
| CLKIO_SE:     | 0.4812 W  |
| CLKIO_SW:     | 0.4507 W  |
| DDR4:         | 2.2601 W  |
| Ethernet:     | 3.2886 W  |
| GDDR6:        | 43.1043 W |
| GPIO_N_B0:    | 0.3118 W  |
| GPIO_N_B1:    | 0.3101 W  |
| GPIO_N_B2:    | 0.2349 W  |
| GPIO_S_B0:    | 0.3052 W  |
| GPIO_S_B1:    | 0.1381 W  |
| GPIO_S_B2:    | 0.2284 W  |
| NoC:          | 15.2879 W |
| PCIe:         | 7.3981 W  |
| PLL:          | 0.3166 W  |
| SERDES_LN_0:  | 0.2221 W  |
| SERDES_LN_1:  | 0.2221 W  |
| SERDES_LN_10: | 0.2221 W  |
| SERDES_LN_11: | 0.2221 W  |
| SERDES_LN_12: | 0.2221 W  |
| SERDES_LN_13: | 0.2221 W  |
| SERDES_LN_14: |           |
| SERDES_LN_15: | 0.2221 W  |
| SERDES_LN_2:  | 0.2221 W  |
| SERDES_LN_3:  | 0.2221 W  |
| SERDES_LN_4:  | 0.2221 W  |
| SERDES_LN_5:  | 0.2221 W  |
| SERDES_LN_6:  | 0.2221 W  |
| SERDES_LN_7:  | 0.2221 W  |
| SERDES_LN_8:  | 0.2221 W  |
| SERDES_LN_9:  | 0.2221 W  |
| SoC:          | 0.8493 W  |
| iNoC:         | 6.3650 W  |
|               |           |

Figure 124 • Example of Power Dissipation Report Hard IP Power Section

# Section: Dynamic Power Per Cell

This section reports details of the dynamic power contributed by instances of each cell type, such as Reconfigurable Logic Blocks (LUT6s, DFFs, MUXes and ALUs), Block RAMs, Network Access Points, etc. This design contains very little programmable core logic, so these numbers are quite small relative to the Hard IPs.

#### Dynamic Power Per Cell

| RLB Power:     | 0.0062 W  |
|----------------|-----------|
| BRAM Power:    | 0.0026 W  |
| LRAM Power:    | 0.0016 W  |
| MLP Power:     | 0.0000 W  |
| NAP Power:     | 0.5250 W  |
| Hard IP Power: | 85.8727 W |
| Other Power:   | 0.0000 W  |

#### Figure 125 • Example of Power Dissipation Report Dynamic Power Per Cell Section

#### Section: Power Per Rail

This section reports the power dissipation for each power rail in the design (rows), breaking it down into categories (columns) such as dynamic vs. static power, and core logic vs. hard IPs. For example, the VDDL power rail represents the programmable logic core of the design, and it contributes all of the core static and dynamic power. The rest of the power rails are used exclusively by the hard IPs.

#### Power Per Rail

| Power Rail      | Total Power (W) | Total Dynamic Power (W) | Total Static Power (W) | Core Dynamic Power (W) | Core Static Power (W) | Hard IP Dynamic Power (W) | Hard IP Static Power (W) |
|-----------------|-----------------|-------------------------|------------------------|------------------------|-----------------------|---------------------------|--------------------------|
| CLKIO_NE_VDDIO  | 0.4124          | 0.3592                  | 0.0532                 | 0.0000                 | 0.0000                | 0.3592                    | 0.0532                   |
| CLKIO_NW_VDDIO  | 0.4124          | 0.3592                  | 0.0532                 | 0.0000                 | 0.0000                | 0.3592                    | 0.0532                   |
| CLKIO_SE_VDDIO  | 0.4124          | 0.3592                  | 0.0532                 | 0.0000                 | 0.0000                | 0.3592                    | 0.0532                   |
| CLKIO_SW_VDDIO  | 0.4124          | 0.3592                  | 0.0532                 | 0.0000                 | 0.0000                | 0.3592                    | 0.0532                   |
| DDR4_S0_VAA     | 0.0129          | 0.0108                  | 0.0021                 | 0.0000                 | 0.0000                | 0.0108                    | 0.0021                   |
| DDR4_S0_VDDQ    | 0.7491          | 0.7098                  | 0.0393                 | 0.0000                 | 0.0000                | 0.7098                    | 0.0393                   |
| FCU_VDDIO       | 0.8452          | 0.1690                  | 0.6762                 | 0.0000                 | 0.0000                | 0.1690                    | 0.6762                   |
| GCG_NE_PLL_VDDA | 0.0120          | 0.0015                  | 0.0105                 | 0.0000                 | 0.0000                | 0.0015                    | 0.0105                   |
| GCG_NW_PLL_VDDA | 0.0120          | 0.0015                  | 0.0105                 | 0.0000                 | 0.0000                | 0.0015                    | 0.0105                   |
| GCG_SE_PLL_VDDA | 0.0120          | 0.0015                  | 0.0105                 | 0.0000                 | 0.0000                | 0.0015                    | 0.0105                   |
| GCG_SW_PLL_VDDA | 0.0166          | 0.0061                  | 0.0105                 | 0.0000                 | 0.0000                | 0.0061                    | 0.0105                   |
| GDDR6_E_VDDA    | 8.4480          | 8.1413                  | 0.3067                 | 0.0000                 | 0.0000                | 8.1413                    | 0.3067                   |
| GDDR6_E_VDDIO   | 4.2780          | 3.8947                  | 0.3833                 | 0.0000                 | 0.0000                | 3.8947                    | 0.3833                   |
| GDDR6_E_VDDP    | 4.6350          | 4.2197                  | 0.4153                 | 0.0000                 | 0.0000                | 4.2197                    | 0.4153                   |
| GDDR6_E_VDDR    | 3.3300          | 2.8442                  | 0.4858                 | 0.0000                 | 0.0000                | 2.8442                    | 0.4858                   |
| GDDR6_W_VDDA    | 8.4480          | 8.1413                  | 0.3067                 | 0.0000                 | 0.0000                | 8.1413                    | 0.3067                   |
| GDDR6_W_VDDIO   | 4.2780          | 3.8947                  | 0.3833                 | 0.0000                 | 0.0000                | 3.8947                    | 0.3833                   |
| GDDR6_W_VDDP    | 4.6350          | 4.2197                  | 0.4153                 | 0.0000                 | 0.0000                | 4.2197                    | 0.4153                   |
| GDDR6_W_VDDR    | 3.3300          | 2.8442                  | 0.4858                 | 0.0000                 | 0.0000                | 2.8442                    | 0.4858                   |
| GPIO_N0_VDDIO   | 0.4905          | 0.4888                  | 0.0017                 | 0.0000                 | 0.0000                | 0.4888                    | 0.0017                   |
| GPIO_S0_VDDIO   | 0.3250          | 0.3234                  | 0.0017                 | 0.0000                 | 0.0000                | 0.3234                    | 0.0017                   |
| SRDS_N_PA_VDDH  | 5.9922          | 0.9466                  | 5.0456                 | 0.0000                 | 0.0000                | 0.9466                    | 5.0456                   |
| SRDS_N_PA_VDDL  | 7.1711          | 0.7401                  | 6.4309                 | 0.0000                 | 0.0000                | 0.7401                    | 6.4309                   |
| TS_VDDA         | 0.0004          | 0.0001                  | 0.0004                 | 0.0000                 | 0.0000                | 0.0001                    | 0.0004                   |
| VCC             | 20.8372         | 19.7863                 | 1.0509                 | 0.0000                 | 0.0000                | 19.7863                   | 1.0509                   |
| VDDL            | 2.2874          | 0.7087                  | 1.5786                 | 0.7087                 | 1.5786                | 0.0000                    | 0.0000                   |

#### Figure 126 • Example of Power Dissipation Report Power Per Rail Section

### Section: Core Dynamic Power Details

This section reports the programmable core dynamic power by power rail and clock domain (rows), breaking it down into categories (columns) for non-clock instance power, non-clock interconnect power, and clock instance and interconnect power.

| Power Rail | Clock                                | Frequency (MHz) | Total Dynamic Power (W) | Instance Power (W) | Interconnect Power (W) | Clock Power (W) |
|------------|--------------------------------------|-----------------|-------------------------|--------------------|------------------------|-----------------|
| VDDL       | i_nap_clk                            | 499.88          | 0.2035                  | 0.1447             | 0.0252                 | 0.0336          |
| VDDL       | i_reg_clk                            | 249.94          | 0.4460                  | 0.3530             | 0.0464                 | 0.0466          |
| VDDL       | i_adm_clk                            | 124.97          | 0.0575                  | 0.0376             | 0.0127                 | 0.0072          |
| VDDL       | tck                                  | 25.00           | 0.0015                  | 0.0001             | 0.0004                 | 0.0011          |
| VDDL       | v_acx_sc_GPIO_H_IOB1_GLB_SER_GEN_CLK | 10.00           | 0.0000                  | 0.0000             | 0.0000                 | 0.0000          |
| VDDL       | Combinational                        |                 | 0.0001                  | 0.0000             | 0.0001                 | 0.0000          |

#### Core Dynamic Power Details

#### Figure 127 • Example of Power Dissipation Report Core Dynamic Power Details Section

#### Section: Per-Tile Core Dynamic Instance Power Details

This section reports the programmable core dynamic instance power by power rail and clock domain (rows), breaking it down into categories (columns) for each type of logic tile, such as clock tiles, boundary IO pin tiles, Machine Learning Processor (MLP) tiles, 2D Network on Chip (NoC) tiles, and Reconfigurable Logic Block (RLBs) tiles.

| Power Rail | Clock                                | Frequency (MHz) | Total Instance Power (W) | Clock Power (W) | IO Pin Power (W) | MLP Power (W) | NOC Power (W) | RLB Power (W) |
|------------|--------------------------------------|-----------------|--------------------------|-----------------|------------------|---------------|---------------|---------------|
| VDDL       | i_nap_clk                            | 499.88          | 0.1447                   | 0.0000          | 0.0000           | 0.0016        | 0.1416        | 0.0016        |
| VDDL       | i_reg_clk                            | 249.94          | 0.3530                   | 0.0000          | 0.0000           | 0.0016        | 0.3480        | 0.0034        |
| VDDL       | i_adm_clk                            | 124.97          | 0.0376                   | 0.0000          | 0.0000           | 0.0011        | 0.0354        | 0.0012        |
| VDDL       | tck                                  | 25.00           | 0.0001                   | 0.0000          | 0.0000           | 0.0000        | 0.0000        | 0.0000        |
| VDDL       | v_acx_sc_GPIO_H_IOB1_GLB_SER_GEN_CLK | 10.00           | 0.0000                   | 0.0000          | 0.0000           | 0.0000        | 0.0000        | 0.0000        |
| VDDL       | Combinational                        |                 | 0.0000                   | 0.0000          | 0.0000           | 0.0000        | 0.0000        | 0.0000        |

#### Per-Tile Core Dynamic Instance Power Details

### Figure 128 • Example of Power Dissipation Report Per-Tile Core Dynamic Instance Power Details Section

#### Section: Per-Tile Core Dynamic Interconnect Power Details

This section reports the programmable core dynamic interconnect power by power rail and clock domain (rows), breaking it down into categories (columns) for each type of logic tile, such as clock tiles, boundary IO pin tiles, Machine Learning Processor (MLP) tiles, 2D Network on Chip (NoC) tiles, and Reconfigurable Logic Block (RLBs) tiles. Interconnect power includes the actual routing wires, as well as the statically programmable FPGA routing MUXes used to connect different wire segments to form a complete route.

| Power Rail | Clock         | Frequency (MHz) | Total Interconnect Power (W) | Clock Power (W) | IO Pin Power (W) | MLP Power (W) | NOC Power (W) | RLB Power (W) |
|------------|---------------|-----------------|------------------------------|-----------------|------------------|---------------|---------------|---------------|
| VDDL       | i_nap_clk     | 499.88          | 0.0252                       | 0.0194          | 0.0000           | 0.0017        | 0.0012        | 0.0366        |
| VDDL       | i_reg_clk     | 249.94          | 0.0464                       | 0.0256          | 0.0000           | 0.0077        | 0.0035        | 0.0563        |
| VDDL       | i_adm_clk     | 124.97          | 0.0127                       | 0.0027          | 0.0000           | 0.0010        | 0.0003        | 0.0158        |
| VDDL       | tck           | 25.00           | 0.0004                       | 0.0007          | 0.0000           | 0.0000        | 0.0000        | 0.0007        |
| VDDL       | Combinational |                 | 0.0001                       | 0.0000          | 0.0000           | 0.0000        | 0.0000        | 0.0001        |

#### Per-Tile Core Dynamic Interconnect Power Details

#### Figure 129 • Example of Power Dissipation Report Per-Tile Core Dynamic Interconnect Power Details Section

# **Power Calculation Methodology**

Power dissipation is calculated using the following basic equation:

$$power_{total} = \sum_{nets} (energy_{net} \times frequency_{net} \times activity_{net})$$

Here total power is summed up over the individual contribution of every net in the design, including nets internal to logic gates and hard IP blocks. Power for each net is calculated as the product of the total energy dissipated in each zero-to-one or one-to-zero transition, measured in units of joules, which is derived from extracted layout data and present in the technology library being used; the target frequency of that net clock domain, measured in units of 1/seconds; and a unitless quantity called activity, which is defined as the average number of transitions *per clock cycle*.

Activity can be larger than one if a net experiences a lot of glitching. The activity factor for clock nets is, by definition, 2.0, since there are two transitions per cycle. ACE typically uses a default value of 0.125 for the activity value of non-clock nets. This value reflects an assumption that non-clock nets switch, on average, about once every eight clock cycles. This has been shown to be a reasonable assumption across a wide variety of designs, but it is, of course, only an approximation and not always correct.

In order to produce the most accurate power report possible, per-net activity values can be specified in a Switching Activity Interchange Format (SAIF) file. SAIF files are typically produced by a gate-level logic simulator. However, if necessary, the file can be written by hand. The accuracy of the activity values in a SAIF file depend on the quality of the simulation testbench, and are only reflective of the operating mode(s) exercised in that testbench. See the section **How to Generate a Simulation-Driven Power Dissipation Report** (page 253) below for more information.

# How to Generate the Power Dissipation Report

This report is generated automatically when running the ACE Flow (page 235) as part of the

write\_reports\_final (page 241)

flow step. However, it is not generated by default. The report\_power implementation option (page 303) must be set to "1" in the project before running the write\_reports\_final flow step.

This report can also be generated on-demand by restoring the routed implementation (page 301) and then calling the report\_power (page 684) Tcl command.

As power dissipation varies across different process corners and operating conditions, a separate power dissipation report is generated for each temperature corner, with the file name of the report noting the corner being reported. See the page Timing Across All Temperature Corners (page 266) for more information.

The Power Dissipation Report can optionally include the contribution of hard IP blocks, such as the PCle controller and the 2D Network on Chip. In order to include those contributions (which can often dominate the contribution of the programmable logic), those hard IP blocks must have been configured in the **IP Configuration editors** (page 335), and also have included the associated **IP Configuration Files** (page 226) in the ACE project.

# How to Generate a Simulation-Driven Power Dissipation Report

As discussed above in the Power Calculation Methodology section, per-net activity values can be specified in a text file called a Switching Activity Interchange Format (SAIF) file. SAIF files are typically produced by a gate-level logic simulator such as Synopsys VCS, Cadence Incisive, Siemens QuestaSim, or Aldec Riviera. This section covers the format of a SAIF file, how to use a SAIF file in ACE, and how to generate a SAIF file in the VCS and QuestaSim simulators. The documentation for your simulator of choice should be consulted for definitive instructions.

### Format of a SAIF File

SAIF files are written in a clear-text format defined in IEEE Standard 1801-2009 (see https://ieeexplore.ieee.org/ document/8686430). Therefore, if desired, small SAIF files can be generated by hand or with a script. The standard defines both *backward* and *forward* SAIF file formats. Here we are using a *backward* SAIF file which is intended for back-annotation into EDA tools. Below is an example of a complete SAIF file that is accepted by ACE.

#### Sample SAIF File

```
(SAIFILE
   (SAIFVERSION "2.0")
   (DIRECTION "backward")
   (DURATION 5950100.00)
   (INSTANCE tb_test1
      (INSTANCE DUT
         (NET
             (ina\[0\]
                (T0 3750100) (T1 2200000) (TX 0)
                (TC 22) (IG 0)
             )
             (clk
                (T0 3000100) (T1 2950000) (TX 0)
                (TC 118) (IG 0)
            )
         )
      )
   )
)
```

The file must:

1. Begin with the SAIFILE keyword.

- 2. Give the version number.
- 3. Specify that it is a backward SAIF file.
- 4. Give the duration of the simulation as the number of verilog timesteps.

Most important are the INSTANCE and NET sections of the file. It can be seen that this design has two levels of hierarchy. The instance tb\_test1 is the testbench containing behavioral verilog that applies test vectors to the device under test. The instance DUT is the Device Under Test, which is an instance of the top level design being compiled in ACE. The design contains two nets, an input net, ina[0], and a clock net, clk. Square brackets and other reserved characters must be escaped with "\" in the SAIF file.

Under each net are five values, T0, T1, TX, TC, and IG. The T0, T1, and TX values are the number of timesteps that the net spent at the logic values 0, 1, and X respectively. The IG value is the number of inertial glitch values — for details see the documentation. The only important value for ACE is the TC value, which is the total number of zero-to-one and one-to-zero transitions over the duration of the simulation. Since the clock net had 118 transitions during simulation, and the ina[0] net had 22 transitions, ACE calculates the activity value, which is defined as the average number of transitions per clock cycle, as 22/118 = 0.1864 (not very different from the default activity value of 0.125).

### How to Use a SAIF File in ACE

To use a SAIF file, two implementation options (page 303) must be specified to ACE:

- 1. The pathname to the SAIF file
- 2. The name of the top-level instance in the simulation testbench

The Tcl interpreter normalizes the pathname, so it can be an absolute or relative path, a direct pathname or a symbolic link, and in Windows or Linux format. The name of the top-level instance in the SAIF file must be specified because ACE only knows the name of the top-level *module* in the RTL. Since the testbench is not being compiled, ACE does know the name of the *instance* of that module in the behavioral simulation testbench module. The default SAIF file pathname is the empty string (no file specified). The default top-level instance name is "DUT", as in this example.

When generating the Power Dissipation Report during the normal ACE flow, specify the pathname to the SAIF file in the ACE project file using the report\_power\_saif\_file implementation option, and the name of the top-level instance in the report\_power\_saif\_top\_level implementation option:

```
set_impl_option -project test1 -impl impl_1 report_power_saif_file "../vcs-routed/
sim_output.saif"
set_impl_option -project test1 -impl impl_1 report_power_saif_top_level "DUT"
```

When generating the Power Dissipation Report from the ACE command line, simply call the report\_power command with the following two options:

report\_power -saif\_file ../vcs-routed/sim\_output.saif -saif\_top\_level DUT

### How to Generate a SAIF File Using Synopsys VCS

In this section, for convenience, we provide instructions for how to generate a SAIF file using Synopsys VCS. However, note that VCS behavior may change at any time, and these instructions may be incorrect or

incomplete. More than one method of generating a SAIF file may be supported. Consult your simulator documentation for definitive instructions.

There are four steps required:

- 1. Generate a Final Simulation Netlist (a post-routing simulation netlist that matches the netlist used by the power report) using ACE. The Generate Final Simulation Netlist (page 241) flow step is an optional flow sub-step that runs under the Design Completion flow step, so that sub-step must be enabled before running the ACE flow.
- From within the verilog testbench, several additional system functions must be called to specify which part of the design to be observed, and to start and stop the recording of data. The following code can be used as a rough template for a simulation testbench:

```
initial begin
   $set_gate_level_monitoring("on");
   $set_toggle_region(mixedHdlScope);
   // initialization of Verilog signals, and then:
   $toggle_start;
   // testbench
   $toggle_stop;
   $toggle_report("sim_output.saif", $timeUnit, mixedHdlScope);
end
```

3. Call the VCS compiler to generate the simv executable. To generate a SAIF file, the -debug\_access+pp flag must be added:

vcs <input\_files> <testbench> -debug\_access+pp

4. Call the simulation executable. To generate a SAIF file, the -lcs (limited customer access) flag must be added:

simv -lcs

# How to Generate a SAIF File Using Siemens QuestaSim

In this section, for convenience, we provide instructions for how to generate a SAIF file using Siemens QuestaSim. However, note that QuestaSim behavior may change at any time, and these instructions may be incorrect or incomplete. More than one method of generating a SAIF file may be supported. Consult your simulator documentation for definitive instructions.

There are seven steps required:

- 1. Generate a Final Simulation Netlist (a post-routing simulation netlist that matches the netlist used by the power report) using ACE. The Generate Final Simulation Netlist (page 241) flow step is an optional flow sub-step that runs under the Design Completion flow step, so that sub-step must be enabled before running the ACE flow.
- 2. Launch QuestaSim in interactive mode, while specifying the additional option -voptargs="+acc". This option prevents QuestSim from compressing the netlist and throwing away nodes that must be reported.

vsim -voptargs="+acc"

3. After the simulator returns to the prompt, run the following command to request the simulator to stop rather than exiting after the simulation completes:

onfinish stop

Specify the scope of the data to be collected, which should include all nets in the DUT. Using the example SAIF file above, this would be as follows:

power add -in -inout -internal -out tb\_test1.DUT.\*

5. Run the simulation:

run -all

6. After the simulation completes, request the simulator to write out the SAIF file:

power report -al -bsaif sim\_output.saif

7. Quit QuestaSim:

quit

# **Design Statistics Report**

The Design Statistics Report is meant to show various statistics about the current design.

Presently, the only statistics being reported are a histogram showing LUT Function usage counts. This information is primarily meant as a tool for Achronix Technical Support to assist ACE users unable to share their full design. It allows Achronix to better understand the nature of the design and thus provide advice on QoR improvements.

This report is not automatically generated by the Flow (page 235), but can be generated manually with the report\_design\_stats (page 680) Tcl command.

# **Multiprocess Summary Report**

The Multiprocess Summary Report provides a comparative summary of the achieved frequencies and worst-case slacks (if the "Run Post-Route Timing Analysis" or "Run Sign-off Timing Analysis" **Flow Steps** (page 235) are enabled), as well as process execution times, for selected **Implementations** (page 231) of a single Project when executed from the **Multiprocess View** (page 75). This report is automatically shown (and refreshed) in the ACE Editor Area as new results become available during Multiprocess execution.

The Multiprocess Summary Report is generated/updated multiple times during a Multiprocess execution as new data becomes available from the executing **Implementations** (page 231). While the Multiprocess flow is still executing, the report contains incomplete results — rows containing incomplete data are marked as such. Similarly, if errors are encountered during flow execution for one of the selected **Implementations** (page 231), the row(s) of data for that implementation are marked accordingly.

🖸 Tip

Because the Multiprocess Summary Report summarizes the results of multiple **Implementations** (page 231) (unlike the other reports, which are generated for a single implementation), the HTML file containing the report is not placed in any implementation report subfolder. Instead, this report is placed in the directory containing the .acxprj ACE **Project File** (page 224), and is named multiprocess\_summary.html.

# If closed, the Multiprocess Summary Report can be re-opened at any time.

To re-open the Multiprocess Summary Report for the active project, select the ( ) **Open Multiprocess Report** button in the upper-right of Multiprocess view, or from the context menu when right-clicking the project in the **Projects View** (page 120).

This report is only available in HTML format. There is no Tcl command available to generate this report manually.

For more information on how this report is used, see Running Multiple Flows in Parallel (page 307) and Attempting Likely Optimizations Using Option Sets (page 392).

# **Timing Results Summary Section**

The Timing Results Summary section of the report is only generated if either the "Run Post-Route Timing Analysis" or "Run Sign-off Timing Analysis" Flow Steps (page 235) are executed during the Multiprocess Flow.

#### 👍 Caution!

Any desired optional flow steps in the Flow View (page 55) must be enabled before Multiprocess execution is started.

The completed implementations in this section are sorted in approximate QoR order by their timing results. The implementation with the best results is at the top (also see the **get\_best\_multiprocess\_impl** (page 644) Tcl command.)

While an implementation is waiting to be executed or is currently executing, the Clock Domain column of the report contains a message to indicate the implementation execution status.

When an implementation has completed execution, the timing results for that implementation are populated in the Report. Much of the time, each implementation provides timing results (Upper-Limit Frequency, Worst Setup Slack, and Worst Hold Slack) for a single PVT combination (named in a column group header). However, when multiple PVT combinations are reported, each PVT will be shown under its own column group header in the summary report. The table cells containing results for the active PVT combination (the specific combination chosen for an implementation, which would otherwise be the only one reported) are shown in bold to differentiate from other PVT combinations shown for that implementation. (See Timing Across All Temperature Corners (page 266) for additional details about when multiple PVT corners will be reported for an implementation.)

The Upper-Limit Frequency, Worst Setup Slack, and Worst Hold Slack cells are independently color-coded to indicate whether the timing constraints were met for each of the defined clock domain/PVT combinations for that implementation. If the timing constraints were met for all clocks and all reported PVT combinations in an implementation, the Implementation Name cell is also color coded green to indicate success. If errors are encountered during flow execution, the appropriate Implementation Name cells are colored red, and " *(Flow Error)* " appears in that row.

Hyperlinks to each detailed Timing Report (page 245) are made available under the first clock domain Upper-Limit Frequency column for each PVT (one is created for each implementation for each reported PVT).

In some cases, some implementations provide Sign-Off timing results but other implementations do not. This difference can happen most often when some implementations are in Evaluation Flow Mode (page 243) while others are not. It may also happen when the multi-process flow is cancelled, or in rare flow error cases. When this mix of timing results from differing flow steps occurs, the column headings indicate that the report contains Sign-Off data. All earlier Post-Route timing results are footnoted to indicate that they are not showing Sign-Off data.

# **Runtime Results Summary Section**

This section of the report is always generated and indicates the total flow execution time and peak memory utilization for each implementation. The flow runtimes reported are wall-clock runtimes (not CPU times) harvested from the run logs. Rows in the table indicate whether an implementation flow execution is incomplete (running or still waiting to run), or has encountered errors.

Many factors affect runtimes:

- Selected Implementation Options (page 0) for an implementation (and thus the Option Sets (page 0)) can have a significant impact.
- The available processors, available memory, and total load on the workstation executing ACE have a significant impact.
  - On multi-user workstations, workstation load may vary widely over the multiprocess execution period.
  - Even on single-user workstations, if using a **Parallel Queue Count** greater than one, be aware that the lastexecuted implementation(s) likely can be executing (at least partially) with a reduced machine load compared to the first-executed implementations. As the parallel execution queue is emptied, new implementation processes are not started, thus fewer processes are executing, meaning that the lastexecuted implementations have the lowest contention for processing cores, caches, memory, I/O, etc.
- · Additionally, when using external cloud/grid/batch Job Submission systems:
  - The reported times do not include the time spent waiting in the external system queue(s). The runtimes reported only include time spent actually running the ACE flow.
  - The processor speeds and system loads may vary widely for the nodes running each job, making runtime comparisons difficult (at best).
  - If meaningful runtime comparisons are required, extra care must be taken to ensure that each node system load and hardware is identical for all jobs for the duration of the multiprocess session.

#### Caution!

Do not compare runtimes unless workstation hardware and system loads are identical for all implementations. Because of all of the limitations listed above, the reported implementation flow execution wall-clock times are intended to be used only as general guidelines, not as benchmarking times.

# Implementation Options Report

The Implementation Options Report provides information about available options for the currently active implementation. This report is not automatically generated by the Flow (page 235), but can be generated on demand using the report\_impl\_options (page 680) Tcl command.

By default, the report only displays the names, descriptions and default values of the most commonly used implementation options (meaning the subset which is shown within the **Options View** (page 100)). In addition, by default, the report displays the options applicable to the target device of the currently active implementation.

The -project and -impl arguments can be used to show the options applicable to a different project implementation.

The -show\_values argument can be used to include the current implementation value of each option in the report.

The -show\_all argument can be used to include all possible options for the specified implementation in the report, instead of only the most-commonly-used subset shown within the **Options View** (page 100).

#### (i) Note

The values of hidden options (those which are not shown in the GUI Options View) should only be altered after guidance from Achronix support.

# Advanced Concepts

The following are advanced concepts intended primarily for extremely experienced users, or users being actively guided by Achronix FAEs.

# ACE Verilog Attributes

This page lists various attributes that can be applied to instances, nets, pin, ports, or other objects in the ACE data model. Each attribute is listed with the type of object or objects to which it may be applied, and a description of how it effects the ACE synthesis, placement, and routing flow.

# locked

Applies to nets only.

Nets marked with this attribute are not unrouted by the run\_unroute command, or when the run\_route flow step is re-run on a routed design.

# fanout\_limit

Applies to nets only.

This is a dual-use property and can be applied globally and also individually to nets.

The global limit is specified with the fanout\_limit impl option.

When applied to an individual net, this attribute overrides the global limit. Net drivers are cloned, or buffer trees inserted, to keep each (non clock/reset) net fanout under this limit. Applies only when the fanout\_control impl option is enabled.

#### Note

ACE never inserts more fanout buffers than the maximum specified by the max\_buffer\_limit impl\_option.

In order to find the correct net name, if the name of the driving register is known, the following Tcl command can be used:

```
set_property fanout_limit 50 [ find {*} -nets -filter @driving_pin=[get_pins *<source
reg>*q] ]
```

# must\_keep

Applies to instances or nets.

The instance or net cannot be deleted by any of the netlist optimization flow commands.

#### (i) Note

If the instance or net is logically redundant, it might be left dangling with no input and no output connections.

### do\_not\_rewire

Applies to instances, nets, pins.

Rewiring permutes input pins among equivalent nets (i.e., nets in a tree of fanout-control buffers) to minimize wirelength and improve timing. This attribute disables rewiring for a given instance, net, or pin. Some rewiring can happen during run\_prepare, but the majority of changes are made after run\_place and run\_route. Subject to the prepnr\_rewire and postpnr\_rewire implementation options.

# do\_not\_clone

Applies to instances only.

Prevents a given instance from being cloned during fanout control optimization. However, fanout buffers may still be inserted for nets above the fanout\_limit.

### do\_not\_cluster

Applies to instances only.

Prevents an instance from being clustered during structural or timing-driven clustering. Structural clustering (enabled with the structural\_clustering\_mode implemenation option) creates clusters from groups of LUTs and Flops when certain pre-defined structures are encountered. Timing-driven clustering (enabled by the timing\_driven\_clustering implementation option) creates larger clusters from LUT-to-LUT and ALU-to-LUT connections to keep timing-critical net routing short. Instances in a cluster are placed together.

# clock\_type

Applies to nets or driver (output) pins.

Normally, this property is set on a net or driver (output) pin using the set\_clock\_type TCL command in the SDC constraints, but it can also be specified using this attribute. Applies globally to all target pins driven by that net or pin. For more information see the documentation for the set\_clock\_type (page 710) Tcl command. The

attribute must be a comma-separated list of the following strings: {"boundary", "trunk", "direct\_trunk", "minitrunk" (Speedcore only), "blocked", "data\_region", "data\_center", "data\_local", "branch\_fast", "branch\_nominal", "none", "low\_jitter", "local", "global", "immediate"}.

#### (i) Note

Not all attribute combinations make sense.

# local\_clock\_type

Applies to pins only.

Has all of the same properties as the clock\_type attribute above, but use this attribute when the type is being specified for a specific target (input) pin, and the routing type needs to be different than the global value specified for the driving net/pin. Useful for certain kinds of data-generated clocks: parts of the clock that feed back should be "data" but the rest should be "data\_region" or "data\_center".

# ace\_useioff

Applies to ports, nets, I/O pin instances, or flop-flop instances.

Depending on the value of the push\_flops\_into\_pads implementation option, the presence of this property causes boundary flop-flop instances to be pushed into the attached input or output pin instance. For more information see the Automatic Flop Pushing into I/O Pins (page 452) section.

### ace\_virtualize

Applies to ports only.

Allows specifying which ports and port busses are virtualized when ACE is run in evaluation flow mode, and when the design contains more top level ports than available I/O pads/pins. For more information see the **Working with Virtual I/O** (page 460) section.

# ace\_virtualize\_clock\_port

Applies to ports only.

When the virtual\_io\_style implementation option is set to the value serialize\_dff, allows specifying the top-level port name to be connected to the clock input of the new serialization flop instances. Cannot be used with the ace\_virtualize\_clock\_net attribute (they are mutually exclusive). For more information see the Working with Virtual I/O (page 460) section.

# ace\_virtualize\_clock\_net

Applies to ports only.

When the virtual\_io\_style implementation option is set to the value serialize\_dff, allows specifying the top-level net name to be connected to the clock input of the new serialization flop instances. Cannot be used with the ace\_virtualize\_clock\_port attribute (they are mutually exclusive). For more information see the Working with Virtual I/O (page 460) section.

### async\_capture

Applies to a DFF "d" input pin only.

Suppresses setup-and-hold checks at the input pin of a DFF instance during Standard Delay Format (SDF) export for the Timing Annotated Gate Level Simulation flow. This attribute is used on the capture flop of user-supplied clock domain crossing synchronizer macros. For more information, refer to the relevant IP Component Library User Guide for that product family.

# location

Applies to instances only.

A string attribute giving the site name on which the instance is to be pre-placed. Equivalent to the "set\_placement -fixed" PDC constraint.

# **Clock Regions**

Device fabrics deal with numerous clocks. Due to physical routing limitations, only a finite number of clocks can be routed to each individual site within the fabric. To keep the placement/routing problem space manageable for the most complex designs, a fabric is divided up into Clock Regions of a relatively coarse granularity, where each Clock Region as a whole allows a finite number of clocks to be routed within that clock region.

Each fabric is divided up into a number of Clock Regions of roughly similar area. The exact numbers of clock regions, the dimensions of each region, the number and types of sites within the region, the allowed sources of the clocks routed to each region, and the differences (like skew) of clock behavior between clock regions all are specified by the chosen target device. A subset of this information is presented in the **Clock Regions View** (page 25). See the technical specification of the target device for complete details.

For designs with an extremely large number of clocks, the use of **Placement Regions and Placement Region Constraints** (page 394) may be necessary to guide placement decisions regarding Clock Regions. This should be discussed thoroughly with an Achronix FAE first, as improper use of Placement Region Constraints can lower QOR or even cause Placement or Routing to become unsolvable.

# **Instance States**

An individual Instance can have a variety of states simultaneously in ACE; only the highest priority state is used to color the Instance in the Floorplanner View (page 45). The states are listed below in the default render priority order. Higher priority states (earlier in the table) take precedence over lower priority states (later in the table). For example, if an instance has Fixed Placement and is also Selected, the Selection color has priority, and the Selection color is used to paint the instance.

Additionally, several of the states have associated icons, which normally are displayed alongside the instance when the instance appears in tables and lists, as in the **Search View** (page 133), **Selection View** (page 137), and **Netlist Browser View** (page 81). Similar to the colors, when multiple simultaneous states are involved, the highest priority icon available is used. Thus, an instance that is both Fixed and Locked uses the Fixed icon, while an instance that is both Selected and Fixed also uses the Fixed icon (because the higher priority Selected state has no corresponding icon).

| Priority | State                       | Default Color  | lcon | Description                                                                                                                                                                                                                                                                                                                |
|----------|-----------------------------|----------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1        | Selected                    | bright green   | -    | This instance has been added to the ACE<br>Selection Set, typically either by using the<br>Selection View (page 137) or the Tcl<br>select (page 709) command. For more<br>information, see Selecting Floorplanner<br>Objects (page 340).                                                                                   |
| 2        | Highlighted                 | (user-defined) | -    | An instance chosen to Highlight, typically<br>by using the Highlight Instance<br>commands in one of the views within the<br>Floorplanner Perspective, or by the<br>highlight (page 665) Tcl<br>command. See <b>Highlighting Objects in</b><br><b>the Floorplanner View</b> (page 342) for more<br>information              |
| 3        | Overassigned Site           | bright red     | _    | An instance that shares a site assignment<br>with another instance. Since a site can<br>only legally contain a single instance, this<br>is an error state.                                                                                                                                                                 |
| 4        | Fixed Placement             | bright yellow  | â    | An instance whose site assignment has<br>been marked as "fixed". As long as an<br>instance is defined with hard fixed<br>placement, ACE does not change the site<br>assignment for that instance during the<br>Placement phase of PnR. For more<br>information, see <b>Placing an Object (page</b><br>346).                |
| 5        | Locked Placement            | dark yellow    | *    | An instance that is a member of a Locked<br>Partition that has remained unchanged<br>since the prior incremental<br>compilation. ACE does not change the site<br>assignment for that instance during the<br>Placement phase of PnR. For more<br>information, see Using Incremental<br>Compilation (Partitions) (page 404). |
| 6        | Default (Soft)<br>Placement | dark grey      | ~    | A placed instance with no other specially defined state is displayed in this manner.                                                                                                                                                                                                                                       |

| Priority | State    | Default Color | lcon | Description                                                |
|----------|----------|---------------|------|------------------------------------------------------------|
| 7        | Unplaced | -             | Θ    | An instance without a current site assignment (placement). |

#### (i) Note

The colors mentioned are the default colors. These colors may be modified on the **Floorplanner View Colors** and Layers Preference Page (page 198). On that same preference page, it is possible to toggle whether some states are shown at all, and to partly alter the render priority of some states.

# **Filter Properties**

Several Tcl commands [find (page 638), filter (page 637)] allow Tcl command-line filtering of object lists. Additionally, the Search Filter Builder dialog (page 189) performs a similar function for the Search view (page 133) in the ACE GUI.

The allowed filtering properties, operators, and values (where applicable) are as follows:

| Property Name                | Operators | Values           | Description                                                                                                                                                                                                    |
|------------------------------|-----------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| @async_reset                 | =         | true, false      | Allows filtering ports, nets, and pins based on whether they connect to an async reset.                                                                                                                        |
| @attribute                   | =         | property : value | Allows filtering instances, nets, and ports<br>based on verilog attribute/defparam<br>values. Values of the @attribute filter must<br>be a property-value pair separated by a<br>semicolon (i.e., prop:value). |
| @clock                       | =         | true, false      | Allows filtering ports, nets, and pins based on whether they connect to a clock net.                                                                                                                           |
| @clock_as_data               | =         | true, false      | Allows filtering instances and nets based on<br>whether they have any data pins being driven<br>by a clock signal.                                                                                             |
| @clock_domain <sup>(1)</sup> | =         | clockDomainName  | Allows filtering instances, nets, paths, and pins based on clock domain name.                                                                                                                                  |

# Table 124 · Supported Filter Properties

| Property Name    | Operators | Values                            | Description                                                                                                                                              |
|------------------|-----------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| @clock_region    | =         | clockRegionName                   | Allows filtering instances, nets, paths, sites,<br>and pins based on clock region name. Some<br>nets and paths may be part of multiple clock<br>regions. |
| @data_as_clock   | =         | true, false                       | Allows filtering nets based on whether they have any clock pins being driven by a data signal.                                                           |
| @direction       | =         | in, out, inout                    | Allows filtering ports and pins based on direction.                                                                                                      |
| @driver_type     | =         | (device-dependent)                | Allows filtering nets and pins based on the type (cell name) of the driving instance.                                                                    |
| @driving_net     | =         | netName                           | Allows filtering instances based on a net name that is driving them.                                                                                     |
| @driving_pin     | =         | pinName                           | Allows filtering instances and nets based on the name of a pin that is driving them.                                                                     |
| @enable          | =         | true, false                       | Allows filtering ports, nets, and pins based on whether they connect to an enable signal.                                                                |
| @fanout          | =, <, >   | (integers > 0)                    | Allows filtering nets and pins based on the<br>number of fanout connections. Valid @fanout<br>values must be integers greater than 0.                    |
| @fixed_placement | =         | true, false                       | Allows filtering instances based on whether placement is fixed.                                                                                          |
| @partition       | =         | partitionName                     | Allows filtering instances, nets, paths, and pins based on partition name.                                                                               |
| @placed          | =         | true, false                       | Allows filtering instances, nets, and pins<br>based on whether they are placed. In this<br>context, "placed" means the net is routed.                    |
| @power           | =, <, >   | (floating point<br>numbers > 0.0) | Allows filtering nets based on power<br>consumption. Valid @power values must be a<br>floating point number greater than 0.0.                            |

| Property Name | Operators | Values              | Description                                                                                                                                                                                                                                                          |  |
|---------------|-----------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| @power_rank   | =, <, >   | (integers ≥ 0)      | Allows filtering nets based on the level of<br>power consumption relative to other<br>nets. The most power-consuming net is<br>ranked 1 while the least power consuming net<br>is ranked n. Valid @power_rank values must<br>be integers greater than or equal to 0. |  |
| @region       | =         | placementRegionName | Allows filtering instances, nets, paths, and pins based on placement region name.                                                                                                                                                                                    |  |
| @reset        | =         | true, false         | Allows filtering ports, nets, and pins based on whether they connect to a reset signal.                                                                                                                                                                              |  |
| @sink_type    | =         | (device-dependent)  | Allows filtering nets and pins based on the type (cell name) of instance(s) the net is driving.                                                                                                                                                                      |  |
| @type         | =         | (device-dependent)  | Allows filtering instances based on the type (cell name) of the instance.                                                                                                                                                                                            |  |

#### **Table Notes**

1. Some instances may be part of multiple clock domains, such as a CDC instance.

# **Timing Across All Temperature Corners**

ACE supports place and route across all temperature corners, as well as reporting timing across all temperature corners of interest for a given place-and-route result at a specific junction temperature. This allows the designer to confirm whether the optimized placed-and-route result is able to close timing at the desired frequency ( $F_{MAX}$ ) at all temperature corners of interest.

# **Temperature Corners and Place and Route**

### (i) Note

By default, ACE only optimizes place and route for a single user-chosen temperature corner per implementation. If it is desired to optimize place and route for multiple temperatures, the impl-option pnr\_optimize\_corners should be enabled (set to 1).

If pnr\_optimize\_corners is zero (disabled, the default), ACE requires setting the desired junction temperature at which the design is placed and routed for the target  $F_{MAX}$ . This selected junction temperature is used to load the corresponding timing libraries and to optimize the place and route to close timing at the requested frequency.

If pnr\_optimize\_corners is not zero (and is thus enabled), the timing libraries for all corners will be used to optimize the place and route, though ACE still requires that a single junction temperature be chosen (for use during Timing Analysis and the generated timing reports for the early flow steps).

Be warned that the value of pnr\_optimize\_corners has no impact upon the generated Timing Report (page 245)s. The number of corners included in the generated timing reports is influenced only by the Flow Steps (page 235) and the chosen Flow Mode (page 243).

# **Temperature Corners and Timing Analysis/Reports:**

When the Flow Mode is set to **Evaluation**, this will force all timing analysis to report only a single temperature corner, even for the Sign Off Timing Report, regardless of other settings. (The single corner will be the one corresponding to the implementation option junction\_temperature, shown as **Design Preparation**  $\rightarrow$  **Junction Temperature** in the **Options View** (page 100).)

When the Flow Mode is set to **Normal** or **Strict**, after all DRC checks have passed (see the **Run Final DRC Checks** flow step), results are sufficiently accurate that timing analysis results will be generated for all relevant temperature corners. This is needed because any given corner might be worse than any other given the underlying hardware technology used (due to the effects of temperature inversion). Keep in mind that prior to passing the DRC checks, timing analysis results will still only be generated for a single temperature corner, the one corresponding to the implementation option junction\_temperature, shown as **Design Preparation**  $\rightarrow$  **Junction Temperature** in the Options View.

|                         | Estimated Timing<br>Analysis Report | Post-Placement<br>Timing Analysis<br>Report | Post-Route<br>Timing Analysis<br>Report | Sign-off (Final)<br>Timing Analysis<br>Report |
|-------------------------|-------------------------------------|---------------------------------------------|-----------------------------------------|-----------------------------------------------|
| Evaluation Flow<br>Mode | 1 corner                            | 1 corner                                    | 1 corner                                | 1 corner                                      |
| Normal Flow<br>Mode     | 1 corner                            | 1 corner                                    | 1 corner                                | all corners                                   |
| Strict Flow<br>Mode     | 1 corner                            | 1 corner                                    | 1 corner                                | all corners                                   |

# Table 125 • Number of temperature corner timing reports generated (as influenced by Flow Mode and Flow Step)

The value of pnr\_optimize\_corners does not influence the number of temperature corners generated for any of the timing reports.

When reports are generated for multiple corners, the report file names are extended with a suffix describing the PVT corner contained within the report. The suffix includes the speed grade, the voltage, and the temperature, in that order, separated by underscores: \_<speed\_grade>\_<voltage>\_<junction\_temp>

For example:

- \_C1\_1p00V\_85C corresponds to: speed grade = C1; voltage = 1.00V; junction temperature = 85°C
- \_C2\_0p70V\_n40C corresponds to: speed grade = C2; voltage = 0.70V; junction temperature = -40°C

#### i Note

The Power Dissipation Report (page 246)s are generated for each temperature corner as well.

Currently, the only way to see a single report summary for multiple temperature corners at once is through the **Multiprocess Summary Report** (page 256). Keep in mind that even when using the Multiprocess feature, each individual implementation being run will still follow all the temperature corner processing rules mentioned above. Using Multiprocess does not change any of the above temperature corner optimization/analysis rules.

# ECO Commands

# ECO Use Cases

The ECO Command Tool Chain is a set of useful tools that allow editing a design with a high level of granularity. These tools can be used to achieve highly specific goals, such as manually adding logic blocks to the fabric, improving timing, performing analysis on the FPGA itself, and more.

# **Net Legality Definition**

Throughout this documentation, the concept of *net legality* is mentioned frequently. For a net to be legal, all of the following must be true:

- · There is exactly one and only one driving/output pin connected to the net.
- There is at least one input/sink pin connected to the net.
- All instances to which the net connects must be placed (with the exception of their respective site pins which do not need to be placed).

When a net is *legal*, the router may route the net. An *illegal* net causes the router to silently exit. When performing ECO changes, it is necessary to tie-off and/or correct any nets that become illegal. ECO commands indicate illegal nets caused by each ECO command, including why such nets were deemed illegal. It is necessary to manually keep track of such nets and correct them along the way.

# Disclaimers

#### 👍 Caution!

ECO commands are intended for advanced users only. Use at your own risk!

ECO commands are intended to be performed at the end of the place-and-route Flow Steps (page 235). Performing ECO before or during place-and-route is possible, but this requires more caution.

Although optional, it is highly recommended to specify the name of a site when inserting an instance, or else ACE refuses to perform net-routing with nets connected to unplaced instances. If desired, optionally execute

run\_place after instance insertion to let ACE handle placement automatically. The flow step run\_place:

- May perform automatic placement of an ECO-inserted instance, but if the new instance is deemed redundant or useless by the ACE reconditioner, it is removed from the design.
- Is not incremental; it always places all instances in the design, which can be time consuming. As such, when using ace\_eco::insert\_instance, consider placing the new instance manually.

While performing ECO, certain nets may become partially routed (i.e., calling rewire\_net -connect without specifying -reroute) or derouted (i.e., the nets lost a pin connection that kept them legal). In these circumstances, a warning is displayed on the Tcl console. All such illegal nets must be identified and resolved before proceeding.

When any illegal nets have been made legal (a driver added to a floating net, a sink pin added to a dangling net, drivers removed from a multi-driven net), rewire\_net <netName> -reroute must be called to physically create the connections specified in the ECO-modified netlist.

If it is decided to perform run\_prepare after performing ECO, all changes made are overwritten since run\_prepare sources the original netlist(s) specified in the ACE project, but not any ECO modifications. As such, keep in mind that all work might be accidentally undone by calling run\_prepare.

Running ECO commands but failing to resolve issues created by the resulting changes may potentially lead to errors within ACE if certain functions are subsequently called. For instance, a set of ECO commands could disconnect an output pin from a net, but fail to connect a new one. If another (non-ECO) command is then called that assumes that each net has a driving pin, ACE reports errors.

ECO commands modify the gate-level netlist generated from run\_prepare, and rerunning run\_place or run\_route with a modified netlist may lead to unintended consequences to the design.

#### 🕑 Tip

It is recommended to save often when performing ECO as inadvertently executing a wrong command may either break the design beyond repair or cause ACE to report errors, forcing a restart from scratch.

# ECO Commands

The ECO commands are all in a special ace\_eco:: Tcl Namespace; they are not included in the global namespace. These commands are

- ace\_eco::delete\_instance
- ace\_eco::delete\_net
- ace\_eco::get\_instance\_pins
- ace\_eco::insert\_instance
- ace\_eco::insert\_net
- ace\_eco::rewire\_instance
- ace\_eco::rewire\_net

### delete\_instance

```
Command Syntax
ace_eco::delete_instance {<i:instance_name> <i:instance_name> ...} [-reroute]
```

The delete\_instance command deletes the named instances and disconnects the pins of those instances from their respective nets. Any nets left with no connections are not automatically deleted. These nets must be deleted manually using ace\_eco::delete\_net.

#### Table 126 · delete\_instance Arguments

| Arg Name                | Optional | Description                                                                                    |
|-------------------------|----------|------------------------------------------------------------------------------------------------|
| <instances></instances> | No       | List of user design instances to be deleted. The "i:" prefix is optional on each instance.     |
| [-reroute]              | Yes      | The optional -reroute argument is used to re-route nets after the instances have been deleted. |

#### delete\_net

| Command Syntax                                                                       |  |
|--------------------------------------------------------------------------------------|--|
| <pre>ace_eco::delete_net {<n:net_name> <n:net_name>}</n:net_name></n:net_name></pre> |  |

The delete\_net command deletes the named nets.

### Table 127 • delete\_net Arguments

| Arg Name      | Optional | Description                                                                      |
|---------------|----------|----------------------------------------------------------------------------------|
| <nets></nets> | No       | List of user design nets to be deleted. The "n:" prefix is optional on each net. |

# get\_instance\_pins

| Command Syntax                                                                                                  |
|-----------------------------------------------------------------------------------------------------------------|
| <pre>ace_eco::get_instance_pins {<i:instance_name> <i:instance_name>}</i:instance_name></i:instance_name></pre> |

The get\_instance\_pins command returns a list of all pins (and nets, if connected) for the named instances. The returned lists takes the form of:

{{t:instance1:pin1 n:net1} {t:instance1:pin2 n:net2} {t:instance1:disconnected\_pin3}}
{{t:instance2:pin1 n:net1} ...}

#### Table 128 • get\_instance\_pins Arguments

| Arg Name                | Optional | Description                                                                                |
|-------------------------|----------|--------------------------------------------------------------------------------------------|
| <instances></instances> | No       | List of user design instances to be queried. The "i:" prefix is optional on each instance. |

### insert\_instance

| Command Syntax                                                                                                                                                                                                                                                            |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ace_eco::insert_instance <i:instance_name> <cell_type_name> [-site <s:site_name>] [-pins<br/>{{<p:pin_name> <n:net_name>} {<p:pin_name> <n:net_name>}}] [-parameters</n:net_name></p:pin_name></n:net_name></p:pin_name></s:site_name></cell_type_name></i:instance_name> |
| {{ <param_name> <param_value>} {<param_name> <param_value>}}] [-fixed] [-reroute]</param_value></param_name></param_value></param_name>                                                                                                                                   |

The insert\_instance command generates a new instance of the specified cell type and inserts it into the netlist. If -site is specified, the command places the new instance on the named site (given that the site is legal to use).

#### Table 129 • insert\_instance Arguments

| Arg Name                          | Optional | Description                                                                                                                                                                                                                    |
|-----------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <instance_name></instance_name>   | No       | The name which is given to the newly inserted instance.<br>The "i:" prefix is optional.                                                                                                                                        |
| <cell_type_name></cell_type_name> | No       | Type of instance. This must be a valid cell type for the current fabric.                                                                                                                                                       |
| -site                             | Yes      | The optional -site argument names the site where the<br>new instance is placed. The site named must be compatible<br>with the cell type, or the command aborts before the<br>instance is created. The "s:" prefix is optional. |
| -pins                             | Yes      | The optional –pins argument specifies a list of pin name/<br>net name pairs. Each named pin is connected to the<br>associated named net. The "p:" and "n:" prefixes are<br>optional.                                           |

| Arg Name    | Optional | Description                                                                                                                                                                                                                 |
|-------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -parameters | Yes      | The optional -parameters argument specifies a list of<br>user parameters and values for the new instance. The<br>parameters must be compatible with the cell type, or the<br>command aborts before the instance is created. |
| -fixed      | Yes      | The optional – fixed argument indicates that given a -site parameter, the newly created instance is fixed to that site. By default, Soft Placement is performed (no fixing).                                                |
| -reroute    | Yes      | The optional -reroute argument is used to re-route nets after the instance has been inserted.                                                                                                                               |

### A Warning!

- $\cdot\,$  The instance name is currently not verified to follow Verilog/VHDL identifier standards.
- Although optional, it is highly recommended to specify the name of a site when inserting an instance; otherwise, ACE refuses to route pins with an unplaced instance.

### insert\_net

| Command Syntax                                                                                                                                                           |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ace_eco::insert_net <n:net_name> {<t:instance_name:pin_name><br/><t:instance_name:pin_name>} [-route]</t:instance_name:pin_name></t:instance_name:pin_name></n:net_name> |

The insert\_net command creates a new net and insert it into the netlist. This new net must have at least two connections specified, and these connections must make the net legal.

### Table 130 · insert\_net Arguments

| Arg Name              | Optional | Description                                                                                                                                   |
|-----------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| <net_name></net_name> | No       | The name to be given to the newly inserted net. The "n:" prefix is optional.                                                                  |
| <pins></pins>         | No       | List of fully-qualified (including instance) pin names. Each<br>named pin is connected to the new net. The "t:" pin prefixes<br>are optional. |
| -route                | Yes      | The optional -reroute argument is used to automatically route the new net after it has been inserted.                                         |

#### A Warning!

- The new net name is currently not verified to follow Verilog/VHDL identifier standards.
- The insert\_net command does not connect to pins already connected to a net; those pins must be disconnected first before calling this command.
- The user-specified net must be legal (has at least one input pin and exactly one driving pin) upon creation, or else the net is not created. However, instances which the new net connects to do not have to be placed.

### rewire\_instance

| Command Syntax                                                                                                                                                                       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>ace_eco::rewire_instance <i:instance_name> "{<p:pin_name> [n:net_name]} {<p:pin_name> [n:net_name]}" [-reroute] [-disconnect]</p:pin_name></p:pin_name></i:instance_name></pre> |

The rewire\_instance command allows connecting or disconnecting the pins of an instance to/from specific nets. Both of these operations can be performed at the same time. Connections from user-specified nets to user-specified pins may be created, deleted, or changed.

#### Table 131 • rewire\_instance Arguments

| Arg Name                        | Optional | Description                                                                                                                                                                                        |
|---------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <instance_name></instance_name> | No       | The name of the instance whose wiring is to be changed.<br>The "i:" prefix is optional.                                                                                                            |
| <pin_net_pairs></pin_net_pairs> | No       | List of user design pins/ports paired with the optional<br>nets to which each are to be connected. The "p:" and "n:"<br>prefixes are optional.<br>Example: ' '{pin1 net1}<br>{disconnected_pin2}'' |
| -reroute                        | Yes      | The optional -reroute argument is used to re-route nets after the instance has been inserted.                                                                                                      |
| -disconnect                     | Yes      | The optional -disconnect argument causes all existing connections to be disconnected before applying new pin/ net connections.                                                                     |

#### (i) Note

- If a named pin/net connection already exists as specified, that argument is safely ignored.
- If a pin name is provided without a net name, that pin is disconnected from any currently connected net.
- If -disconnect is used with an empty pin\_net list, all prior connections are removed without any new connections being created.

#### rewire\_net

#### **Command Syntax**

```
ace_eco::rewire_net <n:net_name> [-connect "<p:pin_name> | <n:net_name> ... "] [-
disconnect "<p:pin_name> ..." ] [-clocktype <type>] [-reroute] [-verbose]
```

The rewire\_net command allows connecting/disconnecting pins from the specific net. The same action could also be accomplished with ace\_eco::rewire\_instance commands, but that can quickly become very cumbersome if most of the pins on one net should now connect to another net. A single ace\_eco::rewire\_net command can do the work that would require hundreds of ace\_eco::rewire\_instance commands, each specifying the same net.

#### (i) Note

The command rewire\_net may be used on a net with no arguments except for -reroute, to perform routing on the specified net. This option is useful for cleanup work as it is necessary to route any remaining partially or unrouted nets.

| Arg Name              | Optional | Description                                                                                                                                                    |
|-----------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <net_name></net_name> | No       | The name of the net whose wiring is to be changed. The "n:" prefix is optional.                                                                                |
| -connect              | Yes      | The optional –connect argument specifies a list of pins to be connected to a net. If already connection, they are first disconnected from their original nets. |
| -disconnect           | Yes      | The optional -disconnect argument specifies a list of pins that should be disconnected from net.                                                               |
| -clocktype            | Yes      | The optional -clocktype argument indicates the clock type of the pins to be connected.                                                                         |

#### Table 132 • rewire\_net Arguments

| Arg Name | Optional | Description                                                                                   |
|----------|----------|-----------------------------------------------------------------------------------------------|
| -reroute | Yes      | The optional -reroute argument is used to re-route nets after the instance has been inserted. |
| -verbose | Yes      | The optional -verbose argument generates additional feedback as the command is running.       |

# **GUI Support**

GUI support for ECO functionality is hidden by default. To enable ECO actions in the GUI, enable the checkbox found at: Window  $\rightarrow$  Preferences  $\rightarrow$  User Advanced Preferences  $\rightarrow$  Enable ECO Functionality.

When enabled, ECO actions for the ECO commands appear in right-click context menus available on most views in the Floorplanner Perspective. For example, right-click a net to display the available ECO net commands; right-click an instance to display available ECO instance commands, etc.

### 👍 Warning!

The GUI ECO wizards do not provide extra safety checks or guidance at this time. Errors, warnings, and success feedback from the ECO changes are only shown in the **Tcl Console View** (page 146) as the ACE ECO Tcl commands themselves are executed by the wizards.

| ÷              | Add Instance to Selection                         |
|----------------|---------------------------------------------------|
|                | Highlight Instance                                |
|                | Choose Highlight Color for next Highlight command |
| Q              | Zoom To Instance                                  |
|                | Show Instance in Netlist                          |
| ≡              | Display Properties for Instance                   |
| ۵              | Fix Placement of Instance                         |
|                | Unplace Instance                                  |
| ÷              | ECO: Insert Net                                   |
| ۹,             | ECO: Insert Instance                              |
| }∘             | ECO: Rewire Instance                              |
| ବ              | ECO: Clone Instance                               |
| ×              | ECO: Delete Instance                              |
| <mark>م</mark> | Configure view                                    |

Figure 130 • Example of ECO Instance Commands in Context Menu

# Add Instance Pin Dialog

| O Add I   | nstance Pi | n  |   |        | ×   |
|-----------|------------|----|---|--------|-----|
| Instance: | inb1_int[3 | 3] |   |        | ] 🗸 |
| Pin:      | ck         |    |   |        | ~   |
|           |            |    |   |        |     |
|           |            | 0  | К | Cancel |     |

The Add Instance Pin Dialog selects an existing pin to add to an existing instance.



#### Table 133 • Add Instance Pin Dialog Fields

| Field    | Description                                                                                                                            |
|----------|----------------------------------------------------------------------------------------------------------------------------------------|
| Instance | A valid instance name. If an invalid name is specified, the green check mark next to the Instance field changes to indicate the error. |
| Pin      | A list of the instance pins.                                                                                                           |

# ECO Insert Instance Dialog

The ECO Insert Instance Dialog allows the addition of a new instance.

| O ECO Insert Insta                                        | ince — 🗆 X                                                                 |
|-----------------------------------------------------------|----------------------------------------------------------------------------|
| nter the inform                                           | ation for the new Instance, then press Finish.                             |
| nstance Name:                                             | and_b9                                                                     |
| Cell Type:                                                | LUT4 ~                                                                     |
| Site Name (optiona                                        | i):                                                                        |
| Pin/Net Connectio                                         | ns (optional) (pins without nets will be ignored):                         |
| Pin                                                       | Net                                                                        |
| din0                                                      | inb1_int_ret_0o                                                            |
| din1                                                      | inb1_int_ret_0o_0                                                          |
| din2                                                      | inb1_int_ret_0o_1                                                          |
| din3                                                      | inb1_int_ret_0o_2                                                          |
| dout                                                      | reg_and_b9_reto                                                            |
| Parameter<br>config_input_inv<br>location<br>lut_function | ptional) (names without values will be ignored): Value 4'b0000 "" 16'h0000 |
| permuted                                                  | III                                                                        |
| Immediately rou                                           | Ite after instance insertion                                               |
| 0                                                         | <u>F</u> inish Cancel                                                      |

# Figure 132 • ECO Insert Instance Dialog Example

# Table 134 · ECO Insert Instance Dialog Fields

| Field         | Description                                                                                                                                                                                                  |  |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Instance Name | The name for the new instance. The name must be unique to the design. If an instance with the given name already exists, the green check mark next to the Instance Name field changes to indicate the error. |  |

| Field                                      | Description                                                                                              |  |
|--------------------------------------------|----------------------------------------------------------------------------------------------------------|--|
| Cell Type                                  | The cell type for the new instance.                                                                      |  |
| Site Name (optional)                       | The name of the site where the new instance should be placed.                                            |  |
| Pin/Net Connections                        | Click a cell in the Net column to connect a pin to an existing net.                                      |  |
| User Parameters (optional)                 | Click a cell in the Value column to specify a parameter value.<br>Parameters without values are ignored. |  |
| Immediately route after instance insertion | If enabled, the design is rerouted immediately after the new instance is inserted.                       |  |

# ECO Insert Net Dialog

The ECO Insert Net Dialog allows the addition of a new net.

| C ECO: Ins  | ert Net                                       | — D          | ×        |
|-------------|-----------------------------------------------|--------------|----------|
| Enter the i | nformation for the new net, then press Finish | h.           | Ŀ,       |
|             |                                               |              |          |
| Net Name:   | bypass_2                                      |              | <b>~</b> |
|             |                                               |              |          |
| Instance    | Pin                                           | 🕂 Add Pin    |          |
| and_b1      | dout                                          | 💢 Remove Pin |          |
| inb1_int[3] | d                                             |              |          |
|             |                                               |              |          |
|             |                                               |              |          |
|             |                                               |              |          |
|             |                                               |              |          |
|             |                                               |              |          |
|             |                                               |              |          |
|             |                                               |              |          |
| 🗹 Immedia   | tely reroute after insert                     |              |          |
| ?           |                                               | <u> </u>     |          |

Figure 133 • ECO Insert Net Dialog Example

# Table 135 • ECO Insert Net Dialog Fields

| Field                            | Description                                                                                                                                                                                        |
|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Net Name                         | The name for the new net. The name must be unique to the design.<br>If a net with the given name already exists, the green check mark<br>next to the Net Name field changes to indicate the error. |
| Add Pin                          | The Instance Pins table in the dialog lists the pins to which the new nets are connected. Use the <b>Add Pin</b> button to add pins to this table.                                                 |
| Remove Pin                       | Use the <b>Remove Pin</b> button to remove all currently selected pins from the Instance Pins table.                                                                                               |
| Immediately reroute after insert | If enabled, the design is rerouted immediately after the new net is inserted.                                                                                                                      |

# ECO Rewire Instance Dialog

The ECO Rewire Instance Dialog allows adjusting the properties of an existing instance.

| ECO Rewi    | re Instance                          | —                             |       | × |
|-------------|--------------------------------------|-------------------------------|-------|---|
| nter the ne | ew wiring information for the        | e instance, then press Finish |       |   |
| nstance Nan | ne: and_b1                           |                               |       |   |
| Cell Type:  | LUTs                                 |                               |       |   |
|             |                                      |                               |       |   |
| in/Net Conr | nections (optional) (pins without r  | nets will be ignored):        |       |   |
| Pin         | Net                                  |                               |       |   |
| din0        | inb1_int_ret_0o                      |                               |       |   |
| din1        | inb1_int_ret_0o_0                    |                               |       |   |
| din2        | inb1_int_ret_0o_1                    |                               |       |   |
| din3        | inb1_int_ret_0o_2                    |                               |       |   |
| dout        | reg_and_b1_reto                      |                               |       |   |
|             |                                      |                               |       |   |
| Force Disc  | connect of all prior nets before rew | viring                        |       |   |
| ✓ Immediate | ely reroute after rewiring           |                               |       |   |
|             | ·,····,                              |                               |       |   |
|             |                                      |                               |       |   |
| 0           |                                      | Finish                        | Cance |   |

Figure 134 • ECO Rewire Instance Dialog Example

### Table 136 • ECO Rewire Instance Dialog Fields

| Field                                              | Description                                                                                 |  |  |
|----------------------------------------------------|---------------------------------------------------------------------------------------------|--|--|
| Pin/Net Connections                                | Click a cell in the Net column to connect the pin to a different net.                       |  |  |
| Force disconnect of all prior nets before rewiring | Causes all existing connections to be disconnected before applying new pin/net connections. |  |  |
| Immediately route after instance insertion         | If enabled, the design is rerouted immediately after the new instance is inserted.          |  |  |

# **ECO Rewire Net Dialog**

The ECO Rewire Net Dialog allows an existing net's pin connections to be adjusted.

| C ECO: Rewire | Net - bypass_2                                     | - | — |        | ×     |
|---------------|----------------------------------------------------|---|---|--------|-------|
| Enter the new | wiring information for the net, then press Finish. |   |   |        | 3     |
|               |                                                    |   |   |        |       |
| Net Name: byp | ass_2                                              |   |   |        |       |
| Instance      | Pin                                                |   | 4 | Add P  | Pin   |
| and_b1        | dout                                               |   | * | Remove | - Pin |
| inb1_int[3]   | d                                                  |   | ~ | Remov  |       |
|               |                                                    |   |   |        |       |
|               |                                                    |   |   |        |       |
|               |                                                    |   |   |        |       |
|               |                                                    |   |   |        |       |
|               |                                                    |   |   |        |       |
|               |                                                    |   |   |        |       |
|               |                                                    |   |   |        |       |
|               |                                                    |   |   |        |       |
| Immediately   | reroute after rewire                               |   |   |        |       |
| 0             | <u> </u>                                           | ı |   | Cance  | el    |

Figure 135 • ECO Rewire Net Dialog Example

### Table 137 • ECO Rewire Net Dialog Fields

| Field                            | Description                                                                                                                         |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Add Pin                          | The Instance Pins table in the dialog lists the pins to which the new net is connected. Click this button to add pins to the table. |
| Remove Pin                       | Click this button to remove all currently selected pins from the Instance Pins table.                                               |
| Immediately reroute after insert | If enabled, the design is rerouted immediately after the Insert Net dialog is completed.                                            |

### Fabric Clusters

Device fabrics in the Achronix Speedster and Speedcore families consist of a device-specific pattern of functional resources called tiles. For example, reconfigurable logic block (RLB) tiles contain LUT, DFF, and ALU sites. BRAM tiles contain block RAM sites. The tiles are arranged in rows and columns, with all columns in the device core (not including the I/O ring) consisting of identical tile types. The arrangement of tiles into columns may look somewhat irregular (i.e., 5 columns of LUTs, a BRAM column, 5 more columns of LUTs, and an LRAM column). However, at a coarse level, those tile arrangements do follow a regular pattern. All fabrics are constructed by arranging rows and columns of tiles into a basic unit of layout called a fabric cluster. A complete device is created by replicating the fabric clusters into a larger grid of rows and columns. For example, the Speedster7t AC7t1500 has 8 rows and 10 columns of fabric clusters, for a total of 80. See the *Speedster7t FPGA Datasheet* (DS015) for additional details.

All fabric clusters are identical, containing exactly the same pattern of tile rows and columns. The exact numbers of fabric clusters, the dimensions of each cluster, and the arrangement and types of tiles within each cluster, are all specified by the chosen target device. A designer can make use of this regularity if the design consists of a number of identical cores. If the cores are designed to fit exactly within one or more fabric clusters, a complete design can be created by replicating that core multiple times across the device using the fabric cluster grid.

The use of **placement regions and placement region constraints** (page 394) might be necessary to guide the placement of multi-core designs in order to align them with the fabric cluster grid. This should be discussed thoroughly with an Achronix FAE first, as improper use of placement region constraints can lower QOR or even cause placement or routing to become unsolvable.

## Chapter 4 : Tasks

While the **Concepts** (page 6) section was primarily concerned with which features exist in ACE, this Tasks section is concerned with how features in ACE may be best utilized.

## **Running ACE**

ACE can be run with full functionality in three different modes:

- GUI Mode (page 282)
- Command-line Mode (page 282)
- Batch Mode (page 283)

A fourth mode, Lab Mode (page 283), is also available, with reduced functionality.

An optional ACE\_INIT\_SCRIPT (page 284) can be configured to load a user-defined Tcl script during ACE startup, prior to running any other Tcl commands or scripts. This enables users, or groups of users, to customize ACE settings, define custom Tcl procs, or define custom ACE flow steps.

Finally, a table of typical supported ACE startup arguments (page 285) is provided at the end of this section.

### GUI Mode

To run in GUI mode, invoke the ace executable either with no options or with the -gui option. GUI mode launches the interactive GUI, from which all commands are issued.

### Starting ACE in GUI Mode, implicit

% ./ace

or

Starting ACE in GUI Mode, explicit

% ./ace -gui

### Command-line Mode

To run in command-line mode, invoke the ACE executable with the -b option from a console. Command-line mode takes control of the console and allows interactively entering Tcl commands at a command prompt.

### Starting ACE in Command-line Mode

```
% ./ace -b
-- ACE -- Achronix CAD Environment -- Version 5.4 -- Build 84486- -- Date 2015-02-11
19:58
-- (c) Copyright 2006-2015 Achronix Semiconductor Corp. All rights reserved.
-- all messages logged in file /home/username/.achronix/ace_2015_02_13_11_00_11.log,
created at 11:00:11 on 02/13/2015
INFO: License ace-v1.0 on server acxlicense (9 of 10 licenses available). Running on
docs.achronix.local (x86_64).
ACE>
```

### Batch Mode

To run in batch mode, invoke the ACE executable with the -b option and the -script\_file option.

### Starting ACE in Batch Mode

```
% ./ace -b -script_file path_to_script_file.tcl
```

### Lab Mode (Reduced Functionality)

ACE also supports a reduced functionality mode, intended for use in Lab environments. The primary purpose of this mode is to allow a lighter-weight tool for chip programming and debugging, and/or for demonstrating hardware functionality with demo designs. In this mode, a license is not required (no license check occurs), and thus most Tcl functionality is unavailable (because most ACE Tcl functionality requires an appropriate license). In lab mode, the user is unable to work with project files, run the Flow, view the Floorplanner, configure IP, etc.

When the ACE GUI is in lab mode, only the default views within the Programming and Debug Perspective and HW Demo Perspective are usable. Only the subset of ACE Tcl commands needed to support those views is functional. The views within the Projects Perspective, Floorplanner Perspective, IP Configuration Perspective, and NoC Performance Perspective are non-functional (and inaccessible), since these views and editors require licensed ACE functionality.

#### Starting ACE GUI in Lab Mode

```
% ./ace -lab_mode
```

or

### Starting ACE in Command-line Lab Mode

```
% ./ace -b -lab_mode
-- ACE -- Achronix CAD Environment -- Version 8.8 -- Build xxxx -- Date 2022-xx-xx xx:xx
-- (c) Copyright 2006-2022 Achronix Semiconductor Corp. All rights reserved.
-- all messages logged in file /home/username/.achronix/ace_2022_08_09_10_11_12.log,
created at 10:11:12 on 08/09/2022
ACE>
```

or

### Starting ACE in Batch Lab Mode

% ./ace -b -lab\_mode -script\_file path\_to\_jtag\_script\_file.tcl

## ACE Initialization Script (ACE\_INIT\_SCRIPT)

An optional ACE\_INIT\_SCRIPT can be configured to load a user-defined Tcl script during ACE startup, prior to running any other Tcl commands or scripts. This enables users, or groups of users, to:

- Customize ACE settings
- Define custom Tcl procedures/commands
- Define custom ACE flow steps
- Extend ACE features and functions

There are three ways to enable the ACE\_INIT\_SCRIPT feature in ACE, which use the following order of precedence:

- 1. Use the -ace\_init\_script commandline. This is useful when creating wrapper scripts to call ACE with an explicit ACE\_INIT\_SCRIPT, or when debugging or testing different ACE\_INIT\_SCRIPTs.
- Define the \$ACE\_INIT\_SCRIPT environment variable as the file path to your ACE initialization Tcl script. This
  can be useful for development teams or organizations wanting to share and standardize the use of the
  ACE\_INIT\_SCRIPT across multiple ACE users.
- 3. Define the \$ACE\_INIT\_SCRIPT environment variable as an empty string. This causes ACE to look for the ACE\_INIT\_SCRIPT in \$HOME/.achronix/ace\_init.tcl. This is useful for an individual developer to customize ACE specifically for that individual, without impacting other users.

### **Relative paths**

If a relative path is used to specify the file path to the ACE\_INIT\_SCRIPT Tcl file, that path is evaluated relative to the current working directory from which ACE was launched (which need not be the ACE installation directory).

### **Example Log Output**

To confirm the ACE\_INIT\_SCRIPT was loaded in your ACE session properly, look for the "Running initialization script" message near the beginning of the ACE session log file.

### Starting ACE in Command-line Lab Mode

```
% ./ace -b -ace_init_script ./my_init_script.tcl
-- ACE -- Achronix CAD Environment -- Version x.x -- Build xxxx -- Date 2023-xx-xx xx:xx
-- (c) Copyright 20xx-20xx Achronix Semiconductor Corp. All rights reserved.
-- all messages logged in file /home/username/.achronix/ace_20xx_xx_xx_xx_xx_xx_log,
created at xx:xx:xx on xx/xx/xxxx
INFO: Running initialization script /full/path/to/my_init_script.tcl
ACE>
```

## ACE Startup Arguments

The most common startup arguments are listed in the following table. Other arguments exist, but should only be used under the guidance of an Achronix FAE (or as specified in one of the Troubleshooting sections of an Achronix User Guide).

### Table 138 · Common ACE Startup Arguments

| Argument                                                                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -b<br>or<br>-batch                                                          | Starts ACE in non-GUI mode, also known as Batch or Command-line mode.<br>See also: the -script_file argument                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| -lab_mode                                                                   | Starts ACE in (unlicensed) Lab Mode, with limited functionality. May be used in combination with ACE GUI mode, Command-line mode, and/or Batch mode. See the prior section in this chapter for more details about ACE Lab Mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <pre>-log_file <path_to_log_file></path_to_log_file></pre>                  | Use this to override default ACE session logging behavior, which would otherwise default to creating a session log file at <user_home_dir>/.achronix/ace_<datestamp>_<times tamp="">.log.<br/>A session log file covers all ACE activity across all projects and implementations touched during the process lifetime of ACE.<br/>Keep in mind that the -log_file argument has no impact upon implementation log files; individual implementation log files are always created under each implementation directory whenever that implementation is being accessed. There is currently no way to override the path of the implementation log files.</times></datestamp></user_home_dir> |
| -print_progress                                                             | Enables verbose progress messages to be logged during execution of the Flow. Verbose progress logging is disabled by default.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| -project_file <i><path_to_acxprj_file< i="">&gt;</path_to_acxprj_file<></i> | Allows pre-specifying which *.acxprj file should be loaded by ACE at startup. This is similar to immediately calling the following ACE Tcl command at the Tcl command prompt after ACE has started (after the -ace_init_script, but before the -script_file): <pre>load_project <path_to_acxprj_file></path_to_acxprj_file></pre>                                                                                                                                                                                                                                                                                                                                                     |

| Argument                                                                                                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ace_init_script<br>path_to_ace_init_script_file>                                                                        | An optional ACE_INIT_SCRIPT can be configured to load a user-defined Tcl script during ACE startup, prior to running any other Tcl commands or scripts. This option overrides th \$ACE_INIT_SCRIPT environment variable and any init script in the user home workspace directory.                                                                                                                                                                                                                                                                                                                    |
| -script_file <i><path_to_script_file></path_to_script_file></i><br>-script_args <i>&lt; string&gt;</i> ] <sup>(1)</sup> | After the ACE session is initialized (after any ACE_INIT_SCRIPT is executed, and after any designated $-project_file$ is loaded), ACE executes the script contained in the script file. If the optional $-script_args < string>$ is also used, then the arguments are passed to the script file when the script is executed. To access these arguments in a TCL script, use the special TCL variables $argc$ and $argv$ . These variables are analogous to the top-level arguments to the C main function, but with the application name itself instead stored in the special TCL variable $argv0$ . |
| snapshot_version <i><int< i="">&gt;</int<></i>                                                                          | Allows specifying which version of Achronix Snapshot should be used during the ACE session. Version 3 was the old *.jam/STAPL support, no longer used starting in ACEv9.2. Version 4 is the new Tcl support available starting in ACEv9.2.                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                         | Intended for use in ACE Batch mode. Requests that ACE report its version number and th immediately exit.<br>Example:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                         | Using the -version argument (in Linux)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| -version <sup>(2)</sup>                                                                                                 | <pre>% ./ace -b -version<br/> ACE Achronix CAD Environment Version 8.8<br/> Build xxxx Date 2022-xx-xx xx:xx<br/> (c) Copyright 2006-2022 Achronix Semiconductor<br/>Corp. All rights reserved.</pre>                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                         | %                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

#### **Table Notes**

- 1. When using script files in Microsoft Windows, starting ACE in batch mode with a script file opens a new console that only survives for the life of the script file, and then immediately closes. This typically makes it difficult to read any logged results which might have appeared in that console. For best results, be sure your script logs its output to a file, or review the session log file after script execution. See also: the -log\_file argument.
- 2. This argument has no effect in GUI Mode. ACE always logs the version number to the Tcl Console immediately at ACE startup in all modes. As when using the <code>-script\_file</code> argument in Windows, ACE starts a separate console window for the session. Because ACE immediately exits after reporting/logging the version banner, this console window is only visible for a fraction of a second. The requested version information can be found in the session log file. See also: <code>-log\_file</code> argument.

## Working With Perspectives

Perspectives define the initial set and layout of views in the Workbench window, providing a set of functionality aimed at accomplishing a specific type of task or working with specific types of resources.

## Switching Between Perspectives

Each perspective has an associated icon on the main toolbar. Switch between perspectives by clicking one of these icons.

It is also possible to view the available choices as a menu by selecting **Window**  $\rightarrow$  **Open Perspective** from the menu bar.

Descriptions of the available perspectives are found in the section describing the Perspectives (page 6) concept.

## **Resetting Perspectives**

Often, when altering positions of **Editors** (page 9) and **Views** (page 16) within a perspective, this can result in an arrangement that is no longer appealing. Rather than try to manually move the Views and Editors back to the original positions, it is much faster and simpler to reset the perspective.

To restore a perspective to its original layout:

- 1. Select **Window**  $\rightarrow$  **Reset Perspective** from the menu bar.
- 2. Click **OK** on the resulting dialog.

## Working with Views and Editors

Views and editors are the main visual entities appearing in the Workbench. In any given perspective there is a single editor area which can contain multiple editors with a number of surrounding views providing context.

## **Opening Views**

Perspectives offer pre-defined combinations of views and editors. To open a view not included in the current perspective, select **Window**  $\rightarrow$  **Show View** from the menu bar.

## Moving and Docking Views and Editors

To change the location of a view or editor in the current perspective:

1. Without releasing the left mouse button, drag the view or editor by its tab.

### (i) Note

A group of stacked views or editors can be dragged using the empty space to the right of the tabs.

- 2. While dragging the tab (or tab stack), as the mouse is moved around the Workbench, the area under the mouse changes to display (sometimes subtle) feedback indicating where the tab (or stack) can dock if the left mouse button is released at the current location.
  - Drag the tab near the left, right, top, or bottom border of another view or editor to see how that view/editor splits its available area with the dragged tab.
  - Drag the tab near the tabs of another tab stack to see where the dragged tab can be inserted/appended in the existing stack.
  - A tab may be dragged outside of the Workbench area to turn it into a detached view (a view shown in its own separate window).

3. When the view is in the desired location relative to the view or editor area under the cursor, release the left mouse button.

### Table 139 • View and Editor Tab Docking Feedback

| Feedback                                                     | Description                                                                                                                                                           |
|--------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Vertical bar between tabs                                    | Marks the insertion point between other tabs.                                                                                                                         |
| Translucent rectangles overlaid<br>upon existing view/editor | Shows the positioning of the dragged view/editor alongside the pre-<br>existing views/editors already in that docking location.                                       |
| Translucent rectangle floating<br>outside the ACE window     | Shows the position where the <b>detached</b> (page 288) view/editor can appear.                                                                                       |
| 0                                                            | No changes. This docking location is either identical to the present<br>layout, or is an illegal position. If the left mouse button is released,<br>no change occurs. |

### Caution!

In Linux, there is currently a known bug, in the application frameworks underlying ACE, that may cause view/editor tab movements to **detach** (page 288) instead of docking when the Help Window is open. See the **Troubleshooting** (page 762) section for more details, including several workarounds.

## **Rearranging Tabbed Views and Editors**

In addition to dragging and dropping (docking) views/editors inside the Workbench, the order of views/editors can be rearranged within a tabbed stack:

- 1. Click the tab of the view/editor to be moved and drag it to the desired location. As the tab is dragged across other tabs, a vertical bar insertion cursor appears.
- 2. Release the mouse button when the insertion cursor is in the desired location.

#### (i) Note

A group of stacked views/editors can be moved by starting the drag using the empty space to the right of the tabs.

### **Detaching Views and Editors**

Detached views and editors are shown in a separate window with a smaller trim. These views work like other views and editors, except that they are always shown in front of the Workbench window. To detach views/editors:

- 1. If the Workbench window is maximized, resize it so that it does not fill the entire screen.
- 2. Click and hold the tab of the view/editor to be detached.

3. Drag the tab (or tab group) outside of the Workbench window and release the mouse button. The tab can also be dragged into the window of a previously detached view/editor to have multiple detached views/editors together.

To restore the view/editor to appear inside of the Workbench window, drag its tab into the Workbench window.

## **Tiling Editors**

UG070

The Workbench allows multiple files to be open in multiple editors. Unlike views, editors cannot be dragged outside the Workbench to create new windows. However, editor sessions can be tiled within the editor area in order to view source files side by side:

- 1. With two or more files open in the editor area, select one of the editor tabs.
- 2. While holding down the left mouse button, drag that editor tab over the left, right, top or bottom border of the editor area. The mouse pointer changes to a drop cursor, indicating where the editor session is to be moved.
- 3. Release the mouse button.
- 4. Optionally, Drag the borders of the editor area, or each editor, to resize as desired.

#### Note

This operation is a similar to moving and docking views inside the Workbench, except that all editor sessions must be contained within the editor area.

### Maximizing, Minimizing, and Restoring Views and Editors

ACE provides a rich environment which, in its basic form, consists of the following:

- · An Editor Area which contains one or more stacks showing the open editors
- · One or more View Stacks which surround the Editor Area and contain one or more views

These elements compete for valuable screen area and correctly managing the amount of area given to each can greatly enhance your productivity within ACE.

The two most common mechanisms for managing this issue are "minimize" (use as little space as possible) and "maximize" (provide as much space as possible). ACE provides two ways to access these operations:

- 1. Use the minimize and maximize buttons provided on a stack border.
- 2. Double-click an individual tab or the blank area to the right of the tabs.

### Maximize:

It is desirable at times to focus attention on one particular view or editor to the exclusion of the others. The most popular candidates for this are maximizing the editor area in order to view a report, or maximizing the **Floorplanner View** (page 45) to make as much of the display available for floorplanning as possible.

ACE implements the maximize behavior by minimizing all stacks *except* the one being maximized. This allows the maximized stack to completely occupy the window while still allowing access to any open views in the perspective by using the icons located in the area around the edges of the window which are called the "Trim Stack".

Editor maximization operates on a complete Editor Area which includes all Editor Stacks, rather than simply maximizing the particular Editor Stack. This allows for "compare" workflows which require the ability to see multiple editor files in a split editor area at the same time.

### Minimize:

Another way to optimize the use of the screen area is to directly minimize stacks that are of no current interest. Minimizing a stack causes it to be moved into the trim area at the edges of the workbench window, creating a Trim Stack.

#### Note $(\mathbf{i})$

The first time a stack is minimized, the Trim Stack may end up on any edge of the window. If the Trim Stack is manually moved to a particular window edge, that same edge is typically reused when that stack is again minimized.

View Stacks get minimized into a trim representation that contains the icons for each view in the stack:

| 🍃 Netlist Browser 🔯 Clo | ck Dor | mains        | ×  | - X  | 1     | Q 🖉     | +   🔞 |      |
|-------------------------|--------|--------------|----|------|-------|---------|-------|------|
| Clock Domain Name       | Hig    | Core         | IO | ALUs | BRAMs | CLK_IPI | CLK_O | DSPs |
| 🔯 clka                  |        | $\checkmark$ |    | 0    | 0     | 1       | 0     | 0    |
|                         |        |              |    |      |       |         |       |      |
| ٠ ۱۱                    | 1      |              |    |      |       |         |       | •    |

Figure 136 • Example View Stack Before Minimization



Figure 137 • Example Trim Stack After View Stack is Minimized

The minimize behavior for the Editor Area is somewhat different. Minimizing the Editor Area results in a trim stack containing only a placeholder icon representing the entire editor area rather than icons for each open editor (since in most cases all of the icons would be the same, making them essentially useless).



Figure 138 • Example of Editor Area Before Minimization



### Figure 139 • Example of Minimized Editor Area Trim Stack

For workflows needing more than one element visible (i.e., having the Editor Area *and* a View Stack in the presentation at the same time) additional screen space can still be gained by minimizing the stacks that are not of current interest. This removes them from the main presentation and places them on the Trim Stack, allowing more space for the remaining stacks in the window.

### (i) Note

There are two ways to end up with a stack in the trim:

- 1. Directly by minimizing the stack.
- 2. Indirectly by maximizing another stack.

Depending on how the Trim Stack was created, its behavior is different: when restoring a stack from a maximized state, only those trim stacks that were automatically minimized during the initial maximize are restored to the main presentation, while stacks that were manually minimized, stay minimized.

### 🕑 Tip

This difference is important in that it allows fine-grained control over the presentation. While using maximize is a one-click operation, it is an "all or nothing" paradigm (i.e., no other stack is allowed to share the presentation with a maximized stack). While adequate for most tasks, it may be desired to have the presentation show more than one stack. In this case, instead of maximizing, minimize all the other stacks *except* the ones wanted in the presentation. When set up, the editor area can still be subsequently maximized, but the subsequent restore only restores the particular stack(s) that were sharing the presentation, not the ones explicitly/manually minimized.



Figure 140 • Example Default Presentation of the Projects Perspective

| <b>O</b> A0    | CE - Ac      | hronix   | CAD Enviro       | onment   | - Version HS1.1 - quicksta                                     | art->impl_1 (AC16tSC01HI01C)       | )                                     |               | x    |
|----------------|--------------|----------|------------------|----------|----------------------------------------------------------------|------------------------------------|---------------------------------------|---------------|------|
| <u>F</u> ile   | <u>E</u> dit |          | ns <u>W</u> indo |          | •                                                              |                                    |                                       |               |      |
|                |              | <b>b</b> | 4 \$ °           | t 🗈 I    | ñ   🛛 🌮   🖪 🖪                                                  | P 🕾 🗗 📮 🗇 🗢 🤣                      |                                       |               |      |
|                | 🗎 Tir        | ming R   | eport - Rou      | ited — o | uickstart 📄 Clock/F                                            | Reset Report — quickstart 🛛        | Utilization Report - Routed -         | - quic        |      |
| 6              | Clo          | ck S     | ummary           | /        |                                                                |                                    |                                       |               | *    |
| -              |              |          |                  |          | ry of each clock domain's ef<br>ilighted in the table below.   | ffective target period, phase, and | target frequency. Clock constraints t | that were not |      |
| <del>.</del> % |              | Clock    | Period           | Phase    | Target Frequency (MHz)                                         |                                    |                                       |               |      |
|                |              | cika     | 3000.00ps        | 0        | 333.3                                                          |                                    |                                       |               |      |
| 8              |              |          |                  |          |                                                                |                                    |                                       |               | - 11 |
|                |              |          |                  |          |                                                                |                                    |                                       |               | =    |
|                | Clo          | ck R     | elations         | ships    |                                                                |                                    |                                       |               |      |
| <br>8          |              |          |                  |          | clock relationships for each<br>ate the frequency ratio of the |                                    | unrelated clock domains (if any). En  | ntries in the |      |
|                | Unre         | elated   | clocks           |          |                                                                |                                    |                                       |               |      |
|                |              | Unrela   | ted Clock        |          |                                                                |                                    |                                       |               |      |
|                | -            | cika     |                  |          |                                                                |                                    |                                       |               |      |
|                |              |          |                  |          |                                                                |                                    |                                       |               |      |
|                | —            |          |                  |          |                                                                |                                    |                                       |               | - 11 |
|                |              |          |                  |          |                                                                |                                    |                                       |               |      |
|                | Effe         | ectiv    | e Clock          | Cons     | straints                                                       |                                    |                                       |               | -    |
|                |              |          |                  |          |                                                                |                                    | 1:                                    | 18M of 352M   | Û    |

Figure 141 • Example of the Projects Perspective With The Editor Area Maximized

# Working with Projects and Implementations

## **Creating Projects**

To create a new project in the workspace:

- 1. Click the () Create Project toolbar button in the Projects view.
- 2. In the Create Project dialog, type in or browse to the location of the new project directory.

### Caution!

Directories in the path that do not exist are created.

3. Type in the new project name and click Finish.

After clicking **Finish**, the new project appears in the Projects view. The new project contains a default implementation named impl\_1, which is set as the new active implementation. A project file is also created and saved in the new project directory.

## Saving Projects

Some project operations cause changes to a project to be saved to the project file automatically, while others change project data without saving. Each Project with unsaved changes is marked in the GUI with an asterisk on the lower

left corner of its project icon (). If any project in the workspace has unsaved changes, the Projects view title is also marked with an asterisk:



Figure 142 • Projects View Title Unsaved Changes Example

To save the changes to a project:

- 1. Select the project in the Projects view.
- Either press CTRL+S on the keyboard, select the ( ) File Save toolbar button on the main toolbar, or select the File → Save menu option.

To save a project to a different file:

- 1. Select the project in the Projects view.
- 2. Select the File  $\rightarrow$  Save As... menu option.
- 3. Browse to a new file location.
- 4. Enter a project name and click **Save**.

When exiting, ACE prompts to save changes to any projects with unsaved changes:

| Sav                             | e Resources        | ×            |
|---------------------------------|--------------------|--------------|
| Select the <u>r</u> esources to | save:              |              |
| 🗹 🗁 proj_loop [Projec           | :t: "proj_loop"]   |              |
| ☑                               | 'proj_z"]          |              |
|                                 |                    |              |
|                                 |                    |              |
|                                 |                    |              |
|                                 |                    |              |
|                                 |                    |              |
|                                 |                    |              |
|                                 |                    |              |
|                                 |                    |              |
| Г                               | <u>S</u> elect All | Deselect All |
| L                               | <u>Select All</u>  | Deselect All |
| г                               |                    |              |
|                                 | OK                 | Cancel       |
|                                 |                    |              |

Figure 143 • Project Unsaved Changes Prompt

## Loading Projects

By default, when the ACE GUI starts, it attempts to automatically re-load all projects which were open in the prior ACE GUI session.

### 🔥 Caution!

Be aware that any projects which are still locked by another ACE session are not automatically re-loaded, nor is any related error reported. Additionally, project files from the prior session which are no longer found in the file system are not loaded, nor are any related errors reported.

### Loading a Project Using the GUI

To load existing Projects (page 224) into the workspace:

- 1. Click the (🐸) Load Project toolbar button in the Projects View (page 120).
- 2. In the Load Project Dialog (page 179), **Browse** to the location of the project directory. Or, if the project has been opened by ACE previously, find the previously opened .acxprj project file in the list of choices in the drop-down combo box within the dialog.

3. Select the project file and click **Open**.

After clicking **Open**, the **load\_project** (page 668) Tcl command is issued and the project now appears in the Projects view. This project is restored from its previous state, and its last implementation is set as the new active implementation. Any place-and-route data for the active implementation is not loaded by default. See **Restoring Implementations** (page 301) for details on loading a prior place-and-route state.

#### (i) Note

#### **Default Implementation Options Change Over Time**

The default **Implementation Options** (page 0) for ACE change over time as new optimizations become available and existing optimizations are refined. When a project is loaded from an earlier version of ACE, a "Project Version Mismatch" popup dialog is shown offering to reset all Implementation Options of all implementations to the latest default values.

To avoid risking the loss of old optimizations saved in implementation options, say no to the offered reset. To see how the new default implementation options could affect the design, simply create a new implementation for the project. The new implementation contains all the new default values for implementation options, but contains no place-and-route data. Be aware that since no constraint files from the project are enabled by default in a new implementation, it is necessary to choose which constraint files to enable for the new implementation before running the flow.

### Loading a Project Using Tcl

The Tcl commands **load\_project** (page 668) and **restore\_project** (page 689) may be used to open projects (and potentially also the most recent project implementation) in ACE:

- The load\_project command is simple, and only opens the specified project for later use, without loading any additional place-and-route state of an implementation.
- The restore\_project command is capable of much more and by default, attempts to load the most recent
   .acxdb file (potentially containing place-and-route data) for the most recent implementation in the specified
   project.

### **Project Locking and Lock Files**

### Warning!

#### Project locks protect users from data corruption

ACE uses project locks and lock files to protect user data. Do not attempt to bypass ("-force") the project locks or lock files.

Achronix does not support running multiple ACE sessions on the same project (directory) simultaneously. Having a single project open in multiple ACE sessions is known to cause problems.

Every project opened by ACE is locked by that ACE session for as long as the project is open. Locking is primarily used to prevent file corruption, which could occur if multiple ACE sessions attempt to operate within the same project simultaneously. If another ACE session attempts to open a project while the project is still locked, ACE reports an error in the Tcl Console. The error message mentions the username and hostname of the session which created the project lock, allowing the coordination of sequential (not simultaneous!) project access.

### Example error message for a locked project

```
cmd> load_project "~/output/quickstart/quickstart.acxprj" -activeimpl "impl_1"
Project: "~/output/quickstart/quickstart.acxprj" is locked by another ACE session and
cannot be loaded. This project is locked by user: TestUser1 on host: TestStation1. [...]
```

Instead of forcing project lock overrides or deleting lock files, when needing simultaneous access to a design, consult your Achronix FAE. Some potential options include Using Incremental Compilation (Partitions) (page 404), or using version control tools to store the project.

### Caution!

While it is possible to keep multiple copies of the same project in separate project directories, this method is extremely difficult to coordinate, and is thus not recommended by Achronix.

In the unlikely occurrence of an ACE crash, a project may mistakenly remain locked after ACE has closed. Because the project is still locked, subsequent attempts to load the project fail with an error message similar to the one above. To recover from such situations, see "Unable to Load Project: Project is Locked (page 765)" under Troubleshooting (page 762).

### **Removing Projects**

To remove a project from the workspace:

- 1. Select a project in the Projects view.
- 2. Click the (X) **Remove** toolbar button in the Projects view.

After clicking **Remove**, the project no longer appears in the Projects view. The project files are not deleted from the file system during this operation, and it is the responsibility of the user to clean up unwanted files on the disk. The project is left untouched on the disk so that it can be loaded again, later, if desired.

### **Opening Project Files in an Editor**

To open a project file in the editor area, double-click the project in the Projects view. The project file now appears in a text editor in the editor area. Editing a project file in the workspace does not affect the project unless the project is removed and then re-loaded from the changed project file.

### Adding Source Files

To add source netlist and constraint files to a project in the workspace:

- 1. Select the Project (page 224) in the Projects View (page 120) to which the source files are to be added.
- 2. Click the ( 🖹 ) Add Source Files toolbar button in the Projects view.
- 3. In the Add Source Files Dialogs (page 152), browse to the location of the source files.
- 4. Select the desired file in the dialog, and click Open.

### Caution!

By default, ACE loads source files in the same order they were added to the project. If ACE is loading files in an incorrect order, drag and drop them into the desired order within the project Netlists and/or Constraints nodes in the **Projects View** (page 120).

After clicking **Open**, the source files appear in the appropriate virtual folder under the selected project in the Projects view. The source files are not actually consumed until the corresponding flow step is run (such as **Run Synthesis**, **Run RTL Simulation**, or **Run Prepare**). Adding a source file to a project simply creates a link to the file so that it may be loaded during flow execution.

See also:

- add\_project\_source\_files (page 612)
- Removing Source Files (page 300)
- enable\_project\_source\_file (page 635)
- disable\_project\_source\_file (page 627)

### Source File Load Order

#### Note

Source file load order is shared by all **Implementations** (page 231) within a given **Project** (page 224). Enabling of constraint files (choosing which constraint files are actually loaded) or netlist files is allowed to differ in each implementation and is managed by the checkboxes in the **Options View** (page 100).

To assist with the understanding of the load order of the source files, the RTL, netlist, and constraint files are listed in the **Projects View** (page 120) in the same order in which they are loaded (the constraint files are additionally listed in order within the **Options View** (page 100)).



Figure 144 • Projects View File Order Example

By default, ACE loads source files in the same order they were added to the Project. Frequently, the order in which source files are loaded is important. For example, the creation of a clock may occur in the source file create\_clocks.sdc, while operations upon that created clock may happen in the source file generated\_clocks.sdc. To avoid errors, first add create\_clocks.sdc to the project as a source file, then add generated\_clocks.sdc as a source file. If attempting to add all the files to the project in a single operation, the results are platform dependent, but often the operating system "helpfully" sorts the bulk-added files alphabetically behind the scenes, which causes ACE to add them to the project in a potentially incorrect order (and thus later try loading them in that same incorrect order).

When the displayed source file load order is incorrect, there are a few ways to alter the load order:

• Changing the order of existing RTL files, netlist source files, and constraint source files can be performed quickly using mouse drag-and-drop operations in the **Projects View** (page 120) (or by using Tcl commands created explicitly for this purpose). The tree should be expanded to show all the netlist and/or constraint files, then drag-and-drop the files to re-order them within the appropriate Project View node until they achieve the desired order. The next time the **Flow is Run** (page 305), the constraint files are loaded in the chosen order.

See also:

- get\_project\_source\_files (page 657)
- move\_project\_source\_file (page 670)
- A more tedious way to alter the order (but possibly the easiest way to script) is by removing all the source files from the project.

```
see:
```

- Removing Source Files (page 300)
- remove\_project\_source\_files (page 676)

Add them to the project again, one at a time, in the desired order.

See:

• add\_project\_source\_files (page 612)

### **Enabling/Disabling Netlists and Constraint Files for Implementations**

Implementations (page 231) are allowed to individually enable and disable the loading of netlists and constraint files within their parent **Project** (page 224). This selective loading is managed through the **Options View** (page 100), under the **Place and Route** category of Implementation Options. Simply uncheck the checkbox next to the constraint files which should not be loaded for the implementation.

See also:

- disable\_project\_source\_file (page 627)
- enable\_project\_source\_file (page 635)

Constraint files which are disabled (unchecked) for the current Active Project and Implementation (page 231) are displayed in grey (instead of black) within the Projects View (page 120).



Figure 145 • Projects View Disabled Constraints File Example

## **Removing Source Files**

To remove a source file from a **Project** (page 224) in the workspace:

- 1. Select a source file in the Projects View (page 120).
- 2. Click the (X) **Remove** toolbar button in the Projects view.

### Or:

- 1. Right-click the source file in the Projects View.
- 2. Choose (X) **Remove** in the popup context menu.

After clicking **Remove**, the source file no longer appears in the Projects view. Source files are not deleted from the file system during this operation, and it is the responsibility of the user to clean up unwanted files on the disk. The source file is left on the disk so that it can be loaded again later, if desired.

See also:

- remove\_project\_source\_files (page 676)
- Adding Source Files (page 296)

### **Disabling Constraint Files**

It is often not necessary to completely remove constraint files from a project. Instead, constraint files can be individually disabled for any **Implementations** (page 231) within a project.

- 1. Select/activate an implementation within the Projects View. The **Options View** (page 100) is updated to show the implementation options for that implementation. At the bottom of the **Place and Route** implementation options category, there is a list displayed of the Constraint Files for the project.
- 2. In the Options View, expand the **Place and Route** implementation options category. At the bottom of the category, there is a list displayed of the Constraint Files in the project.
- 3. Deselect (clear) the checkbox(es) of constraint files which should not be loaded for the implementation.

See also:

- disable\_project\_source\_file (page 627)
- enable\_project\_source\_file (page 635)

## **Opening Source Files in an Editor**

To open a source file in the editor area, double-click the source file in the Projects view. The source file now appears in a text editor in the editor area. Editing a source file in the workspace does not affect the results of the flow unless the flow is re-run on the affected project implementations.

### (i) Note

IP (.acxip) files that are not part of the currently active project cannot be opened.

### **Creating Implementations**

To create a new implementation (page 231) in a project (page 224) in the workspace:

- 1. Select a project in the Projects view (page 120).
- 2. Click the (I) Create Implementation toolbar button in the Projects view.
- 3. In the Create Implementation dialog (page 170), type in the name of the new implementation and click Finish.

After clicking **Finish**, the new implementation appears under the selected project in the Projects view. The new implementation is set to be the **active implementation** (page 231) and contains default values for all **implementation options** (page 0). A new implementation directory structure is also created under the project directory if it does not already exist.

### Saving Implementations

To save the state of the database (options, netlist, constraints, placement, and routing data) for an implementation in a project in the workspace:

- 1. Activate an implementation in the Projects View.
- 2. Run the flow (at least through Run Prepare).
- 3. Optionally edit placement or routing information.
- 4. Click the (1) Save Implementation toolbar button in the Projects view.
- 5. In the Save Implementation Dialog (page 184), type the file path to the .acxdb Archive File to which the implementation data is to be saved and click **Finish**.

After clicking **Finish**, the state of the database (options, netlist, constraints, placement, and routing data) for the implementation is stored in the .acxdb Archive file, which can be restored again later.

See also:

- Restoring Implementations (page 301)
- save\_impl (page 706)
- restore\_impl (page 688)

#### Some Flow Steps Automatically Save the Implementation State

A subset of the Flow Steps (page 235) automatically save the current state in .acxdb files. These files are called:

- <implementation\_name>\_prepared.acxdb
- <implementation\_name>\_placed.acxdb
- <implementation\_name>\_routed.acxdb

These files are created at the end of the Run Prepare, Run Place, and Run Route flow steps, respectively.

### **Restoring Implementations**

To restore the state of the database (options, netlist, constraints, placement, and routing data) for an implementation in a project in the workspace:

- 1. Activate an implementation in the Projects View.
- 2. Click the (I) **Restore Implementation** toolbar button in the Projects view.

3. In the **Restore Implementation Dialog** (page 183), enter the file path to the .acxdb Archive File from which to restore the implementation data and click **Finish**.

After clicking **Finish**, the state of the database (options, netlist, constraints, placement, and routing data) for the implementation is restored from the .acxdb Archive file.

(i) The Run Prepare, Run Place, and Run Route Flow Steps (page 235) automatically save checkpoint .acxdb files (by default) that may be restored later.

See also:

- restore\_impl (page 688)
- save\_impl (page 706)

### **Copying Implementations**

To create a new implementation (page 231) that is a copy of an existing implementation,

- 1. In the Projects View (page 120), select (activate (page 231)) the implementation to be copied.
- 2. Select the (4) Create Implementation toolbar button in the Projects View.
- 3. In the pop-up Create Implementation dialog (page 170):
  - a. Enter the name of the new implementation.
  - b. Check the Copy Option Values from Active Implementation checkbox.
  - c. Click Finish.

After clicking **Finish**, the new implementation appears under the selected project in the Projects view. The new implementation is set to be the **active implementation** (page 231) and contains **implementation options** (page 0) values copied from the source implementation. A new implementation directory structure is also created under the project directory if it does not already exist.

### Setting the Active Implementation

To change the active implementation (page 231) in the GUI, do one of the following:

- · Click an implementation in the Projects view, which activates the selected implementation
- · Click a project in the Projects view, which activates the first implementation of the selected project

Changing the active implementation causes the flow status to be cleared and changes the target for all flow operations to the new active implementation.

### **Removing Implementations**

To remove an implementation from a project in the workspace:

- 1. Select an implementation in the Projects view.
- 2. Click the (X) Delete toolbar button in the Projects view.

After clicking **Delete**, the implementation no longer appears in the Projects view. Removing an implementation from a project causes all settings for the implementation to be deleted from the project file when the project is saved.

## **Configuring Project and Implementation Options**

To configure project and implementation options in the workspace:

- 1. Select an implementation in the Projects view (page 120), changing the active implementation to the selection.
- 2. In the **Options view** (page 100), use the controls to configure the available implementation options for the active implementation.

After changing implementation options in the **Options view** (page 100), the **flow status** (page 243) is optionally cleared based on the options that changed. A change to an implementation option requires the **flow** (page 235) to be re-run for that implementation in order for the changes to affect the results of the flow. The changes to the implementation options are not saved until the affected project is saved.

## Opening Output Files in an Editor

To open an output file in the editor area, double-click the output file in the Projects view. The output file appears in a text editor in the editor area.

(i) Note

Editing an output file is NOT recommended.

## Opening Report Files in an Editor

To open a report file in the editor area, double-click the report file in the Projects view. The report file now appears in a web browser in the editor area.

#### (i) Note

Editing a report file is NOT recommended.

## **Cleaning Projects**

In the **Projects** (page 224) Perspective, while running the **Flow** (page 235) for active **Implementations** (page 231), ACE generates output files and sub-directories under the active implementation directory. When the configuration is changed and the entire flow or a sub-flow is re-run, any previously generated output files with the same filenames are overwritten. However, some organizations prefer to clean the active implementation directory (and sub-directories) before every flow run to avoid having any lingering stale files.

ACE provides a simple and easy way to delete (clean) these sub-directories and output files through the

#### clean\_project (page 616)

Tcl command and/or related actions in the **Projects View** (page 120). Specifically, the implementation subdirectories which are cleaned include:

- .debug/
- output/
- reports/

Additionally, the \*.acxdb files for the selected implementation(s) are deleted.

### 👍 Warning

Cleaning projects (or implementations) is an irreversible action - the files are deleted from the file system.

In contrast, see also **Removing Implementations** (page 302), which removes an implementation from a project without deleting any files from the file system.

### (i) Note

#### Multiprocess Reports are a special case

The **Multiprocess Summary Report** (page 256) files are a special case. These files are not stored at the Implementation level, but at the Project level. Thus, these reports are not deleted when individual Implementations are deleted (**Clean Implementation**), but are deleted when an entire Project is cleaned (**Clean Project**).

### (i) Note

### Log files are never cleaned/deleted

To ensure the full history of an implementation is always maintained, cleaning a project or implementation never deletes \*.log files (or any other files found within the <implementation\_directory>/log/ subdirectories).

To clean the implementations of a project from the workspace:

- 1. Select a project in the Projects view.
- 2. Right click the selected project and select ( **Clean Project** from the menu.
- 3. This option selects all implementations of the selected project by default. Choose one or more implementations to clean from the **Clean project** dialog.
- 4. Click OK.

This operation can also be performed on an implementation:

- 1. Select an implementation from a project in the Projects view.
- 2. Right click the selected implementation and select ( $\checkmark$ ) Clean Implementation from the menu.
- 3. This option selects only the current implementation by default while the rest of the implementations for the selected project are not selected. Choose one or more implementations to clean from the **Clean project** dialog.
- 4. Click OK.

See also:

- Projects View (page 120)
- clean\_project (page 616)
- remove\_project (page 674)
- remove\_impl (page 674)
- Removing Projects (page 296)

• Removing Implementations (page 302)

## Running the Flow

A flow can only be run on the current Active Implementation (page 231). If no active implementation is set in the **Projects View** (page 120), then the **Flow Steps** (page 235) in the **Flow View** (page 55) are disabled. Some flow steps are optional while others are required. Optional flow steps may be enabled or disabled in the Flow view by checking or clearing the checkbox to the left of each flow step label.

## Running the Entire Flow

To run the current Active Project and Implementation (page 231) through the entire flow (sequentially run each of the Flow Steps (page 235) in order):

- 1. Enable the desired optional flow steps (and disable the unwanted optional flow steps) by clicking the checkboxes next to the flow steps. Required flow steps cannot be disabled.
- 2. Choose the ( > ) **Run Flow** or **Re-Run Flow** action in the Flow View (page 55), either as a toolbar button or context menu choice.
- 3. (Optionally) Stop the flow from continuing to the next flow step at any time by clicking the ( ) **Stop Flow** toolbar button in the Flow view. When this occurs, ACE displays a dialog allowing the optional restoration of a prior flow state for the implementation by loading an .acxdb file.

See also:

- restore\_impl (page 688)
- Load Acxdb Dialog (page 178)

Disabled flow steps are skipped (not executed) during this operation.

As each individual flow step is run, its **Flow Status** (page 243) changes from incomplete, to running, to either error or complete. If an error occurs during the execution of a flow step, the flow is stopped, and no further steps are attempted.

See also:

- run (page 690)
- enable\_flow\_step (page 634)
- disable\_flow\_step (page 626)

#### (i) Note

#### Special note regarding the Flow and Incremental Compilation:

When Incremental Compilation is enabled, it might be necessary sometimes to recompile all partitions. This operation can be performed by managing the individual partitions using the **Partitions View** (page 111), but an easier way to trigger the recompile is to select the Flow View context menu choice **Re-Run Flow with "-ic init"**, which re-initializes the state of all partitions before starting the full flow.

See Using Incremental Compilation (Partitions) (page 404) for more details. See also: run -ic init (page 690).

### (i) Note

#### Special note regarding Evaluation Flow Mode:

When the **Flow Mode** implementation option is set to **Evaluation**, the flow steps under **Design Completion** and **FPGA Programming** are not executed. See **Flow Mode** (page 243) for more details.

## Running a Sub-Flow

When using the Flow View (page 55), there are several ways to run a subset of the available Flow Steps (page 235) on the Active Project and Implementation (page 231).

It is possible to run individual flow steps one-at-a-time, to run all required flow steps up to a specified step (stopping when the specified step is completed), and to resume running a partial flow to flow completion.

As each flow step is run, its **Flow Status** (page 243) (as displayed in the Flow View) visibly changes from incomplete, to running, to either complete or error. If an error occurs during the execution of a flow step, the flow stops running any further steps. Disabled Flow steps are not executed during these operations.

### Run an Individual Flow Step

Simply right-click the chosen flow step, and select the **Run Selected Flow Step** context menu item. Alternately, double-click the chosen flow step.

If any prerequisite required flow steps have not yet been executed, they are run in standard order prior to the chosen step. Any preceding optional steps are not run, even if they are enabled.

After any prerequisite required steps are complete, the chosen flow step is executed.

### Warning!

**Run Selected Flow Step** runs the selected step even if that step is optional and not currently enabled (its checkbox is unchecked). Also, this action executes not only the selected step, but any preceding required steps.

Again, only the preceding *required* flow steps are run, not any preceding optional steps, even if they were selected (had their checkboxes checked).

See also:

run -step <id> (page 690)

### Run Remaining Enabled Flow Steps (Resume Flow)

When the flow has been stopped before completion, or when a partial flow state has been loaded (page 294) from a

saved .acxdb file, ACE can continue the flow if the (IP) **Resume Flow** action is chosen. This action causes ACE to start running at the first enabled flow step which follows the latest successfully completed flow step.

- 1. Ensure the desired optional steps are enabled (checked) in the Flow View.
- 2. Choose the (III) **Resume Flow** action from the view toolbar, or from the right-click context menu.

### (i) Note

If the current flow mode is set to **Evaluation**, the flow stops after the **Place and Route** category completes. See **Flow Mode** (page 243) for details.

See also:

- run -resume (page 690)
- enable\_flow\_step (page 634)
- disable\_flow\_step (page 626)

### Stopping the Flow

At any time while a flow step is running, it is possible to ask ACE to stop running the flow with the Flow View ( 📕 ) **Stop Flow** action.

Some flow steps might respond by stopping immediately, while others need to perform some additional work before

exiting the flow step. In both cases, the Flow Status (page 243) of that step typically is changed to the ( ≭ ) Error status to indicate that the flow step did not complete successfully.

It is frequently the case that when the flow is interrupted in this manner, the Tcl Console shows many logged error

messages for the interrupted flow step. Typically the (IP) **Resume Flow** or **Run Selected Flow Step** can be selected and ACE resumes normal work from the last successfully completed flow step.

## **Running Multiple Flows in Parallel**

Normally, ACE only allows a single **project** (page 224) **implementation** (page 231) to be run through the **flow** (page 235) at a time. Using the **Multiprocess View** (page 75), ACE allows running multiple implementations *within a single project* through the flow in parallel, via a configurable number of parallel processes. Executing multiple implementations in this manner allows ACE to provide a **Multiprocess Summary Report** (page 256) of the resulting frequencies, permitting QOR performance comparisons between implementations utilizing different starting clock constraints, placement constraints, and potential optimizations.

### Finding the Multiprocess View

The Multiprocess view is, by default, present in the ( $\square$ ) **Projects perspective** (page 6), in a tab group shared with the **Options view** (page 100). If it is not visible for some reason, the Multiprocess view may be displayed within any perspective by selecting **Window**  $\rightarrow$  **Show View**  $\rightarrow$  **Other...**  $\rightarrow$  **Achronix**  $\rightarrow$  **Multiprocess**.

### **Configuring the Execution Queues**

Within the Multiprocess view, the **Execution Queue Management** (page 77)" section allows the configuring the desired number of parallel processes used to consume the queue of selected implementations. Simply set the value of **Parallel Job Count** to the desired number of parallel processes. Using the minimum value of **1** causes all queued implementations to be executed sequentially, one after another.

ACE may be configured to execute the parallel processes in the background on the host workstation running the ACE GUI, or ACE may submit each implementation as an independent executable job to an external cloud/grid/batch job

submission system. Detailed configuration of the external job submission command is handled on the Multiprocess: Configure Custom Job Submission Tool Preference Page (page 209).

### License Management Considerations with Multiprocess

### 👍 Warning

Each parallel ACE process needs access to an ACE software license.

#### Floating licenses:

When running using the Multiprocess View in the ACE GUI, to run *N* parallel execution queues, *N*+1 ACE licenses are needed (the extra license is for the GUI itself, as it is managing all the queues running in the background). Talk to your Achronix FAE to ensure that your site has enough licenses to enable running with Multiprocess functionality.

#### Node-locked licenses:

When running using the Multiprocess View in the ACE GUI, provide a node-locked license for every host machine running ACE. When running local/background execution, a single node-locked license is sufficient for all ACE sessions running on that host. When running using an external job submission system, every execution host needs its own node-locked license installed on that execution host. Talk to your Achronix FAE to ensure that your site has enough licenses to enable running with Multiprocess functionality.

The following is a common best practice when determining the needed ACE floating license counts to support multiprocess runs at a specific site, as well as choosing the best value for **Parallel Job Count** based upon the available floating license count.

- Start with the number of ACE users (U).
- Determine the maximum number (P) of parallel job execution hosts available to the job submission system. Alternately, if job execution hosts are each allowed to run more than one job at a time, determine the maximum number (P) of ACE multiprocess jobs the system could theoretically handle in parallel, which is usually determined by ACE memory requirements.

#### (i) Note

Remain aware that ACE memory requirements vary widely based upon design size/complexity, target device, and other factors. Remember that ACE logs its peak memory consumption at the completion of every flow step — this peak memory value is a useful guideline when determining expected multiprocess memory consumption.

Sites trying to minimize license usage, or where users must share the available execution hosts equally, the minimum number of required ACE licenses ( $L_{min}$ ) would then be  $L_{min} = U + P$ . Each user is then allowed to consume up to  $L_{user}$  licenses during their multiprocess sessions, where  $L_{user} = 1 + (P \div U)$ .

Sites that want to maximize job throughput, where individual users may be allowed to completely saturate the execution hosts, the maximum number of required ACE licenses ( $L_{max}$ ) would then be  $L_{max} = U + (P \times U)$ . Each user is then allowed to consume up to  $L_{user}$  licenses during their multiprocess sessions, where  $L_{user} = 1 + (P \times U)$ .

Each user must then set their **Parallel Job Count** to their personal value of  $L_{user} - 1$  (one license is reserved for the ACE session coordinating Multiprocess), which should then ensure that no multiprocess jobs run out of licenses.

308

### Important Considerations When Using Background Execution on the Local Host Workstation

Be aware that if the configured number of parallel processes is too high, total execution time actually takes longer than it would at lower values. The constraints are available memory and available processor cores, as well as the load from other processes running on the host workstation.

When choosing how many parallel background implementations to allow, it is very important that users ensure they do not exhaust the physical memory (RAM) available on the executing workstation, otherwise flow execution times quickly increase (due to the OS swapping memory pages to disk). Do take into account any other users on the same workstation, as well as the memory currently in use by the already-running ACE GUI and associated back-end acx process.

Each additional background ACE process takes multiple Gigabytes (GB) of memory — the exact amount varies depending upon the size of the design and the size of the target Achronix device (smaller designs and smaller devices, of course, take less memory). An estimate for large designs on a very large FPGA device is around 16GB of memory used for each background process. Again, this is only an estimate — designs nearing 100% device utilization may require more memory.

Be aware that with modern multi-core hyper-threading workstations, memory limits are usually the reason to constrain the parallel process count. It is not unusual to find workstations capable of running 8 simultaneous threads while only having 32GB of RAM. While on this example workstation, if the ACE user is running the flow on a very large FPGA design (where our estimate was around 16GB per background process), the most efficient parallel process count would likely be **1** or **2**; it would depend upon the Operating System, how much memory ACE and other currently-running processes are already using, and whether the user planned to continue using the workstation interactively while the background processes were executing. Since multiple iterations through the flow are likely, it may be worthwhile to track the total multiprocess duration at multiple parallel process counts, so as the user continues working, they can use the most efficient settings for that workstation.

In the majority of cases, the parallel process count should *at most* be the *lesser* of the following two values (remaining aware that lower values may be even faster):

### · processor constraint: 1 + T

where:

T = the total number of simultaneous threads supported by the workstation,

 $T = (P \times (C \times H))$ , where

P = the total number of processors in the workstation

C = the number of physical cores per processor

H = 2 if the cores are hyper-threaded, 1 if not

### • memory constraint: A / D

where:

*D* = amount of memory needed by the design, as reported in ACE log files (or the Tcl Console) during a prior flow execution

A = the total available (unused) RAM memory,

A = R - (O + G + B + U), where

R =total RAM installed in the workstation

*O* = amount of memory required by the Operating System

G = amount of memory required by the currently-running ACE GUI

*B* = amount of memory required by the currently-running ACE backend process (named acx or acx.exe in process lists)

*U* = amount of memory required by all other user processes expected to execute while the background processes are running

Continuing the example of the 8 thread 32GB workstation: If the workstation is running Linux, estimate the OS requires 0.5GB, the ACE GUI process requires 1GB, the GUI backend process (acx) requires 3GB, and no other user processes are running; the available memory A = (32GB - (0.5GB + 1GB + 3GB + 0GB)) = 27.5GB. If the log files of a prior run report the user design requiring a peak memory usage of 7GB, then the memory constraint value is  $(27.5GB / 7GB) \approx 3.9$ . The processor constraint would be (8 threads + 1) = 9. The lesser of the two values is the 3.9 for the memory constraint. So following the guidelines, the ideal parallel process count would be between **3** and **4**. To completely balance the two constraints for the design, the example user would need 7GB  $\times$  9 threads = 63GB of available memory before they could expect optimal performance running 9 parallel processes.

### 🕑 Tip

### **ACE Memory Utilization**

ACE logs the amount of memory (RAM) used by the backend as a design proceeds through the flow. This number is reported at the end of every flow step (page 235) in the log files and (when the GUI is running the flow in single process mode) in the Tcl Console. It is also possible to directly query ACE at any time to find out the peak backend memory usage in KB with the get ace peak memory usage (page 642)

Tcl command. These features should allow an educated decision to be made as to how much memory each parallel background process requires for the design, and thus how many processes may be executed in parallel within the current memory constraints.

### Example from log

Flow step "report\_timing\_final" completed in 1 seconds. Peak memory usage is 4917 MB.

### Example from Tcl Console View query showing peak memory use in KB

```
cmd> get_ace_peak_memory_usage
5035008
```

### Configuring ACE to Use an External Job Submission System

Due to the wide variety of grid, batch, queue and cloud job submission systems available, it is not possible for ACE to support each individual product specifically. Instead ACE Multiprocess can be configured to interface with whatever job submission system is available at the user site.

### **Minimum Requirements**

Currently, the following are required for the minimum functionality:

- The name of the job submission executable or script (providing a full directory path to the executable or script is recommended, though it may not be necessary in some PATH configurations).
- The job must be submitted in synchronous/blocking mode (the job submission process must not complete until the ACE child process/job has completed execution). ACE itself currently has no support for the tracking of job status through periodic queries as would be necessary with asynchronous/non-blocking jobs.

### A Warning!

A non-blocking/asynchronous job submission system currently risks data corruption, because ACE can no longer guarantee it knows when the job is complete, so ACE cannot properly manage data locking states across the simultaneously executing implementations.

- · An exit code of zero from the job submission process indicates success.
- A non-zero exit code from the job submission process indicates failure. The Multiprocess system simply reports success/failure based upon the exit code value.

Presently, if the job system at the user site is not already a synchronous/blocking system, then it is necessary for the user to write their own script or executable which approximates synchronous/blocking functionality.

In theory, this should be possible:

- 1. Submit the job.
- 2. Capture the unique identifier for that job.
- 3. Loop while querying the job status (using the previously captured unique job identifier from the job system) until completion is indicated.
- 4. Capture the job exit code.
- 5. Return the appropriate exit code (to ACE) indicating the success or failure of the job status.

After the job submission request completes, and after any network files have been written, the ACE Multiprocess GUI reads the output files from the submitted job, gathering the information needed for the Multiprocess Summary Report. The read of the result files only happens once per job.

If the user job submission process finishes before the submitted ACE job is complete (as would happen with a nonblocking job submission system), the ACE implementation output files are either missing or incomplete when queried, and the Multiprocess Summary Report shows that no results were found for that ACE job.

### **Optional Improvements**

When external job submission systems are properly configured, the following features are also available within ACE Multiprocess:

- · Support for killing or cancelling submitted jobs
- · Assignment of the job working directory
- Assignment of a job name
- Streaming real-time log output for each Job

#### Killing or Cancelling Already-submitted Jobs

For simplicity, the ACE Multiprocess system only manages the job through the (blocking) job submission process. The Multiprocess system currently does not track job identifiers or any special job status logged by the job submission process itself. When ACE needs to cancel or kill the job, it essentially sends a "kill" (technically a "SIGINT" in Linux) to the (blocking) job submission process. It is expected that this also kills/cancels the underlying ACE job. If this does not actually kill the underlying ACE job (or remove it from the appropriate job queue, etc.), then it becomes the responsibility of the ACE user to manually kill the job with the job submission tool.

### Job Working Directory

In some cases it might be necessary to specify the working directory of the ACE job as a command line argument to the job submission process. While ACE jobs lacking an explicit working directory assignment are known to run without errors in most situations, some job submission systems may require the explicit assignment of a working directory. The working directory specified by ACE for a job changes for each implementation and, typically, is the implementation directory itself.

### Job Name

It is extremely convenient for ACE Multiprocess to have a way to pass in the job name as a command line argument to the job submission process.

The job name does not aid ACE directly, but is intended to assist external users of the job submission system in tracking job status, job lifetime, queue management, etc. through other (non-ACE) tools.

The job name is currently made unique by concatenating the following information, with items in brackets replaced by their logical values:

ACE\_Multiprocess\_[user name]\_[project name]\_[implementation name]

Additionally, special characters found in the variable values are replaced by the underscore (\_) character.

#### Streaming Real-Time Job Log Output

ACE logs all of its normal output in a log file, which gets post-processed after job completion to verify how far ACE went through the flow, and to harvest the reported timing information for inclusion in the Multiprocess Summary Report. However, properly configuring the following can help the user track the progress of the ACE jobs as they run.

If the job submission process redirects or pipes the standard output and standard error streams from the underlying ACE job, so that the job submission process re-transmits that same data on its own standard output and standard error streams, then ACE may be able to show the streamed job output during the Multiprocess run.

If the underlying ACE job standard output and standard error streams are redirected to a file, preferably through user-managed command line options for the job submission process itself, then ACE may be able to show the streamed job output from the file during the Multiprocess run.

#### (i) Note

Due to various concerns such as network file write caching and the occasional complexity of shell redirection in spawned processes, this job submission log file option may be difficult to get working properly.

### **Configuring ACE**

The external job submissions are performed via a user-configurable command-line executable. The configuration is managed through the **Multiprocess: Configure Custom Job Submission Tool Preference Page** (page 209), reached by following the **(configured in Preferences)** hyperlink in the Multiprocess View. As a potentially useful example, by default ACE is configured to use GridEngine (see http://en.wikipedia.org/wiki/Sun\_Grid\_Engine) through the qsub command. (When using a system other than the GridEngine, users need to clear all fields on that preference page and provide the values which are appropriate for their own system.) For the configuration to work, the job submission command must be in the path (or have its path fully specified), and the ACE executable must be reachable from the job system execution hosts.

ACE is able to optionally provide some values to the job submission system if the related argument fields are populated. The optional values ACE may provide are:

The working directory for the ACE Multiprocess job

- The job name
- · The path and filename to be used by the job submission log file

It is extremely likely that additional command-line arguments are required by the job submission executable in order to meet the ACE minimum requirements. Additional arguments are also typically needed to assign execution queues, memory limits, etc. These additional arguments (and any argument values) should be specified on the preference page as well.

### A Caution!

Command-line arguments must not be specified in the **Job Submission Executable** field. Attempts to do so fail.

### Debugging Job Submission System Configurations:

If the job submission system is properly configured on the host machine, (meaning it is possible to successfully execute non-ACE tasks using the job submission executable from the command line), and ACE is still unable to successfully submit jobs to the system, please contact Achronix technical support.

### 🔒 Warning!

### **Potential for File Corruption**

Attempting to manually run the logged command on the command line (without the Multiprocess View additional automated safety locks in place) might cause ACE data file corruption.

While ACE does provide the complete attempted job submission command in the "Multiprocess Run Logs" section of the Multiprocess view, *DO NOT* copy the text of the attempted command and manually attempt execution from the command line. A large number of assumptions are made (including bypassing the normal project-level and implementation-level safety checks which prohibit file corruption) when ACE is executed using the provided command options and Tcl batch script — these assumptions are violated during manual execution attempts.

### Network File System Latency Concerns

When dealing with external job submission systems, network drive latency becomes a concern. The ACE multiprocess system waits for each external process to complete before it harvests the timing information for that implementation. To avoid potential hangs (where the multiprocess system mistakenly waits forever for a file to appear, or for a file to be completely written), there is a configurable timeout setting, which is by default 5 seconds. If, after the external process for an implementation has completed, the timing summary information cannot be found within the allowed number of seconds, then the **Multiprocess Summary Report** (page 256) shows the message "No Timing Results Found" for that implementation.

### (i) Note

A "No Timing Results Found" message for an implementation in the summary report means the timing information needed for the summary was not available within the allotted time. The allotted time may be increased using the **Allowed seconds of NFS write latency** setting in the **Multiprocess: Configure Custom Job Submission Tool Preference Page** (page 209), as shown in the image below.

| onfigurable<br>ibmission s | options for Multiprocess View<br>ystems.                                                                                                | v behavior when usin                        | g third-party job |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|-------------------|
| b Submissi                 | on Executable (required):                                                                                                               | qsub                                        | Browse            |
| orking Dire                | ctory Argument (optional):                                                                                                              | -wd                                         |                   |
| b Name Ar                  | gument (optional):                                                                                                                      | -N                                          |                   |
|                            | on Log Argument (optional):                                                                                                             | -0                                          |                   |
|                            | submission commandline opt                                                                                                              |                                             |                   |
| Argument                   | Value (optional)                                                                                                                        |                                             | New               |
| -sync                      | y                                                                                                                                       |                                             |                   |
| -j                         | y                                                                                                                                       |                                             | Edit              |
| -b                         | y                                                                                                                                       |                                             | Remove            |
| -q                         | **@@linux64                                                                                                                             |                                             |                   |
| -v                         | RLM_LICENSE                                                                                                                             |                                             | Up                |
| -1                         | mem_free=8G                                                                                                                             |                                             | Down              |
| JobName>                   | mandline:<br>mplWorkingDir> -o <pathtoir<br>-sync y -j y -b y -q **@@linux<br/>G,h_vmem=12G<br/>13\win5_main_64\system\cm</pathtoir<br> | d64 -v RLM_LICENSE<br>d64∖acx.exe -b -scrip | -Î<br>t_file      |
| :\output\20                | criptPath> -log_file <impllog< td=""><td>,</td><td>,</td></impllog<>                                                                    | ,                                           | ,                 |
| :\output\20<br>ImplBatchS  | criptPath> -log_file <impllog<br>nds of NFS write latency:</impllog<br>                                                                 | 5                                           | ,                 |

Figure 146 • Configure Custom Job Submission Tool Dialog

### Configuring the Desired Flow to be Followed by the Selected Implementations

All the implementations run through the Multiprocess View follow the same flow steps (page 235) through the flow (page 235), as configured in the Flow View (page 55). Thus, ensure that all optional flow steps are enabled/disabled as desired before starting multiprocess execution.

Additionally, in the section of the Multiprocess View labeled "Multiprocess Flow Management (page 78)", it may be chosen to stop the multiprocess flows early, prior to traditional "completion". For example, when designs are known to be incomplete, and thus known to fail the **Run Final DRC Checks** flow step, users often choose to stop the flow prior to running that failing flow step.

To stop all the multiprocess flows at a given flow step, simply select that flow step in the **Stop Flow After:** dropdown list. No subsequent flow steps are executed for any of the selected multiprocess implementations.

As a convenience, since optional flow steps are frequently chosen to be the final multiprocess flow step, if the selected final flow step is optional and not enabled, then as the multiprocess implementations are scheduled, the selected flow step is enabled for all the multiprocess implementations before they begin execution. For example, if

**Stop Flow After** is set to **Run Post-Route Timing Analysis** (an optional step), but this flow step is disabled in the Flow View, then the multiprocess flows will all enable that step and stop only after the **Run Post-Route Timing Analysis** flow step has completed.

#### Multiple PVT corners

If it is desirable for the summary report to contain results for multiple PVT corners at once for any implementation, then the Flow Mode (page 243) must be set appropriately for the implementation, and the flow must include/enable the **Run Sign-off Timing Analysis** flow step. See **Timing Across All Temperature Corners** (page 266) for more details.

### Selecting the Implementations to be Run in Parallel

To select the implementations to be run in parallel:

- In the Projects View (page 120), select the desired project (page 224). The Implementation Table within the Multiprocess view Select Implementations (page 78) section is updated to display data for the active project and implementation (page 231).
- In the Multiprocess View, ensure the Existing Implementations radio button within the "Select Implementations" section is selected. This limits the contents of the Implementation Table to just the implementations which already exist for the active project (generating and executing new implementations using option sets (page 0) is covered in Attempting Likely Optimizations Using Option Sets (page 392)).
- 3. In the Implementation Table, all listed implementations are selected (the checkbox in the Implementation

column will be checked) by default. Implementations may be selected/deselected in bulk with the 🗹 Select All

and Deselect All buttons. Individual implementations may have their selection toggled by clicking their checkboxes in the first column of the Implementation Table.

### 🕑 Tip

If the implementation table is not large enough (or is too large) for the full implementation list, simply collapse and/or expand one of the other sections in this view (left-click the section title). This causes the table to resize to exactly fit the current implementation list.

### **Starting Background Execution**

To start background execution:

- 1. When the parallel count has been set, the flow has been configured, and the desired implementations have been selected, click the Start Selected button, or the equivalent (S) Start Background Queue Execution action in the Multiprocess view local button-bar or menu, to begin background multiprocess execution.
- 2. After multiprocess execution has been started, the **Parallel Queue Count** and Implementation Table is disabled. They are not re-enabled until multiprocess execution is completed. In the **Multiprocess Run Logs** (page 81) section, a new tab is created for the logged output of each selected implementation. The log info in each tab is updated live as the corresponding implementation process executes (the displayed log info mirrors the information captured in the **log files** (page 233) for each implementation).
- 3. As implementations are queued, start execution, and complete execution, the implementations execution states (page 80) are updated in the implementation table, and each implementation log tab icon is also updated to show the current execution state.

(i) Note

Presently, it is not possible to control the order of implementation execution.

### 🔒 Caution!

For safety, all ACE Tcl commands (i.e., most ACE GUI interactions) are blocked while multiprocess execution is underway. Blocked Tcl commands are queued and allowed to run when multiprocess execution is completed. Similarly, multiprocess execution is blocked until all in-process and already-queued ACE Tcl commands (including running the Flow in the foreground) are completed.

### Stopping/Canceling Background Execution

All queued and executing background implementations may be quickly cancelled by selecting the <a> Stop All</a> button below the Implementation Table, or the equivalent (<a> Stop All Background Queue Execution</a> action in the Multiprocess view local button bar or menu.

It is also possible to cancel execution of individual implementations. This may only be done via the ( $\blacksquare$ ) Progress View. During multiprocess execution, a ( $\blacksquare$ ) button to show this view is visible in the lower-right of the ACE status bar. This view is also available by selecting **Window**  $\rightarrow$  **Show View**  $\rightarrow$  **Other...**  $\rightarrow$  **General**  $\rightarrow$  **Progress**. The Progress View displays all queued and currently-executing background tasks, including the tasks for the background

implementation processes. To the right of each listed incomplete background task is a (  $\blacksquare$  ) stop icon, which cancels/stops execution of that task. Because the Progress View can list more tasks than just the background multiprocess implementations, caution should be used to avoid cancelling/stopping the wrong task.

### Viewing the Results

After the first implementation completes execution, an HTML Multiprocess Summary Report (page 256) file is created and opened in ACE (the report file is created in the project directory, and is named

multiprocess\_summary.html. This action automatically overwrites previous multiprocess summary reports without prompting). As each subsequent implementation completes execution, the multiprocess summary report is updated with the latest data.

As implementations complete execution, their execution states (page 80) change appropriately. If an implementation encounters errors while running the flow, the execution state for that implementation becomes the Error state, which is reflected by the icon shown both in the log tab and the Implementation Table. In addition, the tooltip for the appropriate log tab and Implementation Table entry is updated to include a summary of the captured error messages. Error details are visible in the log messages shown in the tab, as well as within the Implementation Log (page 234) and Multiprocess Log (page 234) for that implementation.

316

#### Caution!

There is a known sequence whereby all multiprocess results are identical. If there is an existing project with previously generated option sets, and ACE has been upgraded to a newer version, it prompts when opening the existing project to reset the **implementation** (page 231) options to the defaults for the new version of ACE. The recommendation is to accept this reset as a new version of ACE may include new implementation options which are only applied by accepting this reset. At the same time, older implementation options that have been deprecated are removed.

The issue is that currently ACE resets all of the **option sets** (page 0) to the same default values. Subsequently, when a multiprocess flow is run with the new project, all results are identical. The workaround is, after having upgraded ACE to the new version and accepting the **implementation** (page 231) option reset, delete all the implementations other than the original base implementation and then regenerate the **option sets** (page 0).

### **Multiprocess Batch Mode**

#### Overview

To obtain the highest QoR, ACE supports running multiple different implementations in parallel using Multiprocess. Multiprocess is available from the ACE GUI and is described in:

- Multiprocess View (page 75)
- Running Multiple Flows in Parallel (page 307)
- Attempting Likely Optimizations Using Option Sets (page 392)

Multiprocess batch mode provides the same functionality as the GUI, but can be run from the ACE Tcl console command line or by using an external Tcl script. The relevant Tcl command is **run\_multiprocess** (page 693).

#### Modes

Similar to running Multiprocess from the GUI, Multiprocess batch mode must be run in the context of a currently Active Project and Implementation (page 231). The current active project is used as the basis for all the implementations that are run, with the current active implementation used as the basis for any newly-generated implementations.

Multiprocess batch mode supports three modes of operation:

- · Generate implementations from option sets (default setting).
- Seed sweep (-seed\_sweep).
- Use existing implementations (-use\_existing\_impls).

A full list of all options is given in the run\_multiprocess (page 693) manual page.

#### **Generate Implementations From Option Sets**

Running from option sets is the default mode of operation for Multiprocess batch mode and is used when neither -use\_seeds nor -use\_existing\_impls is specified. This mode generates fresh implementations for

every available option set definition. Previously existing implementations with the same name are overwritten. See Attempting Likely Optimizations Using Option Sets (page 392) for additional details.

The currently active implementation is always included as one of the executed flows when this mode is used.

#### Seed Sweep

The seed sweep mode generates fresh implementations (based upon the active implementation) for every specified seed value. Previously existing implementations with the same name are overwritten.

Seed sweep mode is selected by use of the -use\_seeds argument:

```
run_multiprocess -use_seeds {5 7 13}
```

The current active project and implementation forms the basis of each generated implementation, with the implementation option "seed" set to the given seed value as an override of the seed inherited from the active implementation.

Implementations created during seed sweep are named {active\_impl\_name}\_seed{value} (e.g., impl\_1\_seed18 for a seed value of 18 and an active implementation name of impl\_1).

The currently active implementation is always included as one of the executed flows when this mode is used.

#### **Use Existing Implementations**

The Use Existing Implementations mode does not generate any new implementations, but simply runs each of the named implementations. Use Existing Implementations mode is selected by use of the -use\_existing\_impls argument:

```
run_multiprocess -use_existing_impls {impl_1 impl_1_improved impl_1_experimental}
```

To run all existing implementations, specify:

run\_multiprocess -use\_existing\_impls [get\_impl\_names]

Unlike the other modes, the currently active implementation is *NOT* included as one of the flows run unless it is explicitly named in the -use\_existing\_impls list.

#### **Flow Steps**

An important principle to understand is that the enabled or disabled **Flow steps** (page 235) of the currently active implementation are inherited by all implementations executed during Multiprocess batch mode. Therefore, before commencing the Multiprocess batch mode, ensure that the currently active implementation has the desired flow steps enabled (and has the unwanted flow steps disabled).

In addition, Multiprocess batch mode can be configured to stop at an explicit flow step via the <code>-stop\_flow\_at</code> argument. This argument can be used to terminate each flow at a particular step. For example, if <code>report\_timing\_routed</code> is specified as the stop step, then none of the DRC or bitstream flow steps are performed (because those flow steps occur later than the chosen stop step; see the Flow Steps (page 235) page for the ordered complete listing of all default flow steps). Using the <code>-stop\_flow\_at</code> argument reduces the overall time taken for Multiprocess batch mode, as each implementation runs a reduced number of flow steps. After

Multiprocess batch mode has completed and an implementation has been found which achieves the desired QoR, then that implementation can be loaded into ACE, and the final flow steps executed. With the aforementioned example, which was stopped at report\_timing\_routed, the routed .acxdb can be loaded into ACE, and the DRC and bitstream generation flow steps subsequently executed to produced the required bitstream.

#### Note

If the flow step specified by -stop\_flow\_at is disabled in the active implementation when the multiprocess run begins, (as long as the current **Flow mode** (page 243) allows it) the step is explicitly enabled for the active implementation and all executed implementations.

#### **Getting Started**

The commands to start Multiprocess batch mode vary according to whether ACE is running in command-line mode, batch mode (using a script file), or from within the ACE GUI.

#### Command-line Mode (Interactive)

- 1. Open ACE in command line mode (ace -b). See Running ACE (page 282).
- 2. Use restore\_project (page 689) to load the project.
- 3. Set the active implementation (page 710).
- 4. (Optional) Use disable\_flow\_step (page 626) and enable\_flow\_step (page 634) to configure any flow steps desired/ needed or bypassed for all of the implementations that are to be run.
- 5. Issue run\_multiprocess (page 693) command. See examples (page 320) below.

#### Batch Mode (Script File)

Open ACE in command-line mode, passing in a script file. Use script arguments to specify the project name (ace -b -script\_file <my\_mp\_batch\_script.tcl>). See Running ACE (page 282).

| Code                                                                                                                 |
|----------------------------------------------------------------------------------------------------------------------|
| <pre>\$ ace -batch -script_file <my_mp_script> -script_args <my_project_name></my_project_name></my_mp_script></pre> |

An example script file, using the project names as the first argument is shown below.

#### Code

```
# Script file to run Multiprocess batch mode
set my_proj [lindex $argv 0]
# 1. Restore the project
restore_project $my_proj
# 2. Set active implmentation (to the default)
```

```
set_active_impl impl_1
# 3. (Optional) Ensure Run Estimated Timing Analysis flow step is enabled. Disable
Generate Bitstream
enable_flow_step report_timing_routed
disable_flow_step write_bitstream
# 4. Run Multiprocess batch mode generating new implementations from option sets
# Set to a maximum of 8 jobs
```

```
# Stop after Post-Route Timing Analysis.
```

run\_multiprocess -parallel\_job\_count 8 -stop\_flow\_at report\_timing\_routed

#### (i) Note

UG070

```
When running in the command-line mode, or batch mode, in order to cancel a Multiprocess batch mode run, CTRL+C must be used.
```

#### ACE GUI

- 1. Open ACE GUI.
- 2. Load the project (page 294).
- 3. Set the active implementation (page 302).
- 4. (Optional) Using the Flow View (page 55), select or deselect any flow steps desired/needed or bypassed for all of the implementations that are to be run.
- 5. In the Tcl console window, issue the run\_multiprocess (page 693) command. See examples (page 320) below.

#### **Examples**

#### **Running all Option Sets**

To run all option sets, using the existing maximum job count as specified in your ACE GUI preferences:

```
run_multiprocess
```

To run all option sets, limiting concurrent jobs to 8:

```
run_multiprocess -parallel_job_count 8
```

### **Running a Seed Sweep**

To run a seed sweep using preferred seed values:

run\_multiprocess -use\_seeds {2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31}

### **Re-running Four Existing Implementations**

To re-run four existing implementations all at the same time:

```
run_multiprocess -use_existing_impls {impl_1 impl_1_acx_mux_utl_seed impl_1_acx_seed21
impl_1_acx_seed33} -parallel_job_count 4
```

#### **Re-running an Existing Implementation**

To re-run an existing implementation, stopping just after running "write netlist final":

```
run_multiprocess -use_existing_impls {impl_1_seed88} -stop_flow_at write_netlist_final
```

#### **Running all Option Sets**

To run all option sets on the grid, with custom job submission parameters:

```
run_multiprocess -use_job_submission 1 -jobs_wd my_jobs_working_dir -jobs_name
my_job_name -jobs_log my_jobs_logfile -jobs_args {{-sync y} {-j y} {-b y}}
```

#### **Progress Monitoring**

Within the Tcl console or shell, run\_multiprocess checks each of the input arguments to ensure they are correct (including checking that any specified existing implementations exist) and then launches the requested number of parallel implementations runs. Within the Tcl console or shell, run\_multiprocess indicates the start and completion (success or failure) of each implementation run.

To monitor progress, use the Multiprocess Summary Report (page 256) (multiprocess\_summary\_report.html) file that indicates which implementations have completed and their timing summary. This report is generated regardless of whether the Multiprocess batch mode was run from a command shell, or from within the ACE Tcl console. This report can either be viewed external to ACE using a web browser, or within ACE as detailed below.

#### Viewing Multiprocess Summary Report within ACE

Open the Multiprocess Summary Report from the Projects view, by right-clicking the project.



Figure 147 • Open Multiprocess Report

The report can be refreshed by right-clicking the view and selecting **Refresh**, or by pressing the refresh hotkey, **F5**, when the report tab has focus (click the report first). The report view does not automatically update when using Multiprocess batch mode. This behavior differs from when Multiprocess is run directly from the GUI Multiprocess view, where the report view is automatically updated after each implementation completes execution.

| ACE Achronix<br>Project: quickstar<br>Generated by: m                                                                                                                                                                             | CAD Environment -<br>t_speedster_GUI<br>arkstracka on SJC<br>118-08-28 11:08:21 | - Versi<br>4154-N | on 0.X             |                                                    |  |                                           |                                                                                           |                              |                              |                        |                              |                         |                        |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|-------------------|--------------------|----------------------------------------------------|--|-------------------------------------------|-------------------------------------------------------------------------------------------|------------------------------|------------------------------|------------------------|------------------------------|-------------------------|------------------------|
| ming Resul                                                                                                                                                                                                                        | ts Summary                                                                      | ſ                 | -                  | ack<br>orward                                      |  |                                           |                                                                                           |                              |                              |                        |                              |                         |                        |
| This section shows the high-level timing n<br>If multiple columns of PVT timing informat<br>column, then that PVT was not executed<br>"Report all temperature corners" is enable<br>For further timing details, see the linked in |                                                                                 | S                 | Save background as |                                                    |  | olumn with<br>PVT will be<br>to the targe | during this mu<br>bold data repre<br>executed for e<br>et device will b<br>ts directory). | esents the a                 | ctive PVT. V<br>entation, un |                        |                              |                         |                        |
| ming Analysis                                                                                                                                                                                                                     | Summary                                                                         |                   | -                  | Select all<br>Paste                                |  |                                           |                                                                                           |                              |                              |                        |                              |                         |                        |
|                                                                                                                                                                                                                                   |                                                                                 |                   | 0                  | Create shortcut<br>Add to favorites<br>View source |  |                                           |                                                                                           | -                            | Post-Route                   |                        |                              |                         |                        |
| Imp                                                                                                                                                                                                                               | I Name                                                                          |                   | A                  |                                                    |  | )C                                        |                                                                                           |                              | p80V_125C                    |                        |                              | 080V_n40C               |                        |
| 1.00m 12                                                                                                                                                                                                                          |                                                                                 |                   | v                  |                                                    |  | it<br>p<br>k                              | Worst<br>Hold<br>Slack                                                                    | Upper-<br>Limit<br>Frequency | Worst<br>Setup<br>Slack      | Worst<br>Hold<br>Slack | Upper-<br>Limit<br>Frequency | Worst<br>Setup<br>Slack | Worst<br>Hold<br>Slack |
|                                                                                                                                                                                                                                   |                                                                                 | -                 | E                  | ncoding                                            |  | >                                         |                                                                                           |                              |                              |                        |                              |                         |                        |
| impl_1                                                                                                                                                                                                                            |                                                                                 | (Q                | P                  | rint                                               |  |                                           |                                                                                           |                              |                              |                        |                              |                         |                        |
| impl_1_acx_all_                                                                                                                                                                                                                   | opt                                                                             | (9                | ↓ P                | rint preview                                       |  |                                           |                                                                                           |                              |                              |                        |                              |                         |                        |
|                                                                                                                                                                                                                                   |                                                                                 |                   | R                  | efresh                                             |  |                                           |                                                                                           |                              |                              |                        |                              |                         |                        |
| impl_1_acx_cls_                                                                                                                                                                                                                   | pro_ext                                                                         | (Q                | -                  | Export to Microsoft Excel                          |  |                                           |                                                                                           |                              |                              |                        |                              |                         |                        |
| impl_1_acx_cls_                                                                                                                                                                                                                   | pro_seed                                                                        | clk               |                    | end to OneNo                                       |  |                                           |                                                                                           | <u>1466.8</u><br><u>MHz</u>  | +2.318ns                     | +0.073ns               |                              |                         |                        |
|                                                                                                                                                                                                                                   |                                                                                 |                   | P                  | roperties                                          |  | E                                         |                                                                                           |                              |                              |                        |                              |                         |                        |
|                                                                                                                                                                                                                                   |                                                                                 |                   |                    |                                                    |  | -                                         |                                                                                           | 1297.1                       |                              | 1                      |                              |                         | 1                      |

Figure 148 • Refresh Multiprocess Report View

Furthermore, progress monitoring can be achieved if a job submission system is used — completed jobs might be able to be monitored using the job submission system tool suite. Finally, to see the status of an individual implementation, open the <implementation>/log/multiprocessImpl.log file, and monitor updates to the individual implementation progress.

#### Stopping the Running Implementations

When running in command-line or batch mode, use CTRL+C to cancel a Multiprocess batch mode run. When calling run\_multiprocess in the ACE GUI Tcl Console view (page 146), (as with all other Tcl commands,) the command can be cancelled using the Progress view (Window  $\rightarrow$  Show View...  $\rightarrow$  Other  $\rightarrow$  Progress).

### **Detecting Changes to Project Source Files**

ACE provides a rich set of features to enable detecting changes to project source files against the state of the project files loaded into the ACE database during the Run Prepare flow step, as described in the following sections.

### Files Open in the ACE Editor Area

If a project source file is open in a text editor window, a pop-up dialog box appears offering to refresh the contents of the stale file in the ACE editor tab if the source file is changed on disk.

### Smart Change Detection Using Custom Checksums

Instead of caching timestamps for files to perform the checking, ACE caches custom file checksum values. The checksums are computed in a robust way that ignores comment lines and whitespace lines, so that only the actual Verilog netlist or SDC/PDC constraints commands are used in the checksum. This allows generated files, such as the Synplify netlist, to be regenerated from the same RTL which produces the same gate level netlist, but with different comments at the top, to be treated as an unchanged file. Timestamps are inherently fragile and change when a project is copied from one directory to another. This checksum approach is much more robust and does not flag a source file as changed unless its content is meaningfully changed.

### Saving the Active Implementation

When ACE saves an ACXDB file (when the state of the ACE database is saved for the active implementation), it caches the checksums of all project source files used to create that state in the DB. The project source file checksums are saved inside the .acxdb file.

### **Restoring the Active Implementation**

When ACE loads/restores an ACXDB file (when saved place and route data is loaded from the .acxdb file on disk into the ACE database for the active implementation), ACE checks all project source files and checksums on disk against the cached project source files and checksums inside the ACXDB file. If a project source file has been added to the current ACE project, removed from the current ACE project, or if its file checksum has changed, ACE prints a warning message to the Tcl Console and ACE log file. This alerts users that the saved ACXDB is out of sync with the current project source files.

### **Caching the Project Source File State**

The **Run Prepare** flow step is the first flow step, and is where all project source files are loaded into the ACE database from disk. Whenever the **Run Prepare** flow step is run, ACE caches the project source files and checksums for all files used in the active ACE project implementation.

### Automatic Checking while Running the Flow

Each flow step (**Run Place**, **Run Route**, Timing Analysis, Final DRC checks, etc.) checks the project source files (including the .acxprj ACE project file itself) and checksums on disk against the files and checksums cached at the beginning of **Run Prepare**. If any file is missing, added, or out of sync, ACE reports a warning at the end of each flow step to the Tcl Console and ACE log file:



Figure 149 • Missing, Added, or Out of Sync File Warning Example

### Warning Visualization in the Flow View

If any flow step reports a warning about out-of-sync files, all completed flow steps in the Flow View (page 55) are marked with a yellow warning icon instead of the green checkmark icon to indicate that the step is complete, but is out of sync with the source files on disk. The tooltip text in the Flow View shows all the warning messages.

Even when no flow step Tcl commands are running, the GUI checks the project source files and checksums every 5 seconds (by default) in a background thread. If any file becomes out-of-sync, all completed flow steps in the Flow View are marked with a yellow warning icon instead of the green checkmark icon to indicate that the step is complete, but is out of sync with the source files on disk.



Figure 150 • Out of Sync File Warning Example

### Pop-up Dialog Warnings

If the flow is running, a "Project Source Files Changed" dialog appears if a change to project source files is detected during the built-in check at the end of each flow step. The same warning messages that are printed to the Tcl console are displayed in the dialog. Optionally choose to cancel running the rest of the flow, or let the flow continue. The flow continues to run in the background until the choice is made. The pop-up dialog has a preference checkbox which allows disabling the pop-up from being shown in the future.

| 🚺 Proje                                                                               | O Project Source Files Changed                                                                                                                      |  |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| ?                                                                                     | The following project source file changes were detected:<br>Project Source File Changed: The checksum has changed on the project file:<br>C:/Users, |  |  |  |  |  |  |  |  |
| since the flow was started.<br>Do you want to cancel the currently running flow step? |                                                                                                                                                     |  |  |  |  |  |  |  |  |
| Do r                                                                                  | not display this pop-up in the future                                                                                                               |  |  |  |  |  |  |  |  |
|                                                                                       |                                                                                                                                                     |  |  |  |  |  |  |  |  |

Figure 151 • Project Source Files Changed Dialog Example

If the flow is not running, a different "Project Source Files Changed" dialog appears if a change to project source files is detected during the built-in check at the end of each flow step. The same warning messages that are printed to the Tcl console are displayed in the dialog. There is no choice for cancelling the running flow, since the flow is not

running. The pop-up dialog has a preference checkbox which allows disabling the pop-up from being shown in the future.

| O Proje                                                                                                                                                                                                      | O Project Source Files Changed                                                                                                                                          |  |  |  |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| The following project source file changes were detected:<br>Project Source File Changed: The checksum has changed on the project file:<br>C:/Users/ Documents/16t Projects/test_designs/adder/ace/adder.acxp |                                                                                                                                                                         |  |  |  |  |  |  |  |
|                                                                                                                                                                                                              | since the flow was started.<br>Project Source File Changed: The checksum has changed on the project netlist file:<br>.//common/adder_gate.v since the flow was started. |  |  |  |  |  |  |  |
| 🔲 Do i                                                                                                                                                                                                       | Do not display this pop-up in the future                                                                                                                                |  |  |  |  |  |  |  |
|                                                                                                                                                                                                              | OK                                                                                                                                                                      |  |  |  |  |  |  |  |

Figure 152 • Project Source Files Changed Dialog Example When Flow Is Stopped

#### (i) Note

#### **Minimal Pop-up Interruptions**

In general, pop-ups are minimized to only alert new changes. The Project Source Files Changed dialog appears only when a new change is detected. So if the gate level netlist file is changed while the flow is running, the pop-up (if enabled by the user preference) appears. If the same gate level netlist file is then changed several more times, no further pop-up appears since there has already been a notification that the file is different than the original source file. However, if a project constraints file (in addition to the gate level netlist) is then changed, the Project Source Files Changed dialog appears again to alert that now 2 source files are changed.

### **Managing Pop-up Preferences**

There is a user preference to enable/disable the Project Source File Changed pop-up at the bottom of the **Project Management Preference Page** (page 217). This preference setting is the same as that controlled with a checkbox in the Project Source File Changed Dialog. From the main menu bar, select **Window**  $\rightarrow$  **Preferences** and select **Project Management** on the left-hand side of the Preferences dialog. This preference page can be used to re-enable the pop-up if the checkbox in the dialog is enabled.

| Preferences                                                                         |                                                                                                  | $ \Box$ >               |  |  |  |  |
|-------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|-------------------------|--|--|--|--|
| type filter text                                                                    | Project Management                                                                               | ↓ → →                   |  |  |  |  |
| Configure DCC Connection<br>Configure JTAG Connection<br>Critical Path Diagram View | See ' <u>Colors and Fonts</u> ' to configure the font.                                           |                         |  |  |  |  |
| Floorplanner View Colors an                                                         | Close editors on active Implementation change                                                    | Always                  |  |  |  |  |
| Floorplanner View Optimiza <sup>.</sup><br>> General                                | Open Multiprocess summary on active Project change                                               | Always                  |  |  |  |  |
| Help                                                                                | Open reports on active Implementation change                                                     | Always                  |  |  |  |  |
| I/O Designer<br>Multiprocess                                                        | Only open most-recent report of a given type                                                     | Always                  |  |  |  |  |
| Netlist Browser<br>NoC Performance                                                  | Save changed editors from the active project before running the flow                             | Ask in a pop-up message |  |  |  |  |
| Placement Regions<br>Project Management                                             | Flow State Persistence Mode                                                                      | Project                 |  |  |  |  |
| Tcl Console View<br>User Advanced Preferences                                       | □ 'Reload Project' overwrites unsaved local project changes automatic                            | ally                    |  |  |  |  |
|                                                                                     | ☑ Enable background checking for project source file changes during                              | the flow                |  |  |  |  |
|                                                                                     | $\ensuremath{\boxtimes}$ Hide the pop-up dialog when project source files change during the flow |                         |  |  |  |  |
|                                                                                     | Project source file change background checking frequency (seconds)                               | 3                       |  |  |  |  |
|                                                                                     | Group reports by type                                                                            |                         |  |  |  |  |
|                                                                                     | ☑ Only show ACE HTML reports                                                                     |                         |  |  |  |  |
|                                                                                     | ☑ Only show the most recent report                                                               |                         |  |  |  |  |
| >                                                                                   | Rest                                                                                             | ore Defaults Apply      |  |  |  |  |
|                                                                                     | Apply                                                                                            | and Close Cancel        |  |  |  |  |

Figure 153 • Project Management Preference Page Example

| Option                                                                     | Description                                                                                                                                                |
|----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| See also:                                                                  | Link to Colors and Fonts preferences allowing choice of the font used in the Projects view.                                                                |
| Close editors on active implementation change                              | Can be used to automatically close open editors when the active implementation changes.                                                                    |
| Open Multiprocess summary on active project change                         | Can be used to automatically open the Multiprocess summary report when the active project changes.                                                         |
| Open reports on active implementation change                               | Can be used to automatically open implementation-specific reports when the active implementation changes.                                                  |
| Only open most-recent report of a given type                               | Can be used to automatically open only the most-recent report of a given type.                                                                             |
| Save changed editors from the active project before running the flow       | Can be used to automatically save all open editors before running the flow.                                                                                |
| Flow State Persistence Mode                                                | Choose whether or not the enabled/disabled flow step state<br>is persisted across ACE sessions per Session, per Project, or<br>is Disabled (not persisted) |
| Reload Project overwrites unsaved local project changes automatically      | Can be used to automatically overwrite unsaved local project<br>changes when Reload Project is used (without a confirmation<br>prompt).                    |
| Enable background checking for project source file changes during the flow | If enabled, project source files are periodically polled in the background to look for any changes made outside of ACE.                                    |
| Hide the pop-up dialog when project source files change during the flow    | If enabled, source file change notification is suppressed until the flow has finished running.                                                             |
| Project source file change background checking frequency (seconds)         | Determines how often to poll for background source file changes.                                                                                           |
| Group reports by type                                                      | If enabled, reports are grouped into subfolders in the Projects view tree.                                                                                 |
| Only show HTML reports                                                     | If enabled, only HTML reports are shown in the Projects view tree.                                                                                         |
| Only show the most recent report                                           | If enabled, only the most recent report is shown in any subfolder in the Projects view tree.                                                               |

### **Tcl Command Support**

The check\_project\_status Tcl command can be called to manually check file and checksum consistency outside of the built-in checks performed at the end of each flow step. If any file is missing, added, or out of sync, ACE reports a warning to the Tcl Console and ACE log file. This command only applies if the flow has run at least through the **Run Prepare** flow step and there is a design loaded in the ACE DB.

# **Custom Flow Steps**

Custom flow steps can be created by right-clicking the Flow view (page 55) tree and selecting **Create Flow Step**. The **Create a new Flow Step dialog** (page 163) appears:



| <del>.</del> | Flow | $\times$ |               |        |                     | ⊳    |      | 000 |  |
|--------------|------|----------|---------------|--------|---------------------|------|------|-----|--|
| ~            | • 🖯  | Pr       | epare         |        |                     |      |      |     |  |
|              |      | Δ        | Run Prepare   |        |                     |      |      |     |  |
|              |      | Δ        | Run Estimate  | ed Tim | ing Analysis        |      |      |     |  |
|              | 2    |          | Custom User   | Step   |                     |      |      |     |  |
|              |      | Δ        | Generate Pre  |        | Run Selected Flow S | Step | )    |     |  |
| ~            | - 2  |          | ace and Rout  |        | Re-Run Flow with "  | ici  | nit" |     |  |
|              | •    |          | Run Place     |        | Re-Rull Flow with   | -ICI | m    |     |  |
|              |      | 4        | Run Post-Pla  |        | Stop Flow           |      |      |     |  |
|              | •    | <b>A</b> | Run Route     |        |                     |      |      |     |  |
|              | _    |          | Run Post-Rc   |        | Clear Flow          |      |      |     |  |
| ~            | • •  |          | esign Comple  | Δ.     | Create Flow Step    |      |      |     |  |
|              |      |          | Post-Proces   | Ā      | Remove Flow Step    |      |      |     |  |
|              |      |          | Run Final DF  | (=×    |                     | ·    |      |     |  |
|              |      |          | Run Sign-off  |        |                     |      |      |     |  |
|              |      |          | Generate Fin  |        |                     |      |      |     |  |
|              |      |          |               |        | ulation Netlist     |      |      |     |  |
| ~            | • •  | FP       | GA Programn   |        |                     |      |      |     |  |
|              |      |          | Generate Bits |        | 1                   |      |      |     |  |
|              | U    | Δ        | FPGA Downle   | oad    |                     |      |      |     |  |
|              |      |          |               |        |                     |      |      |     |  |
|              |      |          |               |        |                     |      |      |     |  |
|              |      |          |               |        |                     |      |      |     |  |
|              |      |          |               |        |                     |      |      |     |  |
|              |      |          |               |        |                     |      |      |     |  |
|              |      |          |               |        |                     |      |      |     |  |

Remove a custom flow step by right-clicking the Flow view tree and selecting **Remove Flow Step**.

#### A Persistent Custom Flow Steps

Custom flow steps can be defined in an ACE\_INIT\_SCRIPT (page 282) to make them persistent across ACE sessions, so they are defined every time you launch ACE.

# Using the Tcl Console

Any operation that changes project or design data can be performed from the command line via a Tcl command (see the Tcl Command Reference (page 580)). The Tcl Console view (page 146) provides an interface from within the GUI for viewing and executing Tcl commands.

# Sending Commands from GUI Actions

Any action in the GUI that changes project or design data automatically sends a Tcl command through the Tcl Console view (page 146) to do the work. All Tcl commands generated by GUI actions are displayed in the Tcl console along with any output from the command.

```
😔 🚮 🛈 🔥 🐂 🗎 🕴 🗖 🗖
💷 Tcl Console ×
cmd> create_project "C:/code/projects/MyOtherProject/MyOtherProject.acxprj" -impl "impl_1"
Profile clear_design Tcpu 42/+2(1+1) Twck 17:23/+1 Mpk 4334/+0.0 Mcur 1492/-2638.6
cmd> save_project -no_db
cmd> set_active_impl -project "MyProject" "impl_1"
cmd> set_project_option -project {MyProject} — "autoselect_top_module" "0"
cmd> set_project_option -project {MyProject} — "autoselect_top_module" "1"
cmd> set_project_option -project {MyProject} — "check_final_timing" "1"
cmd> set_project_option -h
"ace::set_project_option" : This command sets options for a project. Only one option may be set at a time.
                      : The name of the project option to set a value for.  To see a list of valid project options, u
   <option_name>
   [<value>]
                        : The new value to set the project option to.
   [-project <string>] : The optional -project <projectName> is used to specify an alternate project (by name) to set
cmd>
```

Figure 154 • Tcl Console Example

# Sending Commands from the Console

To send a command from the Tcl console, enter or paste the command text in the entry area in the Tcl console view and press ENTER. Valid commands are highlighted in bold green.

All output from the command is displayed in the Tcl Console view under the command prompt. Informational messages are displayed in **blue text**. Warning messages are displayed in **yellow text**. Error messages are displayed in **red text**.

# **Command Highlighting**

Text entered in the Tcl console is checked against the valid set of user Tcl commands. Valid commands are highlighted in bold green.

# **Command Auto-Completion**

When typing into the Tcl console, pressing the **TAB** key pops up a Tcl command auto-completion dialog. If no autocomplete suggestions are found, an error beep sounds. Pressing the **TAB** key at an empty **cmd>** prompt pops up the full list of available commands. When the command auto-completion dialog is open, use the arrow keys to navigate up and down the list of choices and press the **Enter** key on a selected command to complete it at the command prompt. Typing while the command auto-completion dialog is open shortens or lengthens the list of valid commands, depending on the cursor position in the Tcl console view.



Figure 155 • Tcl Command Auto Completion Dialog Example

# Command Help

When the command auto-completion dialog is open, help text appears to the right of the command list for the selected command.

| Tcl Console ×                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | an 19                                                                                                                                                                                                                                                                                              |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>cmd&gt; create_project "C:/code/projects/MyOtherProject<br/>Profile clear_design Tcpu 42/+2(1+1) Twck 17:23/+1 Mpk 43<br/>cmd&gt; save_project -no_db<br/>cmd&gt; set_active_impl -project "MyProject" "impl_1"<br/>cmd&gt; set_project_option -project {MyProject} — "auti<br/>cmd&gt; set_project_option -project {MyProject} — "chei<br/>cmd&gt; set_project_option -h<br/>"ace::set_project_option" : This command sets options for<br/><option_name> : The name of the project option<br/>[<value>] : The new value to set the project</value></option_name></pre> | 334/+0.0 Mcur 1492/-2638.6<br>coselect_top_module" "0"<br>coselect_top_module" "1"<br>cck_final_timing" "1"<br>r a project. Only one option may be set at a time.<br>n to set a value for. To see a list of valid project options, u                                                               |
| <pre>[-project <string>] : The optional -project <project cmd=""> set set set set_clock_groups set_clock_latency set_clock_type set_clock_uncertainty set_cluster set_csr_clock set_data_check set_disable_timing</project></string></pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | <pre>tName&gt; is used to specify an alternate project (by name) to set "ace::set_active_impl" : This command sets the active implementation for the current ACE session. The active implementation controls which implementation the flow and project management commands are operating on.</pre> |

#### Figure 156 • Tcl Command Auto Completion Dialog Help Text Example

To view help text for commands, either bring up the command auto-completion dialog and select the desired command, or enter the command name at the **cmd>** prompt and use the -help argument to output the help text to the Tcl console.

| 💷 Tcl Console ×                      | A 📓 🛈 🙆 🛱 🗎 🖇 🗖                                                                                              |
|--------------------------------------|--------------------------------------------------------------------------------------------------------------|
| <pre>cmd&gt; create_impl -help</pre> |                                                                                                              |
| "ace::create_impl" : Thi             | s command creates a new implementation in a project. This command causes the new implementation              |
| <implname></implname>                | : The required <implname> argument is used to specify the name for the new implementation.</implname>        |
| [-project <string>]</string>         | : The optional -project <projectname> option is used to specify an alternate project (by name)</projectname> |
| [-copy]                              | : The optional -copy option is used to copy the implementation options of the active implementation          |
| [-not_active]                        | : If this option is set, the new project impl will not be activated and the active impl in the               |
|                                      |                                                                                                              |
|                                      |                                                                                                              |
|                                      |                                                                                                              |
|                                      |                                                                                                              |
|                                      |                                                                                                              |
|                                      |                                                                                                              |
| cmd>                                 |                                                                                                              |

Figure 157 • Tcl Command Help Option Example

# Text Limit

The Tcl console view has a default limit of 2000 lines. When this limit is reached, any new lines entered via commands or message text causes the text at the top of the Tcl Console to be pruned.

This line limit can be adjusted on the Tcl Console Preference page. Increase it as much as you'd like, but keep in mind that the greater the value, the more memory the Tcl Console view will potentially use.

#### (i) Note

Hitting the text limit does not affect the contents of the ACE log file. All messages continue to be logged in the log file and earlier messages are not removed.

# Clearing the Console

Text in the Tcl console view can be cleared by clicking the (🔤) **Clear Console** toolbar button in the Tcl console view. This action clears out all of the text currently in the readout area.

#### (i) Note

Clearing the console does not clear the contents of the ACE log file.

# Viewing the ACE Log File

All Tcl commands and messages issued during an ACE session are recorded in the ACE log file. If the Text Limit (page 334) is reached from excessive messages, it is sometimes useful to browse the log file for previous messages. To open the ACE log file in the editor area, simply click the ( i) **Display Log File** toolbar button in the Tcl Console view.

# **Object Type Prefixes**

There are a variety of different object types supported by ACE. Most of these object types have a special singleletter prefix designating the type. These type prefixes are useful to avoid name collisions (i.e., between a net and a pin with the same name).

Many Tcl commands (i.e., select (page 709)) require that these prefixes be used when commands are issued. Other commands (i.e., find (page 638)), by default, include these prefixes on the return values.

# Table 141 • Object Type Prefixes Used in ACE TclCommands (Sorted Alphabetically by Prefix)

| Prefix | Object Type   |
|--------|---------------|
| с:     | Critical Path |
| d:     | Device Port   |
| f:     | Fabric Pin    |
| i:     | Instance      |
| k:     | Clock Domain  |
| n:     | Net           |
| p:     | Port          |
| s:     | Site          |
| t:     | Pin           |

# Table 142 • Object Type Prefixes Used in ACE TclCommands (Sorted Alphabetically by ObjectType)

| Object Type   | Prefix |
|---------------|--------|
| Clock Domain  | k:     |
| Critical Path | c:     |
| Device Port   | d:     |
| Fabric Pin    | f:     |
| Instance      | i:     |
| Net           | n:     |
| Pin           | t:     |
| Port          | p:     |
| Site          | s:     |

# Creating an IP Configuration

Achronix FPGAs feature a wide variety of embedded IP. These highly flexible IP blocks require configuration for proper operation.

ACE includes a number of IP editors (page 9) and views (page 16) which work together to provide a guide through the process of correctly configuring IP. The data for these IP configuration editing sessions is stored in .acxip files, which may be saved and loaded for future reuse or modification.

Using the data stored in the .acxip files, ACE generates RTL wrappers (Verilog and VHDL) containing the specified configuration parameters around the appropriate Achronix macro cells, as well as appropriate .sdc and .pdc files to complete the IP timing and pre-placement configuration. These generated files may then be incorporated into the user design for synthesis and simulation.

#### (i) Note

Use of a generated VHDL wrapper also requires the generated Verilog wrapper (the VHDL simply wraps the Verilog instantiation).

Creating and editing IP configurations is typically performed from the ( <sup>199</sup>) IP configuration perspective (page 6). In addition to the IP Configuration editors, this perspective incorporates supporting views allowing:

10.1

- · Creating new IP configurations (IP libraries view (page 73))
- Viewing a graphical diagram of the IP configuration currently being edited (IP diagram view (page 71)); the diagram may show the macro interface, the dataflow, and/or the placement of the IP instance within the chip
- Navigating instantly to any page of the active IP configuration editor, while displaying the names and validity of each page (outline view (page 110))
- Viewing a detailed list of all the errors and warnings pertaining to all IP configuration files currently opened (IP problems view (page 73))
- Navigating directly to the source of the problem in the relevant IP configuration editor (IP problems view (page 73))

# Creating and Naming an IP Configuration

Switch to the IP configuration perspective either by clicking the ( $\stackrel{IB}{\longrightarrow}$ ) IP configuration perspective icon or selecting **Open Perspective**  $\rightarrow$  **IP Configuration** from the main menu. Select **File**  $\rightarrow$  **New**  $\rightarrow$  **IP Configuration...** from the main menu, or use the IP libraries view (see IP libraries view (page 73)) to open the New IP Configuration Dialog (page 180). After setting the location and name for the .acxip configuration file, click **Finish** to complete the process and activate the appropriate IP editor.

#### 👍 Caution!

The file name chosen for the .acxip configuration file is used as the module name for the generated Verilog module. A name must be chosen for the .acxip configuration file that is both a valid file name and also a valid Verilog module name which does not conflict with any other module names defined in the Achronix libraries.

For example:

- If the .acxip configuration file is named foo.acxip, the generated Verilog module is named module foo.
- If the .acxip configuration file is named LRAM.acxip, the generated Verilog module is named module LRAM.

If LRAM is a primitive in the Achronix libraries, the user design errors out in simulation or synthesis with module name conflicts.

# Setting the IP Configuration

From the IP Editor, use either the **« Back** and **Next »** or the **Outline view** (page 110) to navigate the editor pages, setting the appropriate values needed for the desired configuration. Any errors and warnings are displayed in the IP **Problems view** (page 73). Some IP editors also display supplemental graphical information in the IP **Diagram view** (page 71).

In addition to the list of problems within the IP problems view, to the left of most fields (sometimes also called

properties) there is a button with an icon indicating the validity of the value in that field. The green checkmark (💜)

indicates the value in the field has no problems. A warning ( <sup>(a)</sup>) or error ( <sup>(a)</sup>) icon is shown when the field value does have one or more problems. The tooltip for the button then shows the problem being reported for the associated field. Clicking the button transfers the application focus to the IP problems View, and within that view, selects all the problems associated with that field.

#### Note

In complicated IP, where there are many interactions between fields, there might be more than one problem entry associated with a single field.

### **Editable Fields**

Most of the properties/fields within the IP Editor pages are editable and correspond (sometimes loosely) to parameters in the underlying Verilog macros.

Editable fields are meant to be modified in a top-down, left-to-right order. This order is recommended because some of the field values affect the validity of downstream values, and ACE often tries to help keep configurations legal by automatically changing downstream values when they are incompatible with newly-edited upstream values.

Often, editable fields may be temporarily disabled when upstream choices cause the field to become irrelevant, or to have only a single legal value. Disabled editable fields become read-only and are shown with an alternate background color, typically grey.

#### 🕑 Tip

Modifications should be made to fields within the IP configurations editors in a top-down, left-to-right order. When editing an upstream value, it often causes downstream values to be overwritten without warning.

### **Calculated Fields**

Some of the fields in the IP editor pages are never editable. These fields contain calculated values based upon the current contents of user-editable fields. These calculated fields are provided for informational purposes.

Many of these calculated values have limited ranges of legal values — when the calculated value falls outside the legal range, the calculated value color changes to indicate a problem. As when user-editable IP configuration properties fall outside a legal range, an IP problem entry (see IP problems view (page 73)) is created. But an IP problem created by a calculated value field does not "blame" the calculated value field, it instead blames one of the user-editable properties involved in its calculation. While only one field is blamed in an IP problem entry, be aware that all active fields that might be involved in the calculation are listed in the IP problem entry as potential fields which, when changed, might fix the IP problem

#### (i) Note

While only one field is allowed to be blamed in an IP problem entry, remain aware that all active fields that might be involved in the calculation are listed in the IP Problem entry. Any one of these listed fields, when changed, might fix the IP Problem.

### **IP Editor Navigation**

Navigate between sequential IP editor pages by using the **«Back** and **Next »** buttons. When one of these buttons becomes disabled, it means there are no further pages of configuration information in the indicated direction.

The currently active page is always selected in the **outline view** (page 110). Navigate directly to a given IP configuration page simply by selecting the desired page name in the **Outline View**. Be aware that pages may be created or removed from the outline view based upon user changes to the IP configuration editable fields.

Left-click any text in the IP diagram view (page 71) to turn to the IP configuration editor page containing the settings for that text.

Double-click a table entry in the IP problems view (page 73) to turn to the IP configuration editor page containing the property being blamed for the selected IP problem.

# Generating the IP Design Files

After setting the IP configuration, click the (<sup>SCE</sup>) **Generate IP Design Files** icon to open the **Generate IP Design Files dialog** (page 176). Select the desired options such as whether to generate the Verilog wrapper, VHDL wrapper, timing constraints, placement constraints, etc. After selecting the desired options and file paths, click **Finish** to create the selected files.

#### (i) Note

The generated VHDL RTL wrapper is not standalone. It requires the generated Verilog RTL file.

### Adding Configuration Files to a Project

Existing configuration files (from other projects, or that were removed from the current project at some point) can be manually added to the active project. Use the procedure under adding source files (page 296) to add the configuration file and its related source files to the active project.

# Viewing the Floorplanner

This section covers working with the floorplanner.

# Opening and Closing the Floorplanner's Fly-Out Palette

To open and close the Floorplanner view fly-out palette of view options:

1. Click the ( 🖣 ) Fly-out button on the far right side of the Floorplanner View (page 45) to open the fly-out palette.

#### (i) Note

While the fly-out palette is open, it may be resized by clicking and dragging its left border.

2. When the view options are configured, click the ( ) Fly-in button on the left side of the fly-out palette to close the fly-out palette.

### Zooming the Floorplanner In and Out

There are several ways to zoom in and out in the Floorplanner View (page 45).

#### (i) Note

Zoom levels are always in powers of 2 (i.e., zoom in is at 200% and zoom out is at 50%). Therefore, it might not be possible to zoom in to perfectly fit a given area.

To zoom in and out with the mouse wheel:

- 1. Hover the mouse cursor over the desired point from which to zoom in or out in the Floorplanner view.
- 2. Move the mouse wheel forward to zoom in or backward to zoom out.

To zoom in and out using keystrokes:

- 1. Hover the mouse cursor over the center of the desired area from which to zoom in or out in the Floorplanner view.
- 2. Type either "Z" or "+" on the keyboard to zoom in or "z" or "-" to zoom out.

To zoom in and out using the **Zoom Tool**:

- 1. Select the  $(\bigcirc)$  Zoom Tool from the view toolbar.
- 2. To zoom in on an area, click in the upper left corner of the area desired and drag the mouse to the lower right until the zoom rectangle encloses the area desired. To zoom out, click the point on the Floorplanner view from which to zoom out and drag the mouse to the upper left until the zoom out label indicates the desired zoom level.

To zoom in and out with the **Placement Tool**:

- 1. Select the ( 🚏 ) Placement Tool from the view toolbar.
- 2. Hover the mouse cursor over the point from which to zoom in or out in the Floorplanner view. Click the left mouse button to zoom in or the right mouse button to zoom out.

To zoom in and out with the **Zoom In** and **Zoom Out** buttons:

- 1. Pan to the area from which to zoom in to or out in the Floorplanner view.
- 2. Click the ( 🔍 ) Zoom In button to zoom in or the ( 🔍 ) Zoom Out button to zoom out.

# **Floorplanner Panning**

To pan with the scroll bars:

- 1. Click and drag the vertical scroll bar to pan up and down or click and drag the horizontal scroll bar to pan left and right.
- 2. In Linux, place the mouse cursor over a scroll bar, then roll the mouse wheel.

To pan with key-strokes:

- 1. Use the arrow keys on the keyboard to pan left, right, up and down.
- 2. To scroll faster, press the CTRL key while pressing the arrow keys.

#### To pan with the **Panning** tool:

- 1. Select the ( ) Panning tool from the view toolbar.
- 2. Click and drag the view with the mouse to pan around.

#### To pan with the **Placement** tool:

- 1. Select the ( 👆 ) **Placement** tool from the view toolbar.
- 2. Ensure that drag-scrolling is enabled. This setting can be toggled by tapping the "Q" key, or by clicking the (**1**) **Toggle Drag-Scrolling** tool bar button.

3. Begin dragging an instance. When close to any of the view edges, the view automatically scrolls in that direction. The size of the view "drag scroll margins" as well as the speed the view drag-scrolls, can be adjusted on the Floorplanner view Colors and Layers Preference page (page 198).

#### 🕑 Tip

If panning the view is too slow, in the Floorplanner view Optimizations Preference page (page 203), there is a setting, When panning, show only background layer, to improve panning/scrolling performance by reducing the amount of graphic rendering performed during the pan/scroll operation.

# Selecting Floorplanner Objects

To select objects with keystrokes:

- 1. In the (  $\[Begin{subarray}{c} \]$  ) Selection section of the view fly-out palette, check the object types to select.
- 2. Press and hold the S key on the keyboard to start a selection rectangle at the current mouse cursor position (clearing/replacing the previous selection).

Optionally, press and hold the SHIFT+S keys to start a selection rectangle at the current mouse cursor position (adding to the current selection instead of replacing it).

- 3. Drag the mouse while holding down the key or keys on the keyboard to create a selection rectangle which includes the objects desired.
- 4. Release the key(s) to apply the selection.

To select objects with the Selection Tool:

- 1. Click the ( 🗟 ) Selection Tool on the view toolbar.
- 2. From the Selection section of the view fly-out palette, check the object types you wish to select.
- 3. Also, ensure the Action control in the fly-out palette is set to Select.
- 4. Click the desired object, or click and drag with the left mouse button in the view to create a selection area rectangle (clearing/replacing any previous selection).

Optionally, hold the CTRL key when clicking/dragging (adding to the previous selection instead of replacing it).

5. Release the mouse button to apply the selection.

Additionally, right-click individual objects and select Add to Selection from the context menu popup.

Further details about the ACE selection set are available on the Selection View (page 137) page.

### **Deselecting Floorplanner Objects**

To deselect objects with key strokes:

- 1. Select the ( 🗟 ) Selection Tool from the view toolbar.
- 2. From the Selection section fly-out palette, check the object types to deselect.
- 3. Press and hold the D key on the keyboard to start a selection rectangle at the current mouse position.
- 4. Drag the mouse while holding down the key to create a selection rectangle including the objects to deselect.
- 5. Release the D key to remove the objects within the rectangle from the current selection set.

To deselect objects with the Selection Tool:

- 1. Select the (  $\$  ) **Selection Tool** from the view toolbar.
- 2. From the **Selection** section of the fly-out palette, check the object types to deselect. Also, ensure the Action control is set to **Deselect**.
- 3. Click and drag with the left mouse button in the view to create a selection rectangle.
- 4. Release the mouse button to remove the objects from the current selection set.

# **Toggling Floorplanner Mouse Tools**

To toggle the mouse tools:

1. Press the ALT key on the keyboard to switch between tools, or simply click the desired mouse tool on the view toolbar.

# Filtering the Floorplanner View

It is often useful to filter the floorplanner view (page 45) graphics to see only objects of interest.

### **Filtering with Layers**

Simple filtering of the view by object type is accomplished with the Layer options in the view fly-out palette.

By checking or unchecking the individual layers, all members of a given object type may be shown or hidden. Sites, Instances, Clock Routes, and Non-clock Routes may be manipulated in this way.

Because routes are always painted on top of instances, which themselves are painted on top of sites, it is often necessary to disable the painting of the topmost layers when they obscure the lower layers.

#### (i) Note

The hiding of individual objects of a given object type layer may be overridden if that object is selected or highlighted, depending upon the current preference settings. See the **floorplanner view colors and layers preference page** (page 198) for more information about changing these preferences.

### **Filtering with Selection**

Selection overrides the layer filters. When a layer is turned off, selected objects (those in the current ACE selection set) remain visible. So, for example, to see just the selected instances, turn off the instances and routes layers. The selected instances remain visible, while all other placed instances (and all non-selected nets) are hidden.

To filter with selection in the floorplanner view:

- 1. Add the desired objects to the current ACE selection set.
- 2. In the ( 🗧 ) Layers section of the fly-out palette, un-check the object types to hide.

# **Choosing Floorplanner Object Tooltips**

For instant feedback on instance, net, or site names in the **floorplanner view** (page 45), a tooltip (hover text) can be enabled. In addition, the contents of the tooltip can be printed to the **Tcl Console View** (page 146) for easy copy and paste.

To get object tooltip text:

- 1. In the ( ) Tool Tip Text section of the fly-out palette (page 49), enable the checkboxes for the object types with data that should be contained in the tool tip text.
- 2. In the floorplanner view, hover the mouse cursor over objects to display the tool tip text.

#### 🕑 Tip

#### **Capturing Tooltip Content:**

Optionally, press the P key on the keyboard while tooltip text is visible to print the tooltip text to the TCL console view, allowing easy copy and pasting to create TCL commands or scripts.

# Viewing Floorplanner Object Labels

A variety of object labels are available when displaying objects in the **floorplanner view** (page 45) (see "Fly-Out Palette").

To display object labels in the Floorplanner view:

- 1. In the ( 🗏 ) Labels section of the fly-out palette, select which object labels to display.
- 2. Pan and zoom to objects of interest to view the object labels.

#### (i) Note

Some labels are not painted unless the view is zoomed in far enough to display the full extent of the text.

# Highlighting Objects in the Floorplanner View

There is typically a tremendous amount of visualization data available in the **floorplanner view** (page 45). Because viewing all of the data simultaneously can be overwhelming, ACE provides tools such as selection and highlighting so that a particular subset of the entire design may be visualized within the floorplanner view. For simple, short-term subset visualizations, this functionality is provided by the ACE selection set as managed in the **selection view** (page 137). For longer-term visualizations, or to simultaneously compare and contrast multiple design subsets, ACE provides the

#### highlight (page 665)

Tcl command. As with the ACE selection set, applied highlights are visibly displayed on placed/routed objects in the floorplanner view. Highlight colors are also shown in several tabular views such as the **netlist browser view** (page 81), where the highlight colors of instances are displayed in their own table column.

#### (i) Note

#### Only instances, nets, and paths may be highlighted.

Currently highlights are only supported for individual instance, net, and path object types (remember to use the correct **object type prefixes** (page 334) when using the Tcl commands).

Most of the views within the floorplanner perspective provide context-sensitive functionality to manage highlights, through buttons in each supporting view to ( $\checkmark$ ) **Highlight** chosen objects, ( $\searrow$ ) **Un-highlight** chosen objects, or to (

In button's in each supporting view to ( ) inging it chosen objects, ( ) in figure chosen objects, or to indicate the supporting view to ( ) inging it chosen objects, ( ) is in the support of the su

independently of the other views, allowing one color for a selection highlight, and an alternate color for a netlist browser highlight). Additionally, some of the views (typically those representing multiple aggregations of objects)

include a button to ( *A*) **Auto-highlight** all objects within that view, with each aggregation automatically using a different color.

#### ▲ Caution!

In tabular views (such as the clock domains view (page 21)), highlights may be shown and manipulated for aggregations of objects (as with the highlight color of a clock domain row representing the shared highlight color of all instances within that clock domain).

Be aware that if there are multiple highlight colors within the aggregation, then no highlight color is shown for the aggregation row in the table. The aggregation only displays a highlight color in the table if every single object within the aggregation has the exact same highlight color.

Additionally, when a new highlight (or un-highlight) is applied to an aggregation, it affects all individual members of that aggregation. The highlight color of all contained individual objects are overwritten with the new highlight value.

The following Tcl commands are available to manage highlights:

- highlight (page 665)
- apply\_highlights (page 615)

#### (i) Note

There is no specific Tcl command to remove existing highlights. Instead, exclude the -rgb flag when calling highlight, which effectively applies a non-highlight to the specified object(s).

### Selection vs. Highlighting

Despite some similarities, selection and highlighting serve two different purposes in ACE. They are compared and contrasted in the table below.

#### Table 143 · Selection and Highlighting Differences

| Selection                                                                                                                                                                  | Highlighting                                                                                                                                                                                                                                 |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| There is a single ACE Selection Set.                                                                                                                                       | Each object in a design may have its own unique highlight color, or a single highlight color may be applied to multiple objects, even if they are different object types.                                                                    |
| The Selection color (a very bright green by default) is managed globally for each object type, through the floorplanner view colors and layers preference page (page 198). | Each Tcl call to highlight an object must specify which color to use for that call. When using the ( ) <b>Highlight</b> action from within a view, the ( ) <b>Choose Highlight Color</b> for that view is used.                              |
| A selection is very short-term, and is never saved/loaded between sessions.                                                                                                | A highlight is expected to be long-term, and highlight colors on objects are saved<br>in .acxdb files when Implementations (page 231) are saved. As a result, prior<br>highlights are restored when an implementation .acxdb file is loaded. |

| Selection                                                                                        | Highlighting                                                                                                                                                                                                                                                                                                                                                              |
|--------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Selection may be applied (through the appropriate view) to aggregations of objects               | Highlights may also be applied (through the appropriate view) to aggregations of objects.                                                                                                                                                                                                                                                                                 |
| Selection membership may be managed through the selection view (page 137)                        | There is presently no special view to manage highlights.                                                                                                                                                                                                                                                                                                                  |
| The selection color of an object (or aggregation) is only rendered within the floorplanner view. | The highlight color is rendered not only within the floorplanner view, but also<br>(sometimes as individual objects, sometimes in aggregate) as a color tile in most<br>of the tabular supporting views of the floorplanner perspective. When the<br>highlight color is displayed in a tabular view, it is typically shown within its own<br>column of color tile values. |

### **Objects May Be Both Selected and Highlighted Simultaneously**

It is possible for objects to be both selected and highlighted at the same time. When this occurs, the exact precedence of the color used to render the object is handled differently depending upon the object type, and which view is being rendered.

When paths are displayed in the floorplanner view, the selection color for a path takes precedence over the highlight color (the selection color for a path is managed on the floorplanner view colors and layers preference page (page 198)).

When instances are displayed in the floorplanner view, the selection color of an instance takes precedence over every other color (the selection color for an instance within the floorplanner view is managed on the floorplanner view colors and layers preference page (page 198)).

#### Note

It is possible to change the relative render priorities of some of the states of an instance on that same floorplanner preference page. The **instance states** (page 262) section discusses this in further detail.

| <ul> <li>Show Overassignment Color on Instances with Site Overassignment Errors</li> <li>Show Fixed Color on Instances with Fixed Placement</li> <li>Show Locked Color on Instances with Locked Placement</li> <li>Show Site Borders on Placed Instances</li> </ul> | Instances<br>Show Highlight Color of Instances on | Top of Overassigned/Fixed/Locked Color |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|----------------------------------------|
| Show Locked Color on Instances with Locked Placement                                                                                                                                                                                                                | Show Overassignment Color on Insta                | nces with Site Overassignment Errors   |
|                                                                                                                                                                                                                                                                     | Show Fixed Color on Instances with Fi             | ixed Placement                         |
| Show Site Borders on Placed Instances                                                                                                                                                                                                                               | Show Locked Color on Instances with               | Locked Placement                       |
|                                                                                                                                                                                                                                                                     | Show Site Borders on Placed Instance              | 5                                      |

#### Figure 158 • Floorplanner Preferences Instance State Render Management

Uniquely among the object types, nets may display both their selection and highlight states simultaneously in the floorplanner view, though this is disabled by default (for performance reasons). By default, when nets are displayed in the floorplanner view, the selection color takes precedence over the highlight color. But nets, being simple lines, are handled specially, as configured in the **floorplanner view colors and layers preference page** (page 198). There, it is possible to choose to have the net highlight rendered on top of the net selection, or vice versa. It is also possible to choose which line thickness (width) shall be used to render both the selection line and the highlight line for the net. By making the bottom line thicker than the top line, it is thus possible to have a "halo" effect of one color outlining the other color for the same net(s).

| Nets/Routes Always Show Highlighted Nets      |   |  |
|-----------------------------------------------|---|--|
| Always Show Selected Nets                     |   |  |
| Show Selected Nets on Top of Highlighted Nets |   |  |
| Thickn <u>e</u> ss of Highlighted Nets        | 1 |  |
| Thickness of Selected Nets                    | 3 |  |

#### Figure 159 • Non-Default Preference Configuration Showing Both Selection and Highlights for Nets

#### 👍 Warning

#### Floorplanner Performance:

Choosing to render highlighted nets thicker than a single pixel wide might have a significant negative performance impact upon floorplanner rendering speeds of large designs at some customer sites. Exact details depend upon specifics of the workstation hardware, OS/kernel version, and the active desktop graphics rendering library.

Rendering selected nets at a thickness greater than one is expected to have little-to-no performance impact upon floorplanner rendering speeds.

### **Batch Mode Highlighting**

Batch-mode highlights in Tcl are supported through the use of the optional -batch command-line argument for the **highlight** (page 665) command. This flag blocks the transmission of incremental highlight updates to the ACE GUI, significantly speeding up execution times when applying multiple scripted highlight changes in sequence. When all batched changes to the highlights have completed, **apply\_highlights** (page 615) must then be called to send the highlight updates to the GUI for display.

#### Example Tcl sequence to highlight all instances orange, except instance names starting with "temp"

```
highlight [find {*} -insts] -rgb {255 128 0} -batch ;# applies orange highlight to all
insts
highlight [find {temp*} -insts] -batch ;# removes highlights from all insts
starting with "temp"
apply_highlights ;# sends pending highlight changes
to GUI
```

# Pre-Placing a Design

This section details manual pre-placement of instances in ACE.

345

### Placing an Object

Currently in ACE, there are two types of objects that can be placed: instances and ports. Placing a port is equivalent to placing the instance to which the port is connected in the design.

There are two types of manual pre-placement in ACE: soft and fixed. Fixed placement locks the placement of an instance to a site such that the placer is not allowed to move the instance to another site. Fixed placement is the only type of pre-placement command recommended. Soft placement is used as a global placement hint to the placer.

#### Caution!

Soft placement is not fully functional.

To begin pre-placement activity, the **Run Prepare** flow step for the active implementation must be run. Placing an object automatically resets the flow status to start over from the **Run Prepare** step.

To place an object from the Search View (page 133), Selection View (page 137), or Netlist Browser View (page 81):

1. In the **Placement** (<sup>\*</sup>) section of the Floorplanner View (page 45) fly-out palette, check the placement options desired.

(i) Note

Fixed placement is recommended for all pre-placement.

- 2. Pan and zoom the Floorplanner view until the destination placement site is visible.
- 3. In the starting view (Search view, Selection view, or Netlist Browser view), click and drag the desired object from the starting view onto the desired destination placement site in the Floorplanner view.

#### (i) Note

The icon on the now-placed object in the Search view, Selection view, and/or Netlist Browser view is now updated to reflect the placement status.

To re-place an object within the Floorplanner view (move from one placement site to another):

#### (i) Note

This operation alters an existing site assignment (placement) for an instance. Sometimes it is helpful to start with a fully placed and routed design, and then fine-tune the placement using this operation.

Be aware that changing the placement of an already-placed object clears the current routing data for all connections to and from that instance.

1. In the **Placement** ( ") section of the fly-out palette, check the placement options desired.

#### (i) Note

Fixed placement is recommended for all pre-placement.

- 2. Click the **Placement Tool** ( **\***) on the view toolbar to change the mouse behavior within the view to drag and drop placement mode.
- 3. Pan and zoom the Floorplanner view until both the to-be-moved instance and its intended destination placement site are visible.
- 4. In the Floorplanner view, click and drag the placed instance from its current placement site onto the new placement site.

### **Changing Between Fixed and Soft Placement**

There are two types of placement in ACE: soft and fixed. Fixed placement locks the placement of an instance to a site such that the placer is not allowed to move the instance to another site. Fixed placement is the only type of preplacement command recommended. Soft placement is used as a global placement hint to the placer.

#### 👍 Caution!

Soft placement is not fully functional.

### Fixing placement of soft-placement objects

To fix placement with key-strokes:

- 1. In the **Selection** ( ) section of the Floorplanner View (page 45) fly-out palette, check the object types having placement that should be fixed.
- 2. Press and hold the **f** key on the keyboard to start a selection rectangle at the current mouse position.
- 3. Drag the mouse while holding down the **f** key on the keyboard to create a selection rectangle which includes the objects desired.
- 4. Release the key to fix the placement of the enclosed objects.

To select objects with the Selection Tool:

- 1. Select the Selection Tool ( 🗟 ) from the Floorplanner View (page 45) toolbar.
- 2. From the **Selection** section of the fly-out palette, check the object types having placement that should be fixed. Also, ensure the **Action** control is set to **Fix Placement**.
- 3. Click and drag with the left mouse button in the view to create a selection rectangle. Optionally, hold **CTRL** while dragging to add to the selection.
- 4. Release the mouse button to fix the placement of the activated objects in the selection.

#### (i) Note

Not using CTRL clears the previous selection!

### Un-fixing (softening) placement of fixed-placement objects

To un-fix placement with key-strokes:

- 1. In the **Selection** ( ) section of the Floorplanner View (page 45) fly-out palette, check the object types with placement that should be un-fixed.
- 2. Press and hold the **u** key on the keyboard to start a selection rectangle at the current mouse position.
- 3. Drag the mouse while holding down the **u** key to create a selection rectangle which includes the desired objects.
- 4. Release the key to un-fix the placement of the enclosed objects.

To select objects with the Selection Tool:

- 1. Select the **Selection Tool** ( 🗟 ) from the Floorplanner View (page 45) toolbar.
- 2. From the **Selection** section of the fly-out palette, check the object types with placement to be fixed. Also, ensure the **Action** control is set to **Un-fix Placement**.
- 3. Click and drag with the left mouse button in the view to create a selection rectangle. Optionally, hold **CTRL** down to add to the selection.
- 4. Release the mouse button to un-fix the placement of the activated objects in the selection.

Not using CTRL clears the previous selection!

### Group Placement Mode

#### A Caution!

#### **Advanced Functionality**

Group placement mode is advanced functionality, and has multiple failure cases. Group placement should only be attempted by expert users who understand all the caveats.

During normal drag-and-drop placement operations (when **Group Placement** is disabled), only the placement of a single instance is altered.

When **Group Placement** is enabled, ACE attempts to *shift* the placement of all instances in the current ACE selection set. Group placement cannot be used on instances that are not already placed – attempting to perform group placement on unplaced instances results in failure.

When group placement is attempted, the placement shift is based upon the relative change in placement site coordinates of a single *anchor* instance. The anchor instance is the instance which is dragged-and-dropped. The relative change is calculated based upon the coordinates of the anchor instance initial site and the destination site.

If the starting site coordinates of the anchor instance are at (X=15000, Y=30000) and the destination site coordinates for the anchor instance are at (X=20000, Y=40000), the coordinate shift is (X=+5000, Y=+10000). For each instance in the selection set, this coordinate shift is applied to that instance starting site coordinates; the resulting X and Y values are the coordinates where the destination site is sought for that instance. If no destination site is found at those adjusted coordinates, the entire group placement adjustment is aborted for all instances, and none of the instances are moved. All instances are left untouched in their initial placements, including the dragged-and-dropped anchor instance.

<sup>(</sup>i) Note

#### 🕑 Tip!

Reminder: The anchor instance must already be a member of the ACE selection set when the drag is initiated. All other instances in the selection set must also already be placed before the group placement drag is initiated.

When choosing a drop location for the anchor instance, keep in mind that all other instances in the selection set must have sites at the same relative coordinate offsets from both the anchor instance starting placement and ending placement. If an ending placement site is not found for any instance at the expected coordinate offsets, the entire group placement adjustment operation is aborted, and all instances remain in their initial placements.

### Adjusting the Existing Placement of a Group of Selected Instances

- 1. Empty the ACE Selection Set (as seen in the Selection View (page 137)).
- 2. Select all the instances that should take part in the group placement adjustment, so that they are added to the ACE Selection Set.
- 4. Ensure that the **Fixed Placement** checkbox (within the **Floorplanner View** (page 45) fly-out palette) is in the desired state.
- 5. Enable Group Placement mode by clicking the checkbox (within the Floorplanner View fly-out palette).
- 6. Choose which placed, selected instance is to be the anchor instance, then scroll and zoom the Floorplanner until both the initial site and destination site for the anchor instance are plainly visible.
- 7. Double-check that all other instances in the selection set have corresponding destination sites.
- 8. Drag the anchor instance from its initial placement to the destination site. If all initial requirements are met, and if destination sites were found for all selected instances at the calculated offsets, the GUI will issue a bulk Tcl **set\_placement** (page 714) command for all selected instances, and the instances should move to the new sites.
- 9. Disable Group Placement mode by clicking the checkbox (within the Floorplanner View fly-out palette).

#### A Caution!

#### Group Placement pays attention to the Fixed Placement checkbox:

Be aware that when a group placement adjustment succeeds, when the new placement is applied, the current state of the Floorplanner View **Fixed Placement** checkbox affects all adjusted placements.

If **Fixed Placement** is checked, all adjusted placements are fixed, regardless of whether they initially had soft or fixed placement. If **Fixed Placement** is unchecked, all adjusted placements are soft, regardless of whether they initially had soft or fixed placement.

All routing to and from the moved instances will be cleared after the placement.

See also: Floorplanner View (page 45), Selection View (page 137), Selecting Floorplanner Objects (page 340), Deselecting Floorplanner Objects (page 340), select (page 709), deselect (page 625), set\_placement (page 714)

# **Removing Placement**

To un-place objects with key-strokes in the Floorplanner View (page 45):

- 1. Ensure the Instances checkbox is checked in the Selection ( 🗟 ) section of the view Fly-out Palette.
- 2. With the mouse positioned in the Floorplanner view, press and hold the **r** key on the keyboard to start a selection rectangle at the current mouse position to remove placement of objects.
- 3. Drag the mouse while still holding down the **r** key to create a selection rectangle including the objects to be unplaced.
- 4. Release the key to un-place all the objects contained by the selection rectangle.

To un-place objects with the **Selection Tool** ( 🗟 ) in the Floorplanner view:

- 1. Select the **Selection Tool** (  $\mathbb{R}$  ) from the view toolbar.
- 2. In the **Selection** ( 🗟 ) section of the view fly-out palette:
  - a. Set the Action control to **Remove Placement**.
  - b. Ensure the **Instances** checkbox is checked.
- 3. Click and drag with the left mouse button in the view to create a selection rectangle.
- 4. Release the mouse button to un-place all the objects within the selection rectangle.

It is also possible to un-place objects using the right-click context menu in the Floorplanner view, Search View (page 133), and Selection View (page 137).

The fastest way to un-place multiple objects is to add them all to the ACE Selection Set (as shown in the Selection view; see Selecting Floorplanner Objects (page 340)), and then un-place all of them at once by performing any one of the following:

- In the Selection view, right-click the mouse on the **Instances** node in the tree, then choose **Unplace All Instances in ACE Selection Set**.
- In the Floorplanner view, right-click the mouse anywhere on the floorplan, then choose **Unplace All Selected Instances**.
- In the Tcl Console View (page 146), type: "run\_unplace -insts [get\_selection] ". (See run\_unplace (page 704).)

#### Performance Tip:

It is always faster to un-place multiple objects at once instead of individually, especially when a very complex net (like a clock net) is affected.

# Saving Pre-Placement Constraints

To save the current placement to disk as pre-placement constraints in .pdc files:

- 1. Place objects in the design as described in Placing an Object (page 346).
- 2. In the Floorplanner view or Package view, click the **Save Pre-placement Constraints** toolbar button (<sup>4</sup>) to bring up the **Save Placement Dialog** (page 185).
- 3. Configure the dialog with appropriate options and click Finish.

After clicking **Finish**, the pre-placement files are saved to disk. If the option was selected to automatically add the files to the current project, the Projects view shows the new files under the active project Constraints folder.

# Using Pre-Placement in the Flow

### **Types of Pre-Placement**

There are three ways to pre-place instances in ACE:

- After the **Run Prepare** flow step, interactively pre-place instances using the ACE GUI drag-and-drop placement features, or use the set\_placement -fixed TCL command in the TCL Console
- Include a PDC constraints file in your ACE project that uses set\_placement -fixed TCL commands to preplace the instances
- Set the location parameter on the instance primitive in the user design RTL (not recommended; the location parameter is effectively the same as using the set\_placement \_fixed Tcl command on that instance)

Using the set\_placement -fixed Tcl commands in a PDC constraints file is recommended. If using the location parameter in the user design RTL, the RTL must be changed and re-synthesized to update the pre-placement.

ACE applies pre-placement from user design RTL and PDC constraints at the end of Run Prepare in two stages:

- 1. ACE loops over all instances that have the location parameter set and internally calls set\_placement fixed on each instance and then prints the log file message "Applying defparam placement of <instance> to location <location>". The log file or TCL console shows messages for each instance placed with the location parameter.
- 2. The **Run Prepare** step applies all of the set\_placement commands in the PDC files. If there is a set\_placement command in your PDC for an instance that is already placed with the location parameter, the PDC set\_placement overrides the placement set in the location parameter. There is no warning message. It is the same as having two set\_placement commands in the same PDC file that place the same instance. The last set\_placement command always wins.

It is recommended to use only the PDC method.

### **Recommended Typical Flow**

To use pre-placement in the flow, it is recommended to first create the pre-placement constraints:

- 1. Run the **Run Prepare** flow step on the active implementation.
- 2. Switch to the Floorplanner perspective and place all the objects for pre-placement (using fixed placement). See **Placing an Object** (page 346) for details.
- 3. Save the pre-placement and automatically add it to the project (see Saving Pre-Placement Constraints (page 350)).
- 4. Optionally, a pin assignment report can be generated for the current placement with the **report\_pins** (page 683) Tcl command.
- 5. Resume running the flow. The pre-placement data is used in the place and route solution.

When the pre-placement constraints are in place, it is recommended to include them in the project for future runs:

1. The next time the flow is run with this implementation, ensure that in the **Options View** (page 100), the new preplacement constraints files are enabled.

- 2. Simply run the **Run Prepare** flow step. The pre-placement constraints are automatically applied. A pin assignment report is also automatically generated during **Run Prepare**.
- 3. Optionally, to see that the objects are pre-placed, switch to the Floorplanner perspective to view the placement.

# Analyzing Critical Paths

Critical paths are computed by timing analysis. Timing analysis can be run at several points in the flow (page 235), as indicated in the flow view (page 55). Timing analysis can be repeated with different implementation (page 231) options without having to re-run the rest of the flow, by double-clicking the appropriate **Run Timing Analysis** flow step (page 235).

The results of timing analysis are shown in a **timing report** (page 245), which is automatically displayed as timing analysis completes. The most recently generated version of each timing report file is always available in every implementation reports sub-directory.

The active critical paths may also be viewed in the **critical paths view** (page 39) and the **critical path diagram view** (page 34). Unlike the reports, the views only show the critical paths for the **active project and implementation** (page 231). When the active implementation changes, the two views are cleared. Also, the views are only populated when timing analysis is run for the active implementation during that same ACE session. The timing analysis data is not saved in the .acxdb file, and must be re-created every session to guarantee correctness.

#### 🕑 Tip

While a generated timing report may be viewed from an implementation reports directory at any time, including in later ACE sessions, the two critical path views only show data from the most recent timing analysis within the current ACE session.

# **Generating Timing Reports**

A timing report (page 245) is generated and displayed in the GUI whenever one of the Run ... Timing Analysis flow steps (page 235) is run. Timing reports may also be generated at any time from Tcl by running the appropriate flow step (run (page 690) -step <flow\_step\_name>) or with the run\_timing\_analysis (page 703) Tcl command.

The accuracy of the timing analysis results will improve as more of the flow steps are executed. (The relative placement and routing may only be estimated until the corresponding flow steps are completed.)

Timing reports can be found in the **implementation** (page 231)'s reports directory, available for browsing via the **Projects view** (page 120). In addition to the HTML report files displayed in the GUI, there are equivalent report files in .txt (text) and .csv (spreadsheet) formats, generated simultaneously with the HTML reports by default.

The Timing Analysis **implementation options** (page 0) in the **options view** (page 100) determine how timing analysis is run and the amount of report information which is generated. Additionally, while the **Flow Mode** (page 243) is set to **Evaluation**, the timing reports will always be limited to a single temperature corner to minimize runtimes.

Critical paths detected during timing analysis are also displayed in the **Critical Paths View** (page 39), using the same information included within the timing reports. (If the critical paths view is empty, it can be repopulated by re-running timing analysis.) The same path ID can be used to cross-reference between the critical paths view and the timing reports.

For details about how temperature corners are handled timing analysis and reporting, see Timing Across All Temperature Corners (page 266).

# **Highlighting Critical Paths**

#### (i) Note

The Floorplanner can only display routed paths. Paths which are not routed cannot be displayed in the Floorplanner.

To highlight a routed critical path in the Floorplanner View (page 45):

- 1. First, run one of the timing analysis flow steps to generate critical path data.
- 2. Then, in the Critical Paths View (page 39), browse through all reported critical paths.
  - a. By default, highlight colors of setup/hold violations are arranged in a gradient from red to yellow according to the slack's distance from zero.
  - b. Paths with a positive slack (setup/hold met) are colored green by default.
- 3. To highlight a path in the Floorplanner, simply check the box for the desired path in the Highlight column of the table within the **Critical Paths View** (page 39). To un-highlight a path, simply uncheck the box.

#### Tip: Critical Path Highlight Colors May Be Changed

The highlight color of each individual critical path can be changed by clicking on the color chooser box in the Highlight column of the Critical Paths View (page 39) table. In the color chooser dialog, select the desired color for that path and click **OK**.

# Selecting Critical Path Objects

In order to manipulate objects (for example, by pre-placing them) on a critical path, it is convenient to add them to the current ACE selection set (as displayed in the **selection view** (page 137)) for easy access.

#### Note

When objects are in the ACE selection set, they change to the selection color which overrides all other colors, including highlight colors.

To add a critical path to the current selection:

- 1. In the critical paths view (page 39), click the table row containing the data for the path for which objects are to be selected.
- 2. To add the path to the current ACE selection set, click the (**See**) Select Path toolbar button on the critical paths view (page 39) toolbar.
- 3. The path is now added to the selection in the **selection view** (page 137) and is shown with the selection color in the **floorplanner view** (page 45).

To add a the pins of a critical path to the current selection:

- 1. In the critical paths view (page 39), click the table row containing the data for the path for which objects are to be selected.
- 2. To add the path pins to the current ACE selection set, click the (<sup>3</sup>) Select Pins toolbar button on the critical paths view (page 39) toolbar.

3. The pins are now added to the selection in the **selection view** (page 137) and are shown with the selection color in the **floorplanner view** (page 45).

To add the instances of a critical path to the current selection:

- 1. In the critical paths view (page 39), click the table row containing the data for the path for which objects are to be selected.
- 2. To add the path instances to the current ACE selection set, click the ( \*) Select Instances toolbar button on the critical paths view (page 39) toolbar.
- 3. The instances are now added to the selection in the selection view (page 137) and are shown with the selection color in the floorplanner view (page 45).

To add the nets of a critical path to the current selection:

- 1. In the critical paths view (page 39), click the table row containing the data for the path for which objects are to be selected.
- 2. To add the path nets to the current ACE selection set, click the (\*) Select Nets toolbar button on the critical paths view (page 39) toolbar.
- 3. The nets are now added to the selection in the selection view (page 137) and are shown with the selection color in the floorplanner view (page 45).

# Zooming to Critical Paths

To zoom the floorplanner view (page 45) to the region of a critical path:

- 1. In the critical paths view (page 39), click the table row containing the desired critical path data.
- 2. To zoom to the path in the floorplanner view (page 45), click the ( ) Zoom to Path toolbar button on the critical paths view (page 39) toolbar.

#### Note

This action only applies to routed designs.

# Printing Critical Path Details

To print the details of a critical path to the Tcl console view (page 146):

- 1. In the critical paths view (page 39), click the table row containing the data for the path for which details are to be printed.
- 2. To print the details text, click the ( ) Print Path Details toolbar button on the critical paths view (page 39) toolbar.

🕑 Tip

Critical path details are also available in the timing report (page 245)

# Using Critical Path Diagrams

The **Critical Path Diagram View** (page 34) provides a graphical representation of a single critical path. These paths are each selected from the table in the **Critical Paths View** (page 39). The graphical representations consist of circular nodes (representing instances) connected by arrows (representing one or more nets).

## 🕑 Tip

To quickly look at the diagrams for all the critical paths:

- 1. Make sure both the Critical Paths View (page 39) and Critical Path Diagram View (page 34) are visible.
- 2. Click a row in the Critical Paths view table.
- 3. Use the keyboard up arrow and down arrow keys to change which row is selected in the table.
- 4. The Critical Path view diagram is updated to graph the relevant critical path.

# **Graph Elements**

The graphical diagram is made up of nodes and arrows. The information represented by the nodes, arrows, and their supporting text, can vary depending upon the current settings in the diagram **fly-out palette** (page 37).

#### Nodes

The larger circles in the diagram are the primary graph nodes which represent the key instances or turn points on the critical path. Intermediate nodes, when enabled, are smaller circles, representing instances the data passes through while flowing between turn points. Several useful pieces of information are available for each graph node. These may be enabled and disabled via the fly-out palette.

#### Note

Some information is hidden when the graph node circle is too small to contain it. To see all enabled information, the diagram must be zoomed in. Configurable tooltips can be used to see information that would otherwise be hidden due to insufficient drawing area.

## Arrows

The arrows connecting the graph nodes in the diagram represent the nets connecting the object instances and can also display various pieces of information that may be enabled and disabled via the fly-out palette. In addition to the direction of the arrow, the line types making up the arrow also represent important information:

- Bold arrows, visible when the Intermediate Nodes fly-out palette setting is disabled, represent one or more nets
  and any hidden intermediate nodes, lumped into a single abstraction. Bold arrows, since they potentially
  represent multiple nets and hidden intermediate instances, may only display text for the cumulative time in
  picoseconds of their Delays. Net Names and Fanouts are never displayed for bold arrows, since they make no
  sense in this context.
- Thinner arrows are shown when the **Intermediate Nodes** fly-out palette setting is enabled. Each of these represent an individual net. Because these thinner arrows each represent individual nets connecting the instances, the individual net **Fanouts** and **Net Names** may also be displayed for each arrow, in addition to the **Delays**.

## **Critical Path Diagram Types**

Different types of critical paths may have different visual representations. The **Type** column in the **Critical Paths View** (page 39) table provides the critical path type of each row.

All path types are displayed as a straight line of objects connected by arrows.

## Adding Portions of the Graph to the ACE Selection Set

When the graph has helped track down which nets and/or instances to adjust for timing purposes, it can be helpful to find those objects in the Floorplanner View (page 45). To do so, use the techniques described in Selecting Critical Path Objects (page 353), or add specific nodes and arrows from the graph to the ACE selection set, and use the Zoom to Selection button in the Selection View (page 137) to cause the Floorplanner View (page 45) to scroll and zoom so that all the selected objects are visible.

# Applying and Checking Properties

# **Applying Properties**

There are three methods to apply properties, detailed below. More information and examples can be found in the Synthesis Optimizations chapter of the *Synthesis User Guide* (UG071).

## defparam

Properties can be applied as defparams on a module or module port in the RTL black-box library. Applying defparams is an internal only method and sets the default value of the property for all instances of that module, or instance pins of a port.

# **RTL Attribute**

Attributes can be set in the RTL to show the design intent and to guide both Synplify and ACE. Synplify attributes are detailed in the Synplify help manual. ACE attributes can also be set in the RTL, and these are passed by Synplify to ACE. Attributes can be applied in both Verilog-2001 and SystemVerilog formats, as shown below:

#### Equivalent methods for applying properties

```
reg my_reg /* synthesis syn_preserve=1, must_keep=1
*/;
(* must_keep=1 *) reg my_reg /* synthesis syn_preserve=1 */;
(* must_keep=1, syn_preserve=1 *) reg my_reg;
```

In certain cases it is necessary to set both a Synplify and an ACE attribute when if, without the Synplify attribute, the object may be optimized or reduced. For example, if it is required to keep a register, then Synplify will require the syn\_preserve attribute to ensure the register is in the netlist output to ACE, and ACE will require the must\_keep attribute to keep the subsequent register. Similar situations arise with directing and controlling fanout, where both

syn\_maxfan (Synplify) and fanout\_limit (ACE) may be required. This requirement is a result of the fact that Synplify Pro does not propagate its own syn\_\* attributes on to ACE in the gate-level netlist.

## set\_property Tcl Command

The set\_property command can be applied in a PDC file to an object. See set\_property (page 715) for full details.

```
set_property IOSTANDARD {"LVCMOS18"} {p:led_anode[0]}
```

# **Checking Whether Properties Were Applied**

It is recommended to use the Synplify technology viewer to verify that properties were applied during Synplify. Selecting the object and then selecting "properties" will list the properties which will be passed to ACE. In addition, the netlist can be searched for the appropriate object, and the properties checked.

Within ACE, examine the object using the **Properties View** (page 127), or use the **display\_properties** (page 628), **get\_properties** (page 658), or **get\_property** (page 658) Tcl commands.

# Configuring External Connections to Hardware

ACE includes features supporting interactions with running hardware through both the JTAG and DCC interfaces.

The ACE JTAG connection utilizes a Bitporter2 pod or FTDI FT2232H (or FT4232H) device various Tcl commands to interact with an Achronix FPGA. The JTAG interface is used by the:

- Download view (page 43)
- Snapshot Debugger view (page 141)
- HW Demo view (page 60)

The automated SerDes link tuning functionality available for some FPGAs also uses JTAG.

#### (i) Note

For more details on managing the physical connection between the workstation, the Bitporter2 pod or FTDI device, and the FPGA board, see the *JTAG Configuration User Guide* (UG004), as well as any documentation specific to the development board.

The ACE DCC connection utilizes a direct serial connection (over a dedicated USB cable, kept separate from the JTAG connection) to interact with the Achronix development board. The DCC interface is used by the HW Demo view (page 60).

# Configuring the DCC Connection

The ACE DCC (Demo Command and Control) connection allows the ACE software to communicate with demo and/or reference designs running on Achronix hardware. The DCC connection is managed using the **Configure DCC Connection Preference Page** (page 192).

## **Background Info**

The ACE DCC connection utilizes a direct serial RS232 connection through a simple on-board 2-pin interface, over a dedicated FTDI USB Serial Port cable. The DCC interface does not make use of the Bitporter. The DCC protocol is currently not a published standard, and is only meant to be used with Achronix demo/reference designs running on Achronix FPGAs on Achronix boards. The DCC interactions perform individual register reads and writes, and are executed using a handful of simple Tcl commands.

## Installing DCC USB Drivers

The necessary USB drivers for the DCC cable are included in the ACE download. They will need to be installed before the DCC cable is connected.

#### Windows

When running the ACE installer, simply make sure the setting **FTDI CDM USB drivers for the Development Board DCC interface** is checked. When the installer completes, the DCC cable may be connected.

#### Linux (not currently supported)

The necessary FTDI USB drivers are already included in supported Linux distros. If the distro-supplied USB drivers do not work correctly, the necessary drivers may be downloaded from the FTDI website. Contact Achronix support if you need help finding the Linux drivers.

## Configuring the USB drivers

The DCC cable USB drivers automatically choose a serial port to be redirected to the USB cable. It may be necessary to view and/or change which serial port is chosen.

#### Windows

To see which serial (COM) port is being used by the driver, go to the Windows Device Manager, and look under **Ports** (COM and LPT). The correct COM port is shown as USB Serial Port (COM\*), with the actual COM port number included.

| a Device Manager                       | - C - X - |
|----------------------------------------|-----------|
| File Action View Help                  |           |
|                                        |           |
| ▲ 🚏 Ports (COM & LPT)                  |           |
| - TP ECP Printer Port (LPT1)           |           |
| USB Serial Port (COM4)                 |           |
| Processors                             |           |
| Sound, video and game controllers      |           |
| Storage controllers                    | E         |
| July System devices                    |           |
| h - 🖩 Universal Serial Rus controllers | •         |
|                                        |           |

#### Figure 160 • Windows Device Manager COM Ports Example

To change which COM port is being used by the USB cable, right-click the USB Serial Port entry, and then choose **Port Settings**  $\rightarrow$  **Advanced**, and select the alternate COM port to be used.

#### Linux (not currently supported)

Contact Achronix support for the latest information about finding or changing the DCC cable serial port assignment.

# **Configuring ACE**

When it is determined which serial port is being used by the DCC cable, ACE needs to be configured to use that same serial port.

Open the Configure DCC Connection Preference Page (page 192) (Window  $\rightarrow$  Preferences  $\rightarrow$  Configure DCC Connection), then populate the Port Name field with the serial port name the DCC cable is using. The exact port names used vary according to the operating system in use.

In Windows, this is a COM port, typically one of COM1 through COM9. COM3 is the most frequent (and thus default) choice.

In Linux, the serial ports are named /dev/ttyS\* with the \* being replaced by a number. This is typically one of /dev/ttyS0 through /dev/ttyS9.

# Configuring the JTAG Connection

Achronix currently supports two JTAG programmer device types:

- Bitporter2
- FTDI FT2232H (or FT4232H)

While in the simplest cases, a test bench may only have a single JTAG programmer device connected to a JTAG scan chain containing a single Achronix FPGA (or eFPGA), many may have multiple JTAG programmer devices, and/ or multiple devices within the connected JTAG scan chain. For these reasons, the ACE tools must specify which JTAG programmer device connection to use, and which JTAG scan chain member is relevant.

The various tools within ACE obtain their choice of JTAG programmer device and JTAG scan chain configuration from a few different locations, mostly based upon the usage model of the ACE tool itself.

The primary sources of JTAG programmer device and JTAG configuration information include:

- The GUI Configure JTAG Connection preference page (page 193)
- · Command-line overrides
- The implementation options (page 0), as managed within the Options view (page 100)

The GUI views and editors responsible for live FPGA interactions retrieve their JTAG programmer device and JTAG connection details from the **Configure JTAG Connection preference page** (page 193).

The various Tcl commands that perform JTAG interactions typically require the JTAG device name to be provided as an argument, and there are specific Tcl commands to list available device connections, open and close individual device connections, and initialize the JTAG scan chain for a device with the desired configuration details. See the *JTAG Configuration User Guide* (UG004) for a complete listing of these Achronix Tcl commands in the jtag:: and device-specific namespaces.

The JTAG scan chain implementation options are currently only used during the FPGA Download flow step (page 235).

#### (i) Note

The acx\_stapl\_player, deprecated starting with ACE 9.2, is currently still being shipped (for backwards compatibility) as a part of the ACE software, though it is to be removed from future releases. While acx\_stapl\_player has previously been used behind-the-scenes by ACE for any JTAG interactions involving the now-obsolete STAPL \*.jam files, it remains available for manual use from the operating system shell/command-line. The use of this tool is covered in detail within the *Configuration User Guide* (available from www.achronix.com/support/docs).

#### Caution!

#### Special note for sites with more than one connected FPGA/eFPGA:

The interactive members of the ACE tools currently assume that only a single FPGA/eFPGA is of interest at a time, and those interactive tools all share a single configuration on the **Configure JTAG Connection preference page** (page 193). This single configuration is stored per-user, and is not unique per-design or per-implementation.

At sites with more than a single connected FPGA/eFPGA, remember to change the JTAG programmer device and JTAG scan chain values stored on that preference page every time when alternating between FPGAs/eFPGAs.

# JTAG Programmer Device Connection

It is often possible that multiple JTAG programmer devices are visible from a single workstation. Because of this, ACE software must be configured to know which JTAG programmer device is intended to be used. The ACE GUI JTAG programmer device and JTAG connection details are managed primarily through the **Configure JTAG Connection preference page** (page 193) (for interactive GUI tools) and the implementation options within the **Options** view (page 100) (for any JTAG tools called within the **flow** (page 235)).

#### Warning!

#### Bitporter2 pods may be damaged if improperly connected!

Read the *Configuration User Guide*, as well the user guide(s) specific to your development kit, before physically connecting the Bitporter2 JTAG ribbon cable to the JTAG header on the development board.

#### Important!

This section describes how to configure ACE to communicate with an already-connected JTAG programmer device. For more details on managing the physical connection between the workstation, the JTAG programmer device, and the FPGA board, see the *Configuration User Guide*, as well the user guide(s) specific to the development kit, and any related release notes.

The *Configuration User Guide* also covers additional details about testing JTAG programmer device connections, JTAG programmer device naming/addressing, and managing connections to multiple devices.

Starting in ACE 9.2, ACE uses the Achronix jtag:: Tcl library to perform all ACE JTAG operations. High-level JTAG Tcl commands may automatically detect the presence of available JTAG devices over USB, though all allow specifying JTAG devices by name. If multiple JTAG devices are detected, and ACE has not been informed which of

the JTAG devices (by name) should be used, the Tcl command execution fails because, for safety, ACE does not pick a JTAG device randomly.

It is strongly recommended to specify the chosen JTAG device by name in all cases, instead of relying upon autodetection. Not only does this avoid problems if additional JTAG devices are connected at a later date, but connections to named devices are faster to initiate.

### 🕑 Tip

Several seconds of initialization time can be saved on every JTAG connection if the JTAG programmer device is specified by name instead of using auto-detection.

The details of JTAG device naming and name retrieval are covered thoroughly in the *Configuration User Guide*. As a simple summary, the device names for supported JTAG devices are derived from their device serial number. The Tcl command jtag::get\_connected\_devices provides a list of connected JTAG device names.

# **JTAG Scan Chain**

The JTAG specification (see en.wikipedia.org/wiki/JTAG) supports multiple devices being connected in sequence, sharing a single set of JTAG pins on the board. These devices are treated as being on the same JTAG scan chain. In order for ACE to successfully communicate with any target device in a scan chain, ACE must be told the scan chain configuration on the **Configure JTAG Connection preference page** (page 193).

| JTAG Scan Chain                         |   |
|-----------------------------------------|---|
| IR Bits Before Target FPGA Device       | 0 |
| IR Bits After Target FPGA Device        | 0 |
| Target FPGA Device Offset in Scan Chain | 0 |

#### Figure 161 • JTAG Scan Chain Fields, Configure JTAG Connection Preference Page

(i) Note

The default JTAG scan chain preference values, all zeros, is always correct for single-device scan chains. For multi-device scan chains, the default values never work.

When multiple FPGA devices are attached to the same JTAG scan chain, the target FPGA device must be specified. Because different FPGA devices have different instruction sizes, the total instruction length before and after the target must be specified as well.







The **Target FPGA Device Offset in Scan Chain** specifies the ordinal position relative to the Bitporter. The device closest to the Bitporter (technically, the device closest to the board JTAG TDI pin) has a target offset of 0.

The number of instruction register (IR) bits before the target FPGA device is specified under **IR Bits Before Target FPGA Device**, while **IR Bits After Target FPGA Device** specifies the number of IR bits that follow the target FPGA device in the chain. Achronix FPGA devices have an instruction size of 23 bits. Hence, in the above example, if all devices were Achronix FPGA devices, there would be 23 instruction bits before the target, (23 instruction bits in the target), and 46 instruction bits after the target.

In JTAG, the least significant bit enters the scan chain first, while the most significant bit enters the scan chain last. From the perspective of ACE, *before* refers to the more significant bits in the scan chain, and *after* refers to the less significant bits. Instruction bits before the target are not scanned through the target FPGA. Instruction bits after the target instruction bits are scanned through the target FPGA before arriving at their scan chain destination. The key detail is that ACE regards the before/after terminology from the perspective of where the bits ultimately land in the instruction registers, NOT in terms of when the bits pass through the JTAG TDI pin, and NOT in terms of the sequence in which the bits pass through the target device.

Thus, in a chain of four Achronix FPGAs (each FPGA instruction register consists of 23 bits, the total IR bits =  $4 \times 23$  = 92 IR bits), to specify the device closest to the TDI pin, the initial device (IR scan chain bits [91:69]) requires an entry of 0:69:0 for the three ACE scan chain configuration values. The first 0 for **IR Bits Before Target FPGA Device**, 69 for **IR Bits After Target FPGA Device**, and 0 for **Target FPGA Device Offset in Scan Chain**. The second Achronix FPGA in a chain of four would be 23:46:1, the third would be 46:23:2, and the fourth would be 69:0:3.

| Device (IR bit Range<br>Within 92-bit IR Scan<br>Chain) | IR Bits Before<br>Target FPGA Device | IR Bits After<br>Target FPGA Device | Target FPGA Device<br>Offset in Scan Chain |
|---------------------------------------------------------|--------------------------------------|-------------------------------------|--------------------------------------------|
| 0 (bits [91:69])                                        | 0                                    | 69                                  | 0                                          |
| 1 (bits [68:46])                                        | 23                                   | 46                                  | 1                                          |
| 2 (bits [45:23])                                        | 46                                   | 23                                  | 2                                          |

### Table 144 • Example Scan Chain Values: Four Achronix FPGAs in the Same Scan Chain

| Device (IR bit Range<br>Within 92-bit IR Scan<br>Chain) | IR Bits Before<br>Target FPGA Device | IR Bits After<br>Target FPGA Device | Target FPGA Device<br>Offset in Scan Chain |
|---------------------------------------------------------|--------------------------------------|-------------------------------------|--------------------------------------------|
| 3 (bits [22:0])                                         | 69                                   | 0                                   | 3                                          |

Specifying a single-device chain (where there is nothing in the chain except the solo target device) would always require an entry of 0:0:0. There are zero IR bits before the target device, zero IR bits after the target device, and it is the device closest to the TDI pin in the JTAG scan chain. This single-device scan chain configuration is the default configuration.

#### (i) Note

#### Instruction register lengths vary by vendor and device.

For those new to JTAG, it might be worth mentioning that if non-Achronix devices are in the scan chain, it is extremely likely that their instruction registers are not 23 bits long, thus the before/after bit counts required would not be multiples of 23.

The scan chain Offset number is independent of the IR bit numbers, and is used to derive data register preand post-padding, since according to the JTAG specifications, devices being bypassed each always have a DR length of one.

# Running the Snapshot Debugger

The following sections describe how to configure and use the snapshot debugger in an end-user design.

#### (i) Note

Snapshot hardware architecture details and use of the ACX\_SNAPSHOT user macro can be found in the *Snapshot User Guide* (UG016), though there may also be supplemental details specific to some Achronix device families. These documents are available from www.achronix.com/support/docs, download.achronix.com (account required), or from an Achronix FAE.

The Snapshot content here in the ACE User Guide provides a general overview of functions which are common to all Achronix devices, and is focused on the snapshot debugger user interface for real time insystem debugging.

# **Snapshot Design Flow**

### 👍 Warning!

#### The JTAG connection must be configured before using the snapshot debugger.

ACE interacts with the FPGA using the JTAG interface through a Bitporter2 pod or FTDI FT2232H device. This JTAG interface must be properly configured in ACE before using the Snapshot Debugger view. The configuration is managed using the **Configure JTAG Connection preference page** (page 193), which is

easily accessible by clicking the (<sup>40</sup>) **Configure JTAG Interface** button in the Snapshot Debugger view. See **Configuring the JTAG Connection** (page 359) for more details.

Snapshot is the real-time design debugging tool for Achronix FPGAs and eFPGAs. Snapshot, which is embedded in the ACE software, delivers a practical platform to evaluate the signals of a user design in real-time and optionally send stimuli to the user design.

To utilize the Snapshot debugger tool, the Snapshot macro must be instantiated inside the RTL for the design under test (DUT). After instantiating the macro and programming the device, the design can be debugged in the ACE GUI using the Snapshot Debugger view (page 141) and the VCD Waveform Editor (page 11), found within the Programming and Debug perspective (page 6).



3702859-02.2022.07.12

## Figure 163 • Snapshot Communication with the Snapshot Debugger View within ACE

When instantiated in a design, the Snapshot macro can be used to interface with any logic mapped to the Achronix FPGA core. The Snapshot macro provides a JTAG/JTAP interface to control/observe debug logic mapped to the core. This interface allows the ACE Snapshot Debugger view, which drives the JTAG interface, to control/observe the signals associated with the debug logic.

Within the ACE GUI, the Snapshot Debugger view allows configuring an embedded Snapshot Debugger core, interactively arm the core, and generate a VCD waveform output of the collected samples. By default, the generated VCD waveform output is displayed in the ACE editor area using the VCD Waveform Editor (page 11). The VCD output can also be read into a third-party waveform viewer.

At a high level, to utilize Snapshot, first:

- 1. Instantiate the Snapshot macro ACX\_SNAPSHOT in the user design.
- 2. Set the required constraints in the .sdc files.
- 3. Synthesize the design.
- 4. Place and route the design in ACE.
- 5. Generate the Bitstream for the design in ACE.
- 6. Configure the ACE JTAG connection to the FPGA (see Configuring the JTAG Connection (page 359))

- 7. Program the Achronix device with the Bitstream.
  - Use of the ACE GUI Download view (page 43) is documented in the section Programming a Device using JTAG in the Download View (page 389)
  - Use of the library of JTAG commands executable on the Tcl command-line is documented in the JTAG Configuration User Guide (UG004)

When these prerequisite steps are complete, the ACE GUI **Snapshot Debugger view** (page 141) allows the evaluation/ interaction with the running design in real-time.

The following sections further explain Snapshot and provide a guide through the process.

# Accessing the Snapshot Debugger

## Open the ACE GUI and Select the Project

Open the ACE GUI tool, and load or activate the selected project in the Projects View as shown below. See:

- Loading Projects, (page 294)
- Setting the Active Implementation (page 302)
- Working with Projects and Implementations (page 293)



Figure 164 • ACE Tool Load Project

## Open the Snapshot Debugger

Click the toolbar button to change to the  $(\stackrel{e}{=}^{0})$  Programming and Debug Perspective as described in the Working with Perspectives (page 286) section. The Snapshot Debugger view (page 141) should be visible by default, as shown below. If not, select Window  $\rightarrow$  Show View  $\rightarrow$  Snapshot Debugger from the main menu bar.

The **Snapshot Debugger view** (page 141) should have automatically loaded the default Snapshot configuration file for the project, generated when the design ran through place and route, located in <ace\_project\_dir>/ <active\_impl\_dir>/output/names.snapshot. If the file loaded, the correct signal names from the user design appear in the **Trigger Channels**, **Monitor Channels**, and **Stimuli** tables. If the file did not automatically load,

click the ( ) Load Snapshot Configuration toolbar button in the Snapshot Debugger view (page 141) to browse to the location of the preferred \*.snapshot configuration file, or manually enter the signal names, channel widths, etc. to match the design.

| ACE - Achronix (                                        | AD Environm     | ent - Version  | - snapsho      | ot_example->impl_1 (AC7t15 | (0ES0)        |   |                                                                                                    | - 0                                          | ı x     |
|---------------------------------------------------------|-----------------|----------------|----------------|----------------------------|---------------|---|----------------------------------------------------------------------------------------------------|----------------------------------------------|---------|
| File Edit Actions                                       | Window H        | Help           |                |                            |               |   |                                                                                                    |                                              |         |
| 🤒 🖩 🖷 📤 🗠                                               | ł 🗈 🗈 i (       | 🤋 察 i 🖻 i      | <b>.</b> 🔊 📖 🛛 | P 🗭 🖗 🐁 🖓                  |               |   |                                                                                                    |                                              | Q       |
| 🎋 Snapshot Debugg                                       |                 |                |                |                            | 🔍 🔾 🔳 🄄 🖗 🛃 👘 |   | E Options 🛛 🔖 Multiprocess                                                                         |                                              |         |
| ▼ Trigger Conditio                                      | ns              |                |                |                            |               | ^ | Project: snapshot example                                                                          |                                              |         |
| Set up the condit                                       | ions to trigger | the capture of | f data on the  | monitor channels.          |               |   | Implementation: impl_1                                                                             |                                              | -       |
| Trigger Mode                                            |                 | Single         |                |                            | ~             |   | Design Preparation                                                                                 |                                              |         |
| Number of Sequ                                          | ential Triggers | 3              |                |                            | ~             |   | Advanced Design Preparation                                                                        |                                              |         |
| Trigger Channel                                         | Width           | 38             |                |                            | ~             |   | Place and Route                                                                                    |                                              |         |
| - Trigger Channe                                        | els             |                |                |                            |               |   | Report Generation                                                                                  |                                              |         |
| Channel                                                 | Trigger 1       | Trigger 2      | Trigger 3      | Signal Name                | ^             |   | Timing Analysis                                                                                    |                                              |         |
| 0                                                       | x               | X              | x              | reset_n                    |               |   | Bitstream Generation                                                                               |                                              |         |
| 1                                                       | х               | Х              | Х              | stimuli_valid              |               |   |                                                                                                    |                                              |         |
| 2                                                       | х               | х              | х              | x_snapshot.arm             |               |   | FPGA Download                                                                                      |                                              |         |
| 3                                                       | х               | Х              | Х              | limit_a[0]                 |               |   |                                                                                                    |                                              |         |
| 4                                                       | х               | х              | х              | limit_a[1]                 |               |   |                                                                                                    |                                              |         |
| 5                                                       | х               | Х              | Х              | limit_a[2]                 |               |   |                                                                                                    |                                              |         |
| 6                                                       | х               | Х              | х              | limit_a[3]                 |               |   |                                                                                                    |                                              |         |
| 7                                                       | х               | х              | Х              | limit_a[4]                 |               |   |                                                                                                    |                                              |         |
| 8                                                       | х               | Х              | х              | limit_a[5]                 |               |   |                                                                                                    |                                              |         |
| 9                                                       | х               | х              | Х              | limit_a[6]                 | v             |   |                                                                                                    |                                              | -       |
| Load Signal N                                           | lames From A    | ctive Project  | Reset Signal   | Names                      |               |   |                                                                                                    |                                              |         |
| Monitor Channel                                         | k.              |                |                |                            |               |   |                                                                                                    |                                              | :       |
| <ul> <li>Stimuli</li> </ul>                             |                 |                |                |                            |               |   | ■ Tcl Console ☆ III                                                                                | B. B. S. | 8       |
|                                                         |                 |                |                |                            |               |   | (c) Copyright 2006-2022 Achronix Semiconductor Corp. All rights reserved.                          |                                              | <u></u> |
| <ul> <li>Advanced Optio<br/>Configure log an</li> </ul> |                 |                |                |                            |               |   | all messages logged in file C:/Users/Labadmin/.achronix/ace_2022_12_09_12_38_30.L                  | og, create                                   | d at    |
| Configure log an                                        | · -             |                | dvanced opti   | ons                        |               |   | INFO: License ace-v1.0 on server cad2 (1966 of 2000 licenses available). Running on                | SJC-LAB33                                    | (x64).  |
| Pre-Store                                               | Pre-Store 0%    |                |                |                            | ~             |   | <pre>cmd&gt; restore project "C:/projects/achronix/snapshot example/ace/snapshot example.acx</pre> | pri"                                         |         |
| Trigger 1 Select                                        | t               |                |                |                            |               |   | cnd>                                                                                               | -                                            |         |
| Select Using                                            | AND OSel        | ect Using OR   |                |                            |               |   |                                                                                                    |                                              |         |
| Trigger 2 Select                                        |                 |                |                |                            |               |   |                                                                                                    |                                              |         |
| Select Using                                            |                 | ect Using OR   |                |                            |               |   |                                                                                                    |                                              |         |
| Trigger 3 Select                                        |                 |                |                |                            |               | ~ | <                                                                                                  |                                              | >       |
|                                                         |                 |                |                |                            |               |   | 35M of 512M                                                                                        |                                              |         |

Figure 165 • Snapshot Debugger View

# Configuring the Trigger Pattern

#### (i) Note

The Trigger Channel signal names are automatically configured to the correct values when the names.snapshot file is loaded. The names.snapshot file is generated during design preparation (the **Run Prepare Flow Step** (page 235)), which contains the user design signal names connected to Snapshot, along with the trigger width and the maximum number of sequential triggers.

# Configuring the Trigger Mode

The Trigger Mode option allows the user to select the trigger mode to use when the Arm action is run.

### Single

The default trigger mode is **Single**, which means the trigger conditions are programmed in to the ACX\_SNAPSHOT macro and then the GUI waits for a single trigger event to occur which matches those trigger conditions, and then a single VCD file is recorded. This option arms Snapshot and captures data only once.

### Immediate

If **Immediate** trigger mode is selected, pressing the Arm button results in the same behavior as **Single** trigger mode, except that all 3 trigger patterns are treated as "Don't Care" (X's) so that the trigger event will occur as soon as the Arm button is pressed. This mode is useful to quickly capture the state of the running design without waiting for any trigger pattern to be met.

## Repetitive

If **Repetitive** trigger mode is selected, the trigger conditions are programmed in to the ACX\_SNAPSHOT macro and samples are captured repetitively until the upper limit of trigger event records is reached. When **Repetitive** trigger mode is selected, an additional set of repetitive trigger mode options will appear to allow the user to configure the number of sequential times Snapshot should be armed repetitively using the configured trigger conditions, and the way in which the output VCD files are managed. This mode is useful when the trigger conditions do not narrow in on the exact data pattern and the pattern you intend to observe occurs sporadically at the trigger conditions. You can let the repetitive trigger mode run for a long period of time, taking several capture records at the trigger conditions, to help find the pattern you are interested in. The user can optionally cancel the remaining Snapshot session once the desired data is captured.

The repetitive trigger Record Limit setting determines how many times (number of records) the GUI will repeatedly Arm the Snapshot debugger and capture samples. The user may set this to automatically run Snapshot up to 128 times.

The repetitive trigger VCD Record Limit setting determines how many Snapshot records to capture in a single VCD file. This essentially concatenates the VCD files from consecutive runs of Snapshot (records) into a single VCD file. The VCD file waveform contains a set of virtual signals to indicate the system timestamp at which each Snapshot record was captured. The user may concatenate up to 10 Snapshot records in a single VCD file.

If the Overwrite VCD File option is selected, the VCD Waveform File name specified in the Advanced Options section will be used to store the output VCD file. The file will be overwritten with the new VCD file each time the VCD record limit is reach. If the Overwrite VCD File option is not selected, then multiple VCD files will be written out and a unique VCD record number will be added to the VCD Waveform File name specified in the Advanced Options section for each VCD. For example, if you set the Record Limit to 8 and set the VCD Record Limit to 2, and set the VCD Waveform file path the "./snapshot.vcd", then Snapshot would output 4 VCD files to "./snapshot1.vcd", "./ snapshot2.vcd", "./snapshot3.vcd", "./snapshot4.vcd", each containing 2 Snapshot capture records.

# **Configuring Trigger Patterns**

The Snapshot Debugger can be configured to use a **Trigger Channel Width** of 1 to 40 bits. The value entered in the Snapshot Debugger View must match the value of the *TRIGGER\_WIDTH* parameter set on the ACX\_SNAPSHOT module in the user design RTL. (This will be the width of the *i\_trigger* bus.)

The Snapshot Debugger is capable of handling one to three sequential trigger patterns. The post-trigger data is sampled once the last trigger pattern in the sequence is matched.

The user may specify the number of desired sequential trigger patterns using the **Number of Sequential Triggers** option in the **Snapshot Debugger View** (page 141). If **1** is selected, Trigger 2 and Trigger 3 are ignored. If **2** is selected, Trigger 3 is ignored and Snapshot will trigger when Trigger 1 is matched, followed (on any subsequent clock) by a match on Trigger 2. If **3** is selected, then Snapshot will trigger after a match on Trigger 1, followed (on any subsequent clock) by a subsequent clock) by a match on Trigger 2, followed (on any subsequent clock) by a match on Trigger 3.

Each sequential trigger is hooked up to the trigger channels on the Snapshot Debugger core. The LSb of the trigger pattern is hooked to trigger channel 0, and the MSB is hooked to upper most trigger channel bit (TRIGGER\_WIDTH - 1).

Each sequential trigger is made up of three parts: the pattern mask, the edge mask, and the don't care mask. In the Snapshot Debugger View, these 3 masks are combined for ease of use into a single trigger pattern value, which allows each bit to be specified as **X** (don't care), **R** (rising edge), **F** (falling edge), **O** (level 0), or **1** (level 1). The trigger pattern defines the trigger channel signal conditions that are required to detect a match. If a given trigger channel value is set to X (don't care), then this trigger channel is ignored when computing a match. If a given trigger channel value is set to R (rising edge), then this trigger channel is is evaluated as a match when a rising edge of this signal is seen by Snapshot. If a given trigger channel value is set to F (falling edge), then this trigger channel value is set to 1 (level 1), then this trigger channel value is set to 5 (level 0), then this trigger channel value is set to 1 (level 1), then this trigger channel value is set to 6 (level 0), then this trigger channel value is set to 1 (level 1), then this trigger channel is is evaluated as a match when a falling edge of this signal is seen by Snapshot. If a given trigger channel is is evaluated as a match when a falling edge of this signal is seen by Snapshot. If a given trigger channel value is set to 1 (level 1), then this trigger channel is is evaluated as a match as long as this signal's level is seen as a 1 by Snapshot (it is not edge sensitive). If a given trigger channel value is set to 0 (level 0), then this trigger channel is is evaluated as a match as long as this signal's level is seen as a 1 by Snapshot (it is not edge sensitive).

#### Warning!

If any active Trigger is configured with as all X's (don't care), the trigger pattern will be a match on the first clock cycle that trigger is evaluated.

The values within a trigger pattern may cause a trigger match event either by AND'ing or OR'ing. If AND'ing, then **all** signal values not masked (set to X) must match their pattern for the trigger match event to occur. If OR'ing, then the trigger match event will occur if **any** of the non-masked (not set to X) signal values match the specified pattern. The AND/OR configuration is set per sequential trigger using the **Select using AND** or **Select using OR** radio buttons. This selection can be different for each sequential trigger.

In the "Trigger Channels" table of the Snapshot Debugger View, the trigger patterns can be viewed and edited.

## Setting Pattern Values Using the Table

For each channel, a value of **X** (don't care), **R** (rising edge), **F** (falling edge), **O** (level 0), or **1** (level 1) can be specified via a pull-down menu under each "Trigger" column as shown below.

| Channel | Trigger 1 |   | Trigger 2 | Trigger 3 | Signal Name   |  |
|---------|-----------|---|-----------|-----------|---------------|--|
| 0       | Х         |   | Х         | Х         | reset_n       |  |
| 1       | Х         |   | Х         | Х         | stimuli_valid |  |
| 2       | Х         |   | Х         | Х         | arm           |  |
| 3       | Х         | Ŧ | Х         | Х         | limit_a[0]    |  |
| 4       | Х         |   | Х         | Х         | limit_a[1]    |  |
| 5       | 0         |   | Х         | Х         | limit_a[2]    |  |
| 6       | R         |   | Х         | Х         | limit_a[3]    |  |
| 7       | F         |   | Х         | Х         | limit_a[4]    |  |
| 8       | Х         |   | Х         | Х         | limit_a[5]    |  |
| 9       | Х         |   | Х         | х         | limit_a[6]    |  |

### Figure 166 • Trigger Channels Setting Example

## Setting Multiple Pattern Values as a Bus

The Assign Bussed Values Dialog wizard allows assigning a value to multiple signals from the **Snapshot Debugger** view (page 141) "Trigger Channels" or "Stimuli Channels" tables as a bus. After configuring the bus in the dialog, the values of each signal are propagated to all the selected signals in the **Snapshot Debugger View** (page 141). There are 2 ways to launch this dialog to allow bus assignment of values:

- 1. With your mouse, left click to select a single row in the **Snapshot Debugger View** (page 141) table which has a bussed signal name (i.e. din[2]). Then right mouse click to edit the **Value by Bus**. This method will automatically find all the other bits in the bus with the same signal name (i.e. din[0], din[1], din[2], etc.) and open the dialog to allow editing of the entire bus of signals.
- With your mouse, hold CTRL or SHIFT and left click to select multiple rows in the Snapshot Debugger View (page 141) table. Then right mouse click to edit the Value by Selection. This method will open the dialog to allow editing of all selected signals as a bussed value.

| O Assig | gn Busse | ed Values                                            |               | O Assi | gn Bussed  | Values                                             |               |
|---------|----------|------------------------------------------------------|---------------|--------|------------|----------------------------------------------------|---------------|
| Bus Va  | lue Ass  | signment                                             |               | Bus Va | alue Assig | gnment                                             |               |
|         |          | ows you to automatically configure<br>bussed signal. | e             |        |            | vs you to automatically configure<br>issed signal. |               |
| Binary  | Value    | 10100011                                             |               | Binary | Value X    | (1R0F                                              |               |
| Hex Va  | lue      | a3                                                   |               | Hex Va | lue ?      | ?                                                  |               |
| Decima  | al Value | 163                                                  |               | Decim  | al Value ? | ,                                                  |               |
| Bit     | Value    | e Signal Name                                        |               | Bit    | Value      | Signal Name                                        |               |
| 0       | 1        | limit_a[0]                                           |               | 0      | F          | reset_n                                            |               |
| 1       | 1        | limit_a[1]                                           |               | 1      | 0          | stimuli_valid                                      |               |
| 2       | 0        | limit_a[2]                                           |               | 2      | R          | arm                                                |               |
| 3       | 0        | limit_a[3]                                           |               | 3      | 1          | limit_a[0]                                         |               |
| 4       | 0        | limit_a[4]                                           |               | 4      | Х          | limit_a[1]                                         |               |
| 5       | 1        | limit_a[5]                                           |               |        |            |                                                    |               |
| 6       | 0        | limit_a[6]                                           |               |        |            |                                                    |               |
| 7       | 1        | limit_a[7]                                           |               |        |            |                                                    |               |
|         |          |                                                      |               |        |            |                                                    |               |
|         |          |                                                      |               |        |            |                                                    |               |
|         |          |                                                      |               |        |            |                                                    |               |
| 0       |          |                                                      | Finish Cancel | 0      |            | ۱                                                  | Finish Cancel |

### Figure 167 • Assign Bussed Values Dialog Example

See Assign Bussed Values Dialog (page 157) for more information on this dialog.

# Configuring the Monitor Signals

#### (i) Note

The Monitor Signals are automatically configured to the correct values when the names.snapshot file is loaded. The file is generated during design preparation (the **Run Prepare flow Step** (page 235)) which contains the user design signal names connected to Snapshot, along with the monitor width and number of samples.

The value of **Monitor Channel Width** in the **SnapShot Debugger view** (page 141) must be configured to match the value of the MONITOR\_WIDTH parameter of the ACX\_SNAPSHOT instance inside the RTL of the design being debugged (this is the width of the i\_monitor bus).

The value of **Number of Samples** in the **SnapShot Debugger view** (page 141) should be configured to match the value of the MONITOR\_DEPTH parameter of the ACX\_SNAPSHOT instance inside the RTL of the design being debugged. If the value in the GUI does not match the value in the RTL, the value from the RTL is used and a warning is entered into the Snapshot log file.

# Naming Captured Signal Data

Custom signal names for each channel can be entered under the **Signal Name** heading within the "Monitor Channels" table. The signal/bus names in the table are then used as labels on the captured signal data in the VCD waveform output, and are visible in the VCD Waveform Editor (page 11).

Multiple signals can be combined into a bus by selecting multiple rows in the "Monitor Channels" table, right-clicking

a selected signal row to bring up a popup context menu, and selecting ( ) Assign Bus Name from the context menu to bring up the Assign Bussed Signal Names dialog (page 155). After configuring the bus in the dialog, the bus name and indices are propagated to all the previously-selected signals.

To select a contiguous range of rows:

- 1. Select the first signal.
- 2. hold the Shift key and select the last signal.

To select a non-contiguous set of rows:

- 1. Select the first signal.
- 2. While holding down the Ctrl key, select the other signals.

Signal names may be returned to their defaults by clicking the **Reset Signal Names** button under the "Monitor Channels" table.

#### Note

**Reset Signal Names** resets all signal names in the table at once, not just the currently selected rows/ signals.

The **Load Signal Names From Active Project** button loads the names.snapshot file generated during design preparation (the **Run Prepare flow step** (page 235)) which renames all signals with their project-specific names, and also loads the project-specific default settings for monitor width, user clock frequency, default .log and .vcd file path, etc.

# **Configuring Test Stimulus**

(i) The stimuli channel signal names are automatically configured to the correct values when the names.snapshot file is loaded. The names.snapshot file is generated during design preparation (the **Run Prepare Flow Step** (page 235)), which contains the user design signal names connected to Snapshot, along with the stimuli width.

Snapshot has the capability to send 0 to 512 bits of test stimuli (the ACX\_SNAPSHOT macro output signal o\_stimuli) to the Design Under Test (DUT). This data is sent once per arming session, is only valid while the o\_stimuli\_valid signal is high.

This o\_stimuli output is optional, and need not be connected to the DUT — it may safely be left floating when Snapshot is used to only read signals.

The value of **Stimuli Channel Width** in the **SnapShot Debugger view** (page 141) must be configured to match the value of the STIMULI\_WIDTH parameter of the ACX\_SNAPSHOT instance inside the RTL of the design being debugged (this is the width of the o\_stimuli bus).

In the Stimuli Channels table of the Snapshot Debugger View, the stimuli values can be viewed and edited.

# Setting Stimuli Values Using the Table

For each channel, an output value of **0** (level 0), or **1** (level 1) can be specified via a pull-down menu under the **Value** column as shown.

| Channel | Value |   | Signal Name    |
|---------|-------|---|----------------|
| 0       | 0     |   | dut_stimuli[0] |
| 1       | 0     |   | dut_stimuli[1] |
| 2       | 0     |   | dut_stimuli[2] |
| 3       | 0     |   | dut_stimuli[3] |
| 4       | 0     | Ŧ | dut_stimuli[4] |
| 5       | 0     |   | dut_stimuli[5] |
| 6       | 1     |   | dut_stimuli[6] |
| 7       | 0     |   | dut_stimuli[7] |
| В       | 0     |   | reset_n        |
|         |       |   |                |

### Figure 168 • Stimuli Channels Value Setting Example

# Setting Multiple Stimuli Values as a Bus

The Assign Bussed Values Dialog wizard allows assigning a value to multiple signals from the SnapShot Debugger view (page 141) Stimuli Channels table as a bus. After configuring the bus in the dialog, the values of each signal are propagated to all the selected signals in the SnapShot Debugger View (page 141). There are two ways to launch this dialog to allow bus assignment of values:

1. Left click to select a single row in the SnapShot Debugger View (page 141) table which has a bussed signal name (i.e., din[2]).

Right click to edit the **Value by Bus**. This method automatically finds all other bits in the bus with the same signal name (i.e., din[0], din[1], din[2], etc.) and opens the dialog to allow editing of the entire bus of signals.

2. Hold CTRL or SHIFT and left click to select multiple rows in the SnapShot Debugger View (page 141) table.

Right click to edit the **Value by Selection**. This method opens the dialog to allow editing of all selected signals as a bussed value.

| O Ass  | O Assign Bussed Values                                                                               |               |               |  |  |  |  |  |  |  |  |
|--------|------------------------------------------------------------------------------------------------------|---------------|---------------|--|--|--|--|--|--|--|--|
| This   | Bus Value Assignment This wizard allows you to automatically configure the value of a bussed signal. |               |               |  |  |  |  |  |  |  |  |
| Binary | Binary Value 10100011                                                                                |               |               |  |  |  |  |  |  |  |  |
| Hex V  | alue                                                                                                 | a3            |               |  |  |  |  |  |  |  |  |
| Decin  | nal Value                                                                                            | 163           |               |  |  |  |  |  |  |  |  |
| Bit    | Valu                                                                                                 | e Signal Name |               |  |  |  |  |  |  |  |  |
| 0      | 1                                                                                                    | limit_a[0]    |               |  |  |  |  |  |  |  |  |
| 1      | 1                                                                                                    | limit_a[1]    |               |  |  |  |  |  |  |  |  |
| 2      | 0                                                                                                    | limit_a[2]    |               |  |  |  |  |  |  |  |  |
| 3      | 0                                                                                                    | limit_a[3]    |               |  |  |  |  |  |  |  |  |
| 4      | 0                                                                                                    | limit_a[4]    |               |  |  |  |  |  |  |  |  |
| 5      | 1                                                                                                    | limit_a[5]    |               |  |  |  |  |  |  |  |  |
| 6      | 0                                                                                                    | limit_a[6]    |               |  |  |  |  |  |  |  |  |
| 7      | 1                                                                                                    | limit_a[7]    |               |  |  |  |  |  |  |  |  |
|        |                                                                                                      |               |               |  |  |  |  |  |  |  |  |
|        |                                                                                                      |               |               |  |  |  |  |  |  |  |  |
|        |                                                                                                      |               |               |  |  |  |  |  |  |  |  |
|        |                                                                                                      |               |               |  |  |  |  |  |  |  |  |
|        |                                                                                                      |               |               |  |  |  |  |  |  |  |  |
| 0      |                                                                                                      |               | Finish Cancel |  |  |  |  |  |  |  |  |

Figure 169 • Assigned Bus Values Dialog Wizard Example

See Assign Bussed Values Dialog (page 157) for more information on this dialog.

# **Configuring Advanced Options**

# **Pre-Store**

In the **Snapshot Debugger View** (page 141), the **Pre-Store** setting configures the portion of samples that are collected before the trigger, and (indirectly) how many are collected after the trigger.

For example, assume that Snapshot is configured to use a monitor depth of 1024 samples. See the table below:

| "Pre-Store" value | Samples collected before trigger | Samples collected after trigger |
|-------------------|----------------------------------|---------------------------------|
| 0%                | 0                                | 1024                            |
| 25%               | 256                              | 768                             |
| 50%               | 512                              | 512                             |
| 75%               | 768                              | 256                             |

## Table 145 • Effect of "Pre-store" on samples collected before and after the trigger event

When a **Pre-Store** value other than **0%** is selected, the .vcd file contains a signal snapshot\_pre\_store that transitions (goes low) at the point where the (last sequential) trigger event occurred. Thus, the trigger event may easily be found without needing to actually count the samples.

# **Trigger Pattern Match Behavior**

The values within a trigger pattern may cause a trigger match event either by ANDing or ORing. If ANDing, then *all* signal values not masked (set to X) must match their pattern for the trigger match event to occur. If OR'ing, the trigger match event occurs if *any* of the non-masked (not set to X) signal values match the specified pattern. The AND/OR configuration is set per sequential trigger using the **Select using AND** or **Select using OR** radio buttons. This selection can be different for each sequential trigger.

# **User Clock Frequency**

The **Frequency** field must be configured to match the the user\_clk frequency in the target user design, which typically matches the timing constraint set in the SDC file of the design being debugged. The value from the user design SDC file is set automatically in the names.snapshot file when an active implementation is available. The frequency value entered in the Snapshot GUI (or .snapshot configuration file) determines the time (in picoseconds) for all signals shown in the captured VCD file. All samples are captured at the rising edge of the Snapshot user\_clk signal.

# **Configure Output File Locations**

The final Snapshot configuration steps specify the locations of the output files which contain the log messages and sample data collected by Snapshot.

File Paths Relative To Chooses whether the Log File and Waveform File paths are understood to be relative to the Active Project directory or to the Working Directory. (This setting only matters when the Log and Waveform file paths provided are relative paths, and not absolute paths). When the Working Directory option is chosen, keep in mind that the working directory will be the path returned by the Tcl command pwd. (See https://www.tcl.tk/man/tcl8.6/TclCmd/pwd.html)

**Log File** configures the file name and path for the log file generated by the Snapshot Debugger run. The associated **Browse** button provides a directory/file selection dialog for the selection of a location different than the default (the

default is <active\_impl\_dir>/log/snapshot.log, or if there is no Active Project and Implementation (page 231), <user\_home>/snapshot.log). If an error occurs during setup or while reading back the sample information, the Snapshot log file contains the error messages.

**Waveform File** configures the file name and path for storing downloaded sample waveform information from the SnapShot Debugger core in VCD format. The **Browse** button allows for the selection of a location different than the default (the default is <active\_impl\_dir>/output/snapshot.vcd, or if there is no active implementation, <user\_home>/snapshot.vcd).

# Collecting Samples of the User Design

#### 👍 Caution!

#### The JTAG connection must be configured before collecting Snapshot samples!

ACE interacts with the FPGA or eFPGA using the JTAG interface through a USB Bitporter2 pod or FTDI FT2232H device. This JTAG interface must be properly configured in ACE before using the **Snapshot Debugger View** (page 141). The configuration is managed using the **Configure JTAG Connection Preference Page** (page 193), which is easily accessible by pressing the ( $\stackrel{\frown}{=}$ ) **Configure JTAG Interface** button in the upper-right of the view. See **Configuring the JTAG Connection** (page 359) for more details. The ( $\stackrel{\frown}{=}$ ) **Configure JTAG Interface** button provides a summary of the current JTAG configuration settings (for pod name and scan chain) in its tooltips for ease of reference.

Starting in ACE 9.2, Snapshot uses Tcl JTAG commands instead of STAPL commands for all JTAG interactions (see *JTAG Configuration User Guide* (UG004) and *Snapshot User Guide* (UG016) for details). If taking advantage of the Tcl JTAG libraries, this slightly complicates things, because now it must be ensured that the JTAG device is not connected when starting to use Snapshot (at present, using the Snapshot Debugger view requires sole ownership of the JTAG device connection, and errors are reported if Snapshot fails to open the device connection on its own. Achronix plans to relax this limitation in a future release of ACE, ensuring that Snapshot can share an already-open JTAG connection with others). What this means is that jtag::close must be called on the connection (if already open) before Snapshot can use the connection.

#### Caution! The JTAG connection must be closed before collecting Snapshot samples!

Snapshot must be the sole owner of the Tcl JTAG connection to the JTAG device for the lifetime of the polling/collection. This means jtag::close must be called (if the Tcl JTAG connection was previously opened) before starting the () Arm or () Capture Startup Trigger actions. If the Tcl JTAG connection to the JTAG device name remains open when either action is started, the attempted action fails, and an error message is placed in the .log file reporting that Snapshot was unable to open the named JTAG connection.

## Arming the Snapshot Debugger

When all the fields in the **Snapshot Debugger view** (page 141) are configured, and the design is running on the target device, Snapshot is ready to be armed.

Select the (**O**) **Arm** button (or the (**O**) **Arm Snapshot** button in the SnapShot Debugger view toolbar), and the ACE Snapshot Debugger sends the configuration data (including the optional stimulus) to the ACX\_SNAPSHOT

(or ACX\_SNAPSHOT\_JTAG\_UNIT) circuit running on the Achronix device, waits for the trigger condition(s) to be met, retrieves the trace buffer contents, and outputs a VCD file as well as a LOG file.

When Armed, Snapshot begins to analyze the already-executing design in real-time.

The Snapshot log file and Snapshot waveform file are populated with the captured results, and the files are opened in ACE (the log file opens in an ACE **text editor** (page 10), while the waveform (.vcd) file opens in the ACE **VCD waveform editor** (page 11)). If an error occurs during Snapshot Debugger configuration or while reading back the sampled information (trace buffer), the Snapshot log file contains the relevant error messages, and the Snapshot waveform file is not created/updated.

The ( I cancel button aborts the Snapshot arming process. The Snapshot log file is updated, but the Snapshot waveform file is not created/updated if the cancel button is clicked. Cancel is useful if accidentally sending in trigger conditions that are never matched.

If using **Repetitive** trigger mode, Snapshot repetitively executes the arm action for the number of records specified, or until the cancel button is clicked. See **Configuring the Trigger Pattern** (page 366) for details on the Repetitive Trigger feature.



Figure 170 • Snapshot Debugger Arming Example

## Using the Startup Trigger

The Startup Trigger feature is a very special case of Snapshot sample collection, intended specifically to fill the trace buffer based upon captured trigger events that happen very soon after the Achronix FPGA enters user mode. When Snapshot is configured to use the Startup Trigger feature, unlike typical interactive Arming, this means the macro automatically arms as soon as the FPGA enters user mode, so that trigger analysis (and potentially sample collection) can begin immediately. When the (%) **Capture Startup Trigger** action is selected, ACE does not arm the

Snapshot circuit (and does not send any stimuli), but simply starts polling the Snapshot circuit already running on the Achronix device, waits for the trigger conditions to be met (if not already met prior to the button being pressed), and retrieves the populated trace buffer contents. It is not unusual for the trace buffer to already be filled, ready and

waiting (because the trigger conditions had already been met), when the user starts the (<sup>N</sup>) **Capture Startup Trigger** action in ACE. After the trace buffer data has been retrieved, Snapshot creates the VCD file based on the collected trace buffer contents. Of course, a Snapshot . Log file (with the name and path chosen in the **Advanced Options** section in the **Log File** field) is also always populated to provide additional success/failure details, and is opened in the ACE GUI when the action is complete, along with the VCD file.

Be aware that before the Startup Trigger functionality can be used in the Snapshot Debugger view, the Startup Trigger feature must have already been specifically enabled using the initial startup trigger parameters on the ACX\_SNAPSHOT (or ACX\_SNAPSHOT\_JTAG\_UNIT) macro, which includes the needed circuit configuration in the bitstream used to program the Achronix FPGA/eFPGA (see the *Snapshot User Guide* (UG016) for details). This of course means that any time the macro parameters are changed, the bitstream needs to be regenerated and the Achronix device need to be reprogrammed.

Because the Startup Trigger functionality can only be used at chip startup, the FPGA needs to be reset and reprogrammed between Startup Trigger attempts.

Be aware that as soon as the (**O**) **Arm** action is triggered in any session where the Startup Trigger function was configured in the Snapshot circuit, (before the FPGA has been reset/reprogrammed) the startup trigger conditions and any pre-existing trace buffer contents are cleared when the interactive Arm action re-initializes the Snapshot circuit.

# Viewing the Captured VCD Waveform

ACE includes a built-in simple VCD waveform viewer, called the VCD Waveform Editor (page 11), which is used whenever any ACE-generated \*.vcd file is opened within ACE. This viewer is only used when viewing VCD files generated by Snapshot, typically from the Snapshot Debugger View (page 141) when Running the Snapshot Debugger (page 363) or after using the run\_snapshot (page 701) Tcl command in ACE batch mode. The VCD waveform editor currently does not allow loading of \*.vcd files generated outside of ACE/Snapshot and will instead show an error message; it is required that third-party VCD viewers be used for VCD files not generated by Snapshot.

If the VCD Waveform Editor (page 11) has insufficient functionality for some use cases, be aware that the \*.vcd file created by Snapshot uses the industry standard format, thus any third party VCD viewer can also be used to examine the ACE-generated VCD files.

The VCD waveform viewer does not allow editing the content of a \*.vcd file, but it does allow users to alter which of the signals captured within the VCD are displayed, to change the order of the displayed signals, and to compare/ contrast the captured values graphically as waveforms.

The example screenshot below shows an example dataset from a Snapshot session where relatively few signals were captured with a high sample count. Three signal names are visibly selected in the name/value table (the rows in the table with a grey background), with their waveforms displayed in bold orange. The marker line is also visible in the waveform area, in pink, with the values of each of the signals at that exact marker time displayed in the table on the left (in the **Value** column). Bussed signals also have their values displayed in the table in hex format, and bus values are also displayed in the waveform area (when the visible area between bus edges is wide enough to fit the bus value), again in hex format. Buttons can be seen above the table on the left to operate on the table contents as a whole. Buttons can seen below the table on the left to change the table content in a more granular manner. Buttons can be seen in the upper-right above the waveform to scroll and zoom the content of the waveform area. Below the

waveform area are live feedback labels describing the tick (or time) counts for the onscreen area, the marker position, and the mouse cursor position. At the very bottom left of the screenshot, tabs can be shown that allow switching between the **Waveform** view of the file data, and the **File Preview** (raw textual) view of the VCD file. While not shown in the screenshot, tooltips are also supported over the waveform area, which will show the signal/bus name, value, and tick/time under the mouse cursor.



## Figure 171 • VCD Waveform Editor Example

The VCD Waveform Editor (page 11) page describes each of these features at a high level, while the following sections describe in more detail how each feature may be utilized.

# Opening a VCD file

When using the **Snapshot Debugger View** (page 141), Snapshot automatically opens any VCD files as soon as they are created (or updated) during a Snapshot session.

When ACE starts, ACE also automatically re-opens any VCD files that were previously open the last time ACE was closed.

There are also several ways to manually open VCD files previously generated by Snapshot:

- With the drop-down application menu choice **File** → (<sup>22</sup>) **Open Files** and/or the (<sup>22</sup>) **Open Files** button (in the upper left, in the application button bar), arbitrary files can be browsed to and opened graphically, including VCD files.
- If a Snapshot VCD file was previously output to one sub-directory of an implementation (for example, output or reports), the file can be opened by selecting it from the corresponding file listings in the Projects View (page 120).
- The Tcl command display\_file (page 627) can be used (from the Tcl Console View (page 146)) to open VCD files (or any other files) in ACE.

### **Re-Opening the Same Filename Restores Prior State**

ACE includes the ability to remember many details, by filename/path, of the chosen configuration in the VCD editor. When a previously-used filename/path is re-opened, either manually or automatically, ACE tries to restore many details from the prior VCD viewing session, like the exact signals which were chosen to be visible, and their relative ordering in the signals table. Restoring the exact prior configuration is not always possible, of course, if certain details (like the signal names being captured) are changed between sessions (as may occur when existing VCD files are overwritten by a later capture).

## Viewing the Raw Text Content

While ACE always defaults to showing the VCD file content as waveforms, the raw textual content of the file can always be viewed by selecting the **File Preview** tab in the lower-leftmost corner of the view.

There are no special features available when viewing the VCD file textual content in this manner.

## Viewing the Signal Data as Waveforms

When opening a VCD file, ACE always defaults to showing the VCD file content as waveforms. If using the **File Preview** to view the raw text, user may always return to viewing the waveform data by selecting the **Waveform** tab in the lower-leftmost corner of the view.

There are a wide variety of ways that ACE allows altering which portion of the captured data is visible and in what order. These are mentioned in detail in the following sections.

#### What is Displayed by Default

When opening a VCD file for the first time, ACE defaults to showing every captured signal, and when encountering a bus signal, shows only the consolidated bus. The individual captured bits within the bus are available, but will be collapsed by default.

The order of the signals in the table (and accompanying waveforms) initially match the order of the signals as found in the VCD file.

The initial position of the waveform marker is the first moment of the trace, at tick 0. Thus, in the signals table, the values shown are also from tick 0. (The values column in the signals table always represents the value found for the signal at the time of the marker.)

Though ACE remembers for future sessions all changes regarding which signals are displayed, and in which order,

the (\*) **Reset Signal Table** button in the upper left above the signals table will forget prior setting and restore the displayed signals to defaults, as if the file were being loaded for the first time.

### Adjusting the Table and Table Column Widths

The width of the entire signals table may be adjusted by dragging the separator between the table and the waveform to the right/left. If the table width is too narrow to display all the contained columns, a horizontal scrollbar allows scrolling the table content to the right or left.

As with most tables in ACE, the column widths within the signals table can be adjusted by dragging the vertical column separator (the vertical grey line between the column header titles) to the right/left to widen/narrow each column. When a column is too narrow to display its full content, the column content is truncated and an ellipsis suffix is appended. On some operating systems/desktop environments/themes, it is also possible to double-click any table column separator to cause the column (to the left of the separator) to automatically resize its width to accommodate its widest content for all the rows which are visible on screen. On some desktop configurations (and table widths), the right edge of the rightmost (value) column may not be easily distinguishable/visible; in these cases, scroll the entire table as far right as possible, then treat the right edge of the table as the rightmost column separator.

### Panning/Scrolling the Table and Waveform Contents

The signals table can be scrolled vertically using the table vertical scrollbar or the waveform vertical scrollbar. Both the table and the waveform scroll vertically in lockstep, so that the signal name/value and the waveform for that signal are always aligned (as if the waveform was just another column in the table). The mouse scroll wheel can be used over the signals table (and the table vertical scrollbar) to scroll vertically. On some operating systems/desktop environments/themes, using the scroll wheel over the waveform area vertical scrollbar also scrolls the table and waveform area vertically (though on others, it changes the zoom level of the waveform area).

Scrolling horizontally, the signals table and waveform are are not in lockstep, and are independent. Horizontal scrolling of each can be done clicking/dragging their horizontal scrollbars independently. On some operating systems/desktop environments/themes, using the mouse scroll wheel over the waveform area horizontal scrollbar also scrolls the waveform area horizontally (though on others, it changes the zoom level of the waveform area).

The ( ) Move marker to previous edge and ( ) Move marker to next edge buttons can also be used to move the marker, and the waveform is panned to center horizontally on the marker position. When a single row is selected in the table, the marker finds the previous/next edge for that signal. When multiple rows are selected in the table, the marker finds the previous/next edge detected for any of the signals at those rows in the table. (When there are no signals selected in the table, these buttons become disabled.)

The up/down arrow keys on the keyboard may also be used to change the selected table row vertically, and when the top/bottom of the table are reached, pan/scroll the table vertically (with the waveform area moving vertically in lockstep). After clicking the mouse in the waveform area to give the waveform area focus (which also moves the marker to the clicked position), the up/down/left/right arrow keys on the keyboard can also be used to pan/scroll the waveform area vertically or horizontally, with the signals table moving vertically in lockstep with the waveforms.

## Changing the Waveform Zoom Level

The ( ) **Zoom in** button (found in the upper-right of the waveform area) causes the horizontal space used to represent one tick (or unit of time) to get wider. The rescaled visible area is based around the center of the current visible area, not around the mouse position nor the marker position.

The ( $\triangleleft$ ) **Zoom out** button (found in the upper-right of the waveform area) causes the horizontal space used to represent one tick (or unit of time) to get wider. The rescaled visible area is based around the center of the current visible area, not around the mouse position nor the marker position.

Using the mouse vertical scroll wheel over the waveforms similarly changes the zoom level in the waveform area. Be aware that when using the mouse wheel, the mouse position is taken into account, so the tick/time under the mouse stays visible as the zoom changes. On some operating systems/desktop environments/themes, using the mouse scroll wheel over the waveform area's scrollbars may pan/scroll the waveform area instead of changing the zoom level.

There are also several keyboard shortcuts that may be used when/if the waveform area has application focus. (Click the mouse in the waveform area, including either waveform scrollbar, to move application focus so that the keyboard shortcuts work.) The "**Z**" and "+" (plus) keys zoom in based on the mouse cursor position, and the "**z**" and "-" (minus) keys zoom out, also based on the mouse cursor position.

## Changing the Order of Displayed Signals

There are two ways to change the position of a single signal within the signals table:

- Select one (or more, as long as they are adjacent) row(s) in the table, then press the **Move Up** and **Move Down** buttons (found below the table) to move the selected rows up and down with respect to their neighbors.
- Select one row in the table, then vertically drag that row to the desired destination position in the table. Visible feedback is provided (a horizontal bar, bold and/or colored, the details vary based on the OS/desktop environment/theme) to indicate the drop/insertion point between the current rows of the table.

Multiple adjacent selected signals in the table can be moved together as a unit using the same actions. To select multiple rows, click the first row, press and hold the **Shift** key on the keyboard, then click and release the mouse button over the second row, causing all intervening rows to be selected at once. (Note that when using drag-and-drop, the **Shift** key on the keyboard must remain pressed during the drag-and-drop operation, and should not be released until the mouse button has already been released at the drop/insertion location.)

Be aware that contiguous bus bits are not allowed to be separated/split from their parent bus. When moving a bus, the bus and all its contiguous bits will move as a single unit. Similarly, when moving anything past a bus, the moved row(s) will move over the entire bus (and all contiguous bits) in one step.

Keep in mind that if a signal is going to be moved a significant distance, it may be faster to hide/remove the signal, and then re-add/insert the signal directly at the new desired location.

## Adding VCD File Signals to the Display

With the Add button and the accompanying Add Signals to Waveform Viewer Dialog (page 150), one or more signals can be added and placed anywhere within the signals table.

To insert a signal at the top of the table:

- 1. Ensure that no rows of the table are selected. If necessary, deselect any selected rows by holding the keyboard **Ctrl** key while clicking a selected row.
- 2. Press the Add... button to bring up the Add Signals to Waveform Viewer Dialog (page 150),
- Find and select the desired signal(s) in the list. (If your desired signals are not in the list of hidden signals, which is shown by default, first select the Select from All Signals mode in the dialog.) To select more than one signal, press and hold the Shift key when clicking the mouse to select multiple adjacent signals. Press and hold the Ctrl key on the keyboard when clicking to select multiple non-adjacent signals.
- 4. Press the **Insert** button in the dialog to insert the chosen signals at the top of the table.

To append a signal at the bottom of the table:

- 1. (The selection state in the table does not matter when appending signals to the bottom of the table).
- 2. Press the Add... button to bring up the Add Signals to Waveform Viewer Dialog (page 150),
- Find and select the desired signal(s) in the list. (If your desired signals are not in the list of hidden signals, which is shown by default, first select the Select from All Signals mode in the dialog.)
   To select more than one signal, press and hold the Shift key when clicking the mouse to select multiple adjacent signals. Press and hold the Ctrl key on the keyboard when clicking to select multiple non-adjacent signals.
- 4. Press the **Append** button in the dialog to append the chosen signals to the bottom of the table.

To insert a signal in the middle of the table:

- 1. Select the one row immediately below the desired row where the signals should be inserted.
- 2. Press the Add... button to bring up the Add Signals to Waveform Viewer Dialog (page 150),
- 3. Find and select the desired signal(s) to be added from the list in the dialog. (If your desired signals are not in the list of hidden signals, which is shown by default, first select the Select from All Signals mode in the dialog.) To select more than one signal, press and hold the Shift key when clicking the mouse to select multiple adjacent signals. Press and hold the Ctrl key on the keyboard when clicking to select multiple non-adjacent signals.
- 4. Press the **Insert** button in the dialog to insert the chosen signals before the row that was selected. Recall that buses are not allowed to be split, so if the insertion point attempted (the selected row in the signals table) is a bus bit, the actual insertion will occur before the entire bus.

## **Duplicating Signals**

It is often desirable to have a signal included in the table (and waveform area) multiple times to ease value comparisons. Simply choose your insertion point in the table as mentioned above, then use the **Add..** button to add another copy of the desired signal to the table. (Make sure the **Select from All Signals** mode in the **Add Signals to Waveform Viewer Dialog** (page 150) is chosen, because the signal is already displayed, and, thus, is not in the list of currently hidden signals.) If necessary, then use the **Move Up** and **Move Down** buttons (or drag-and-drop signals in the table using the mouse) to better align the copied signal in relation to its peers.

## Removing/Hiding Displayed Signals

Signals can also be hidden/removed from the table (and simultaneously the waveform area).

Simply select the row(s) in the signals table containing the signal(s) to be hidden/removed, then press the **Remove** button below the table, or right-click and select **Remove** from the context menu. The chosen signal(s) are hidden.

Keep in mind, this does not affect the content of the VCD file, and the signal(s) may still be revealed/added again at any time (and at any desired position in the table).

### **Examining Signal Values**

While it is possible to see the values of all the signal traces by simply examining the waveform, proper use of the signals table in combination with the waveform area can make things much easier.

#### **Bits Versus Buses**

lcons are shown to the left of each signal name as an indicator whether the name corresponds to a individual bit signal, or a bus, or a bit within a bus.

#### Table 146 • Signal Name/Value Table Icons

| lcon | Description |
|------|-------------|
| -    | Signal      |
| I    | Bus         |
| ŀ    | Bus bit     |

In the table, the values (in the Values table column) of bit signals and bus bit signals are shown as a simple 0 or 1. The Values column for a bus row will be shown in (unsigned) hexadecimal format.

Additionally, bus hex values are displayed within the waveform area when there is sufficient horizontal space between edges of the value to contain the rendered value string. Zooming in on the waveform area increases the horizontal distance between bus edges, allowing wider bus values to become visible.

When dealing with wide buses, it might make sense to make the waveform font choice as small a point size as remains legible, allowing wider bus values to be shown in the same amount of horizontal space. Use the (

% ) **Configure colors...** button (in the upper-right above the waveforms) to quickly access these color and font preferences.

#### Expanding and Collapsing Buses and Bus Bits

Buses will be shown collapsed by default, with none of the individual bits of the bus being visible.

Buses can optionally be expanded to expose the individual bits. All bits of all buses can be expanded at once by

using the ( 🖽 ) **Expand All Buses** button, in the upper left above the signals table. A single bus may be expanded by selecting the bus row in the table, then right clicking the mouse on that row, and selecting **Expand Bus** from the context menu.

After a bus has been expanded to show its bus bits, it can also be collapsed again. All bits of all buses can be collapsed at once by using the ( ) **Collapse All Buses** button, in the upper left above the signals table. A single bus

may be collapsed by selecting the bus row or the row for any of its bits in the table, then right clicking the mouse on that row, and selecting **Collapse Bus** from the context menu.

### **Highlighting Signal Rows**

When rows are selected in the signal table, the corresponding waveforms are rendered with a special selection foreground color (orange by default). Optionally, using font preference settings (see below), selected bus values in the waveform area may also be rendered in a user-selected font to make them stand out even more, if the selection foreground color change is insufficient.

Multiple rows in the table may be selected (and thus highlighted in the waveforms) simultaneously by holding the CTRL key on the keyboard while clicking on each desired signal row in the table.

#### Understanding How the Waveform Area Represents Time

The Snapshot signal traces are captured with respect to both a snapshot clock (ticks, abbreviated "tk") and an elapsed time (shown in s, ms, us, ns, ps, or fs, whichever is most appropriate). Ticks and elapsed time may be toggled between by pressing the button centered below the waveform area (which alternates between the labels **Show Ticks** and **Show Times** each time it gets pressed).

There are four labels below the waveform area that show the times for various portions of the interface:

| Label  | Description                                                                                                                                                   |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Left   | The tick or elapsed time value at the leftmost visible part of the waveform area.                                                                             |
| Right  | The tick or elapsed time value at the rightmost visible part of the waveform area.                                                                            |
| Marker | The tick or elapsed time value at the marker bar, which may be offscreen, and may thus have a value less than the left value or greater than the right value. |
| Cursor | The tick or elapsed time value at the cursor horizontal position.                                                                                             |

#### (i) Note about Cursor values

When the mouse moves away from the waveform area, the last position over the waveform is retained by the **Cursor** value. This ps or tk value does not change until the mouse cursor is again over the waveform, even if the view is scrolled or the zoom factor is changed.

#### Using the Marker

The waveform area includes support for a user-managed marker, represented as a pink colored vertical bar by default, to allow examining signal values at chosen points in time/ticks.

When the marker is moved, the **Values** column in the signals table are immediately updated to contain the values of all signals at the point in time/ticks represented by the marker location. Additionally, the value of the "marker" label below the waveform area is updated to show the exact time/tick value of the marker.

#### Targeted Marker Placement

Clicking the primary mouse button anywhere within the waveform area moves the vertical marker bar to the horizontal position that was clicked. (When zoomed far enough out, the marker may even be placed after the trace has ended.)

The "m" (for marker) and "s" (for select) keyboard shortcuts also causes the marker to be placed under the current cursor position. (If the cursor is over the signals table, the marker is moved to the left edge of the visible waveform area, such that the tick/time value shown for the "Left" and "Marker" values below the waveform area matches.)

Using the Marker to Find the Next or Previous Signal Edge

The ( ) Move marker to previous edge and ( ) Move marker to next edge buttons (found in the upper-right of the waveform area) can also be used to move the marker from its current position to a new signal edge position, and the waveform is panned to center horizontally on the marker position. When a single signal is selected in the table, the marker finds the previous/next edge for that single signal. When multiple signals are selected in the table, the marker finds the previous/next edge detected for any of the signals selected in the table. (When there are no signals selected in the table, these buttons become disabled.)

## Tooltips

The waveform area includes tooltip support and will thus display the signal name, signal value, and time corresponding to the current mouse cursor position.

## Editing Waveform Color and Font Preferences

All of the colors and fonts used within the waveform area (as well as the font used in the table) are allowed to be adjusted as **Preferences** (page 191). These can be reached quickly by pressing the ( $\ref{eq:page 191}$ ). These can be reached quickly by pressing the ( $\ref{eq:page 191}$ ). These can be reached quickly by pressing the ( $\ref{eq:page 191}$ ). These can be reached quickly by pressing the ( $\ref{eq:page 191}$ ). These can be reached quickly by pressing the ( $\ref{eq:page 191}$ ). These can be reached quickly by pressing the ( $\ref{eq:page 191}$ ). These can be reached quickly by pressing the ( $\ref{eq:page 191}$ ). These can be reached quickly by pressing the ( $\ref{eq:page 191}$ ). These can be reached quickly by pressing the ( $\ref{eq:page 191}$ ). These can be reached quickly by pressing the ( $\ref{eq:page 191}$ ). Configure colors... button in the upper-right of the waveform area, or by navigating to Window  $\rightarrow$  Preferences  $\rightarrow$  General  $\rightarrow$  Appearance  $\rightarrow$  Colors and Fonts  $\rightarrow$  VCD Editor.

| Colors and Fonts                                                                |      | (⇒ ⇒ ⇒ 8              |
|---------------------------------------------------------------------------------|------|-----------------------|
| Colors and <u>Fonts</u> (font, size, type, ? = any character, * = any string) : |      |                       |
| type filter text                                                                |      |                       |
| ✓ ₩ VCD Editor                                                                  | ^    | Edit                  |
| Ar Table, Font (set to default: Tree and Table font for views)                  |      | _                     |
| Time Marker                                                                     |      | Use System Font       |
| Waveform, Background Color, Even Row                                            |      | <u>R</u> eset         |
| Waveform, Background Color, Odd Row                                             |      |                       |
| Aa Waveform, Font, Deselected rows (set to default: Dialog Font)                |      | Ed <u>i</u> t Default |
| May Waveform, Font, Selected rows (set to default: Dialog Font)                 |      | Go to Default         |
| Waveform, Foreground Color, Even Row Waveform, Foreground Color, Odd Row        |      | <u>No to pendant</u>  |
| Waveform, Foreground Color, Selected Row                                        |      | Expand All            |
| View and Editor Folders                                                         | ~    |                       |
| Description:                                                                    |      |                       |
|                                                                                 |      |                       |
|                                                                                 |      |                       |
| Previe <u>w</u> :<br>No preview available.<br>Restore <u>D</u> efau             | ilts | Apply                 |

Figure 172 • Default Colors and Fonts Used by the VCD Editor Area

These preferences can be altered to, for example, provide a green-on-black color scheme, as would be seen on a traditional lab scope. Some prefer to have a bold font for the selected signals (for hexadecimal bus values). An example of this sort of color and font scheme is visible in the screenshot at the end of the VCD Waveform Editor (page 11) description.

# Saving/Loading Snapshot Configurations

An existing known-good Snapshot configuration (the collection of settings in the **Snapshot Debugger View** (page 141)) may be re-used at a later date, or in batch mode.

Snapshot configurations may be saved to a Snapshot configuration file (with the .snapshot file extension) using the ( ) Save SnapShot Configuration button found in the Snapshot Debugger view (page 141) toolbar.

These Snapshot configurations may then be loaded later by using the ( ) Load SnapShot Configuration button, found in the Snapshot Debugger view (page 141) toolbar.

#### Note

Previously saved Snapshot configuration files are necessary to run Snapshot in Batch mode (page 387).

#### 🕑 Tip

When a user design containing the ACX\_SNAPSHOT macro completes the **flow step** (page 235) **Run Prepare**, a names . snapshot configuration file is automatically generated. This file contains harvested information from the design including the monitor width, monitor depth, monitored signal names, trigger width, maximum number of triggers, trigger signal names, stimuli width, stimuli signal names, and user clock frequency. When an **active project and implementation** (page 231) is available, the Snapshot Debugger view automatically loads the implementation names . snapshot file to pre-populate the relevant fields of the view. When generated, the file contains only a subset of a complete Snapshot configuration, and thus a generated names . snapshot file should not be used to drive **Snapshot in batch mode** (page 387) via Tcl.

The names.snapshot configuration file can be loaded as a starting point to map the Snapshot RTL configuration into the Snapshot Debugger View. The Snapshot settings can be further customized and saved as custom Snapshot configuration files for later use.

# Snapshot in Batch Mode

It is also possible to run Snapshot from ACE in batch mode or from the GUI Tcl Console. To do so, use the TCL command **run\_snapshot** (page 701). Note that **run\_snapshot** (page 701) requires the use of a **previously-saved** (page 386) Snapshot configuration file (.snapshot), and allows some values to be overridden by Tcl options. It can run Snapshot through either the Arm or Startup Trigger mode. The latter is selected with the <code>-startup\_trigger</code> option. See the **run\_snapshot** (page 701) command in the TCL Command Reference section for further details about the Tcl options. Note, <code>run\_snapshot</code> (page 701) functions the same as the **Snapshot** Debugger view (page 141). After running Snapshot, the JTAG connection status is retained, meaning that if the JTAG connection is open prior to calling **run\_snapshot** (page 701), it will stay open, and if the JTAG connection is closed prior to calling **run\_snapshot** (page 701), it will close the connection when programming completes.

The Snapshot configuration file may be edited manually in a text editor, or by configuring the Snapshot Debugger view (page 141) in the ACE GUI and saving the Snapshot configuration (page 386).

#### Example Snapshot Configuration File

```
#Snapshot Configuration File
#Tue Sep 12 13:52:54 PDT 2017
files_relative_to_project=1
frequency=322.0
log_file=./impl_1/log/snapshot.log
monitor_ch0.name=reset_n
monitor_ch1.name=stimuli_valid
monitor_ch10.name=limit_a[7]
monitor_ch11.name=counter_a[0]
monitor_ch12.name=counter_a[1]
monitor_ch13.name=counter_a[2]
monitor_ch14.name=counter_a[3]
monitor_ch15.name=counter_a[4]
monitor_ch16.name=counter_a[5]
monitor_ch17.name=counter_a[6]
```

```
monitor_ch18.name=counter_a[7]
monitor_ch19.name=counter_b[0]
monitor_ch2.name=arm
monitor_ch20.name=counter_b[1]
monitor_ch21.name=counter_b[2]
monitor_ch22.name=counter_b[3]
monitor_ch23.name=counter_b[4]
monitor_ch24.name=counter_b[5]
monitor_ch25.name=counter_b[6]
monitor_ch26.name=counter_b[7]
monitor_ch27.name=counter_b[8]
monitor_ch28.name=counter_b[9]
monitor_ch29.name=counter_b[10]
monitor_ch3.name=limit_a[0]
monitor_ch30.name=counter_b[11]
monitor_ch31.name=counter_b[12]
monitor_ch32.name=counter_b[13]
monitor_ch33.name=counter_b[14]
monitor_ch34.name=counter_b[15]
monitor_ch4.name=limit_a[1]
monitor_ch5.name=limit_a[2]
monitor_ch6.name=limit_a[3]
monitor_ch7.name=limit_a[4]
monitor_ch8.name=limit_a[5]
monitor_ch9.name=limit_a[6]
monitor_width=38
num_samples=4096
num_triggers=3
pre_store=0%
repetitive_trigger.overwrite_vcd=0
repetitive_trigger.record_limit=10
repetitive_trigger.vcd_record_limit=10
snapshot_version=3
stimuli=110010100
stimuli_ch0.name=stimuli[0]
stimuli_ch1.name=stimuli[1]
stimuli_ch2.name=stimuli[2]
stimuli_ch3.name=stimuli[3]
stimuli_ch4.name=stimuli[4]
stimuli_ch5.name=stimuli[5]
stimuli_ch6.name=stimuli[6]
stimuli_ch7.name=stimuli[7]
stimuli_ch8.name=do_reset
stimuli_ch9.name=stimuli_ch9
stimuli_width=9
trigger1.select_using_and=1
trigger2.select_using_and=1
```

```
trigger3.select_using_and=1
trigger_ch0.name=reset_n
trigger_ch1.name=stimuli_valid
trigger_ch10.name=limit_a[7]
trigger_ch11.name=counter_a[0]
trigger_ch12.name=counter_a[1]
trigger_ch13.name=counter_a[2]
trigger_ch14.name=counter_a[3]
trigger_ch15.name=counter_a[4]
trigger_ch16.name=counter_a[5]
trigger_ch17.name=counter_a[6]
trigger_ch18.name=counter_a[7]
trigger_ch19.name=counter_b[0]
trigger_ch2.name=arm
trigger_ch20.name=counter_b[1]
trigger_ch21.name=counter_b[2]
trigger_ch22.name=counter_b[3]
trigger_ch23.name=counter_b[4]
trigger_ch24.name=counter_b[5]
trigger_ch25.name=counter_b[6]
trigger_ch26.name=counter_b[7]
trigger_ch27.name=counter_b[8]
trigger_ch28.name=counter_b[9]
trigger_ch29.name=counter_b[10]
trigger_ch3.name=limit_a[0]
trigger_ch30.name=counter_b[11]
trigger_ch31.name=counter_b[12]
trigger_ch32.name=counter_b[13]
trigger_ch33.name=counter_b[14]
trigger_ch34.name=counter_b[15]
trigger_ch4.name=limit_a[1]
trigger_ch5.name=limit_a[2]
trigger_ch6.name=limit_a[3]
trigger_ch7.name=limit_a[4]
trigger_ch8.name=limit_a[5]
trigger_ch9.name=limit_a[6]
trigger_mode=Single
trigger_width=38
vcd_file=./impl_1/output/snapshot.vcd
```

# Programming a Device using JTAG in the Download View

This section describes the GUI features and end user tasks for programming a bitstream using a JTAG connection. Other modes of bitstream programming such as CPU, Serial Flash, and 2-stage over PCIe are covered in the *Configuration User Guide*.

### 🔒 NOTE

#### The JTAG connection must be configured before using the Download View!

ACE interacts with the FPGA using the JTAG interface through a Bitporter2 pod, or a FTDI FT2232H or FT4232H device. This JTAG interface must be properly configured in ACE before using the Download view. The configuration is managed using the **Configure JTAG Connection preference page** (page 193), which

is easily accessible by clicking the (<sup>10</sup>) **Configure JTAG Interface** button in the Download view. See **Configuring the JTAG Connection** (page 359) for more details.

A bitstream (\*. hex) file can be downloaded to the FPGA or eFPGA device from the **Download view** (page 43). To access the Download view, change to the ( $\stackrel{\blacksquare}{=}$ ) Programming and Debug perspective, or select **Window**  $\rightarrow$  **Show View..**  $\rightarrow$  **Others**  $\rightarrow$  **Download View**.

From this view, bitstream files can be selected for downloading, programming options can be adjusted, utility functions can be called against connected devices, and the actual download to the target device may be triggered.

# Selecting a Bitstream File

By default, the **Download View** (page 43) automatically remembers the last \*.hex bitstream file opened by the current userid, and pre-populates the filename/path with the last-used value when ACE is started.

When a different bitstream file is desired, it can be chosen by either selecting a hyperlink from the provided lists of bitstream files, or by pressing the **Browse** button.

As elsewhere in ACE, pressing the **Browse** button allows searching for \*.hex files in the filesystem using the graphical file browser native to the operating system desktop environment.

The view also remembers the last dozen or so files the chosen, and lists them in the Suggested Recently Used lists as hyperlinks. The list only displays files which are still valid choices. Previously used files which have been deleted from the file system are not be displayed in the list of suggestions. Select any listed hyperlink to make that file the active \*.hex bitstream file to be downloaded.

ACE also includes a suggestion list of all the \*. hex files that exist for the Active Project and Implementation (page 231). ACE updates this suggested file list whenever new files are created or when files are deleted. Unlike in prior versions, ACE no longer attempts to automatically pick which bitstream file should be used. A hyperlink must now be manually chosen when switching to a file to be the active bitstream used. Recent configuration feature improvements, such as support for Partial Reconfiguration and Multi-Stage Programming, make it impossible for the Download view to always display the bitstream file that is most needed.

### Lab Mode

The **Browse** button continues to work normally when in Lab Mode. The list of suggested **Recently used** files continues to be populated and usable. This list is updated if any new files (not already in the list) are chosen using the **Browse** button. But when ACE is in Lab Mode, it is impossible to load projects/implementations meaning there is never a "current" active project/implementation. Thus the list of suggested file hyperlinks from the active implementation is empty in Lab Mode.

# Selecting Bitstream Programming Options

While getting ready to use the **Download view** (page 43) to program a device with a bitstream \*.hex file, there are some configuration options available to be adjusted by toggling checkboxes in the view. Any adjustments should be made prior to each bitstream file download.

Table 147 • JTAG Programming Options

| Option                                                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Perform an FCU reset to clear the (e)FPGA<br>config memory    | When checked, performs a soft reset and clears all device<br>configuration memory before beginning programming. This reset is<br>typically only disabled for multi-stage programming after stage 0<br>programming has completed but before programming later stages<br>begins, or for Partial Reconfiguration when partial bitstreams are in<br>use (see the chapter titled Partial Reconfiguration in the<br><i>Speedster7t Configuration User Guide</i> (UG094) for more details). |
| Close the JTAG connection/device when programming is complete | By default, the chosen JTAG connection (see <b>Configuring the JTAG</b><br><b>Connection</b> (page 359)) is opened at the beginning of programming<br>(if it was not already open) and is closed when programming is<br>completed. Uncheck this box to leave the named JTAG connection<br>open when programming is complete, allowing additional JTAG<br>interactions to occur over the same open connection.                                                                        |

# Downloading the Bitstream to the Target Device

When using the Download view (page 43), after finishing Selecting a Bitstream File (page 390), and Selecting Bitstream Programming Options (page 391), perform the download to the target device by pressing the Download Bitstream button.

This causes the Tcl command jtag::download\_bitstream to be executed in the Tcl Console view (page 146) using the appropriate arguments. All feedback from the command (informational, warnings, and errors) appears in the Tcl Console view, and also is saved in the ACE session Log file (page 233).

For more information about the JTAG Tcl interface commands, and for troubleshooting information regarding common programming problems, please see the *Speedster7t Configuration User Guide* (UG094).

# Optimizing a Design

There are numerous methods of design optimization available in ACE.

Many optimizations can be performed automatically by ACE, at the cost of additional runtime. These automatic optimizations are managed at a granular level through the **implementation options** (page 0), which may be configured from the **Options view** (page 100) and/or the **set\_impl\_option** (page 712) Tcl command.

Achronix optimization experts have also collected together into **option sets** (page 0) the implementation options which are known to work well together. These option sets may be used to create new implementations for user designs, to allow comparing/contrasting how various optimizations affect achieved frequencies and required runtimes.

Other optimizations must be performed manually, typically by editing the design source RTL or .sdc timing constraints. Analyzing critical paths (page 352) is an important part of this process. Optimization through RTL changes is currently beyond the scope of this document — ask your Achronix Field Applications Engineer for more information regarding source optimization possibilities.

# Attempting Likely Optimizations Using Option Sets

In addition to running multiple flows in parallel (page 307), the Multiprocess view (page 75) allows generating new implementations with auto-generated combinations of implementation options (page 0). These known-good subsets of implementation options are called option sets (page 0).

ACE can generate customized option sets based on design details (such as the target device) found within the active project and implementation (page 231). These customized option sets are only generated by request, and are specific to the details of each implementation. To generate the customized option sets for the active implementation, use the Refresh Option Sets button in the Multiprocess view (page 75), or the option -create\_option\_sets when calling the run\_multiprocess (page 693) Tcl command.

The Multiprocess view allows selecting a starting template **implementation** (page 231) and then generating new implementations using the template implementation as a base. Each generated implementation overrides the implementation options found in the template implementation with the specified option set configuration (an overriding subset of the full collection of implementation options). The majority of the implementation options within the generated implementation are left with the same settings as existed in the template implementation. Only the options specified in the option set are overridden to take on new values. The newly generated implementation is given a name which includes the option set name for clarity (the generated name uses the template implementation name as a prefix, with the option set name as the suffix).

See the information in Running Multiple Flows in Parallel (page 307), which discusses the basic use of the Multiprocess view (page 75) and Multiprocess Summary report (page 256) — the rest of this section builds upon those descriptions.

### Selecting the Implementations to be Generated and Run in Parallel

After finding the Multiprocess view (page 307), configuring the execution queues (page 307), and configuring the desired flow to be followed by the selected implementations (page 314), the implementations to be generated may be selected:

- 1. In the Projects view (page 120), select (activate) the desired project (page 224) and implementation (page 231).
- 2. Select the radio button labeled **Generate Implementations from Option Sets**, found within the Multiprocess view **Select Implementations** (page 78) section.
- 3. Click the **Refresh Option Sets** button to generate new option sets particular to the details of the active project/ implementation. All of these custom option sets include "auto" in their names.
- 4. The Implementation Table within the Multiprocess view Select Implementations (page 78) section is then updated to display a collection of potential implementations based upon the active implementation (page 231), with names derived from the refreshed option sets.

The first entry in the Implementation Table is the active implementation itself. This implementation is the template from which all the generated implementations are derived. All other implementations in the table are generated, one for each option set, if they are selected (their checkbox is checked) when background execution is started. The Description column of the table indicates succinctly what implementation option changes are caused by each option set (thus describing how each generated implementation differs from the template, the active implementation).

### Generating Option Set Implementations and Starting Background Execution

After the ( ) Start Selected button has been pressed, but before the behavior described in Starting Background Execution (page 315) commences, ACE:

- 1. removes implementations in the active project with the same name as to-be-generated implementations
- 2. creates new implementations (exact copies of the template implementation) with the required names
- 3. applies the appropriate option set implementation options to the new implementations (overriding the inherited implementation option values with the subset making up the option set)
- 4. adds all selected (checked) implementations to the background processing queue(s), to be run through the flow

From this point on, the available functionality and behavior is identical to that described in Running Multiple Flows in Parallel (page 307), beginning with starting background execution (page 315).

#### A Warning!

Each generated implementation which is selected overwrites *without prompting* any already-existing implementation with the same name in the active project. The template (active) implementation is not changed/overwritten. If a previously-existing implementation with a to-be-generated name collision is kept,

the previously-existing implementation must be renamed to avoid the name collision *before* the ( ) **Start Selected** button is pressed.

### Interpreting/Utilizing the Results

After viewing the results (page 316), the final step of an optimization pass is usually comparing the results and choosing which generated option set implementation provides the best QoR in comparison to the template implementation.

By default, the implementations in the **multiprocess summary report** (page 256) are sorted approximately by QoR, though it is likely still preferred to analyze the results in detail to choose which implementation is the best by preferred criteria.

#### (i) Note

#### **Early Access Functionality**

The automatic QoR sorting of the Multiprocess Summary report should be considered early access functionality. The sort details are likely to change (and improve) in future ACE releases.

That best generated implementation could then be renamed, so that it does not get overwritten by future multiprocess runs (e.g., it might be named "fastest1", "lowestpower1", etc.).

With the newly-renamed implementation selected in the Projects view (making it the active implementation), it also becomes the new template implementation in the Multiprocess view, ready for another multiprocess iteration through the option sets.

By iterating through several best template implementations (perhaps each with a new implementation name for "breadcrumb" purposes), the desired QoR may be reached.

#### 👍 Caution!

Ensure **Generate Implementations from Option Sets** is selected for each optimization iteration, otherwise any changed implementation options in the template implementation are not inherited by the option set implementations.

Also, there is a scenario where all multiprocess results can be identical. The cause and a workaround are described in Running Multiple Flows in Parallel (page 316).

# Placement Regions and Placement Region Constraints

#### A Warning!

Placement Regions and Placement Region Constraints are an advanced feature, and should only be used under the guidance of an Achronix FAE. Unguided use of placement region constraints can cause loss of QOR, or may make a design impossible for the Placer or Router to solve.

#### (i) Note

#### ACE automated placement often produces better QOR than user-defined placement regions/constraints

When attempting to use Placement Regions and Placement Region Constraints, it is highly recommended that a parallel implementation of the project lacking the user-defined Placement Regions be kept. In a number of tested cases, completely automated placement in ACE was able to produce better QOR than with user-defined Placement Regions and Placement Region Constraints. This can easily be achieved by keeping the placement region constraints in a separate pdc file, which can then be enabled or disabled for the place and route flow.

Placement Regions are user-defined rectangular areas of the core fabric (*not* the IO Ring), to which the user can inclusively constrain the placement of multiple instances from their design, without needing to manually assign instances to specific sites within that region.

Because of clock distribution limitations, only a finite number of clocks can be routed to each of the **Clock Regions** (page 262) in the fabric. Placement regions allow advanced users to ensure that those constraints are met if the automated tools need guidance. When necessary, clocked instances (flops, BRAMs, etc) may be constrained to placement regions to guarantee ACE does not attempt routing more clocks into a region than the region can support.

Placement Regions and the associated instance placement constraints may be manipulated through Tcl, or via the ACE GUI using the Floorplanner View (page 45) and Placement Regions View (page 114). The Search View (page 133), Selection View (page 137), Critical Paths View (page 39), and Netlist Browser View (page 81) may also be used to assign instance placement constraints by using drag-and-drop operations.

Be aware that Placement Regions are not treated as distinct objects in the ACE design database. Thus, they do not have their own **object type prefix** (page 334), nor are they directly searchable in the **Search View** (page 133) or with the Tcl find (page 638) command.

# **Placement Region Preferences**

There are a number of user preferences which may be configured to alter how the mouse creates placement regions and assigns placement region constraints. These preferences are found on the **Placement Regions Preference** page (page 216).

# **Creating a New Placement Region**

Placement regions may be created/defined by using the mouse in the Floorplanner View, or by directly calling the Tcl command

#### create\_region (page 624)

. In both cases, the bounds of the created region may "snap to" (grow to encompass) the entirety of all enclosed Clock Region boundaries or tile boundaries.

To create a Placement Region using the mouse in the Floorplanner view:

- 1. Ensure the (🛅 ) Floorplanner Placement Region Tool is active.
- 2. (Optional) If the Placement region is meant to align with one or more **Clock regions** (page 262), enable the overlays for those regions from the **Clock Regions view** (page 25). This does not affect the functionality in any way, but makes it easier to know where to define the region bounds.
- 3. Press and hold the left mouse button with the cursor at one of the corners of the area to be defined as the new Placement region.
- 4. While still holding the left mouse button, drag the cursor to the opposite corner of the desired Placement region area. Release the left mouse button when the cursor reaches the desired location.
- 5. ACE calculates the enclosed subtile grid coordinates, growing the grid as necessary to ensure all partiallyenclosed tiles are fully enclosed.
- 6. The Create Placement Region dialog (page 171) pops up pre-populated with the calculated subtile coordinates:

| ⊘ Create Placement Region —                                                                                           |        | × |
|-----------------------------------------------------------------------------------------------------------------------|--------|---|
| Create Placement Region                                                                                               |        |   |
| You can create placement regions in the Core and constrain instances to them later via drag and drop or TCL commands. |        |   |
| Region Name region_1                                                                                                  |        |   |
| ✓ Include Routing                                                                                                     |        |   |
| Region Alignment<br>None<br>Snap to Tile Boundaries<br>Snap to Fabric Clusters<br>Snap to Clock Region Boundaries     |        |   |
| Region Type<br>Inclusive<br>Keep out<br>Soft                                                                          |        |   |
| Subtile Grid Coordinates                                                                                              |        |   |
| X1 Coordinate 36                                                                                                      |        |   |
| Y1 Coordinate 48                                                                                                      |        |   |
| X2 Coordinate 171                                                                                                     |        |   |
| Y2 Coordinate 187                                                                                                     |        |   |
|                                                                                                                       |        |   |
| ⑦ <u>Einish</u>                                                                                                       | Cancel |   |

### Figure 173 • Pre-Populated Create Placement Region Dialog

- 7. Fill in the desired Placement region name.
- 8. Select whether the Placement region should be snapped to align with the edges of the Clock regions (page 262), or the **fabric clusters** (page 281), or with the more granular grid of basic resource tiles.
- 9. Select whether the Placement region should be an inclusive region, a "keep out" region, or a soft region (see the **create\_region** (page 624) Tcl command documentation for more information on these options).
- 10. Click the **Finish** button to create the new Placement Region.

11. ACE adds the new Placement Region to the table in the **Placement Regions View** (page 114) and displays it as a translucent overlay within the Floorplanner (at this point, the region contains no constraints).

# Resizing an Existing Placement Region

Existing Placement Regions may be resized with the **set\_region\_bounds** (page 716) Tcl command, or with the mouse in the Floorplanner view. Any existing Placement Region Constraints for that region are kept — only the enclosed area is updated.

To resize a Placement Region with the mouse in the Floorplanner View (page 45):

- 1. Ensure the (🛅 ) Floorplanner Placement Region tool is active.
- 2. In the **Placement regions view** (page 114), ensure the checkbox in the first column is selected for the desired Placement region. This makes the Placement region overlay visible within the Floorplanner view.
- 3. Ensure the Snap To: option in the Placement Regions Preference page (page 216) is configured as desired.
- 4. (Optional) If the Placement region is meant to align with (snap to) one or more **Clock regions** (page 262), enable the overlay for those regions from the **Clock Regions view** (page 25). This action does not affect the functionality during the resize in any way, but makes it easier to know where to define the region bounds.
- 5. Move the mouse over any of the four corners of the placement region to be resized. The mouse cursor changes to a diagonal resize cursor when in a potential resize location.
- 6. Press and hold the left mouse button and drag the mouse to expand or shrink the Placement region area as desired.
- 7. Release the left mouse button when the mouse is at the desired location.
- 8. ACE calculates the enclosed subtile grid coordinates, growing as necessary to ensure all partially-enclosed subtiles (or Clock regions) are fully enclosed.
- 9. The Placement Region View table content is updated to show the new site counts enclosed by the Placement region, and the Floorplanner is updated to show the new Placement region overlay.

# Moving an Existing Placement Region

Existing Placement Regions may be moved with the **set\_region\_bounds** (page 716) Tcl command, or with the mouse in the **Floorplanner view** (page 45). Any existing Placement Region Constraints for that region will be kept — only the enclosed area will be updated.

Be aware that the **Snap To** setting is enforced during the move — the enclosed area might not stay the same dimensions after the move. As with creating/resizing a region, the area will grow to ensure there are no partial sites in the enclosed area. It is frequently desired to resize (shrink) the Placement Region after a move, as it can easily grow larger than expected if sites/Clock Regions were partially enclosed at the ending mouse location.

To move a Placement Region with the mouse in the Floorplanner:

- 1. Ensure the (🛅 ) Floorplanner Placement Region Tool is active.
- 2. In the Placement Regions view, ensure the checkbox in the first column is selected for the desired Placement Region. This selection makes the Placement Region visible within the Floorplanner view.
- 3. Ensure the Snap To option in the Placement Regions Preference Page (page 216) is configured as desired.
- 4. (Optional) If the Placement Region is meant to align with (snap to) one or more **Clock Regions** (page 262), enable the overlay for those regions from the **Clock Regions view** (page 25). Enabling the overlay does not affect the functionality during the resize in any way, but makes it easier to know where to define the region bounds.

- 5. Move the mouse over the placement region to be moved. The mouse pointer changes to a "move" cursor when the mouse is over any placement region.
- 6. Hold the left mouse button while dragging the mouse to the desired new location for the placement region.
- 7. Release the left mouse button when the upper-left corner of the dragged region is at the desired location.
- 8. ACE calculates the enclosed subtile grid coordinates, growing as necessary to ensure all partially-enclosed subtiles (or Clock regions) are fully enclosed.
- 9. The Placement Region View table content is updated to show the new site counts enclosed by the Placement region, and the Floorplanner is updated to show the Placement region overlay at the new location (and with the latest dimensions).

# Assigning Placement Region Constraints

Placement region constraints may only be assigned to core and boundary instances (not I/O pads). Instances may be assigned placement region constraints interactively from the Tcl console, or from a PDC constraint file, with the add\_region\_insts (page 614) and add\_region\_find\_insts (page 613) Tcl commands, or interactively with drag-and-drop mouse actions in the ACE GUI.

When using the add\_region\_insts (page 614) or add\_region\_find\_insts (page 613) Tcl commands, the instances to constrain may be specified using an explicit list of instance names, or by clock domain name or critical path ID.

If specified as an explicit list of instance names the list may be formatted explicitly, or it may be the output of a find (page 638) Tcl command.

```
add_region_insts "region_1" {i:inst1 i:inst2}
add_region_insts "region_1" [find -insts inst*]
add_region_insts "region_1" [find -insts inst* -filter {@type=DFF && @clock_domain=clk1}
]
```

If specified by critical path ID, ACE determines which instances are part of that critical path, and assigns the placement region constraint to those Instances.

add\_region\_insts "region\_1" {c:sc\_s0}

Likewise, if specified by clock domain name, ACE determines which instances are part of that clock domain, and assigns the placement region constraint to all of those instances.

add\_region\_insts "region\_1" {k:clka}

When writing PDC constraint files, the recommended practice is to use the add\_region\_find\_insts (page 613) command instead of the add\_region\_insts (page 614) command. This is because:

When the instance list is specified with a find (page 638) command, or by critical path ID or clock domain name expression, the command/expression is evaluated and expanded into a list at the time at which the add\_region\_insts (page 614) command is evaluated (which happens at the beginning of the run\_prepare (page 698) flow step), not at the time at which it is applied with the apply\_placement (page 615) command (which happens at the end of the run\_prepare (page 698) flow step).

- 2. New instances which may be created during the run\_prepare (page 698) flow step, even if they would have matched the command/expression, are not included. Therefore, the add\_region\_insts (page 614) command is best reserved for interactive use.
- 3. The add\_region\_find\_insts (page 613) command, on the other hand, specifies the find (page 638) command as a string argument to be batched and evaluated later during the apply\_placement (page 615) command.

```
add_region_find_insts "region_1" "find -insts inst*"
add_region_find_insts "region_1" "find -insts inst* -filter {@type=DFF &&
@clock_domain=clk1}"
```

#### (i) Note

#### Saving Critical Path or Clock Domain Constraints

When critical paths or clock domains are used to specify the constraint, they are immediately expanded into a list of the corresponding instances within ACE at the time at which the

add\_region\_insts (page 614)

command is evaluated. If the placement region constraints are later exported from ACE (and saved into a pdc file), they are exported as explicit lists of instance names and the original association with a critical path or clock domain is lost. More concise constraints for user designs may be created by manually entering the placement region constraint in the PDC file using the clock domain name instead of the list of explicit instances.

If any instance which was previously assigned a placement region constraint is assigned a new placement region, the prior constraint is overridden and discarded.

Optionally, placement region constraints may be restricted to allow only flops, in which case all other instances are excluded. (Setting these inclusion/exclusion preferences for mouse actions is done on the **Placement Regions Preference page** (page 216).)

```
add_region_insts -flops_only "region_1" [find -insts * -filter {@clock_domain=clk1}]
add_region_find_insts -flops_only "region_1" "find -insts * -filter
{@clock_domain=clk1}"
```

When placement region constraints are assigned to instances interactively using drag-and-drop mouse actions in the ACE GUI, the mouse drag-assign actions can start from:

- the Search view, where individual Instances and/or Paths, groups of Instances and/or Paths, or all Instances and/or Paths in the search results (if the titled branch nodes themselves are dragged, even the Instances/Paths not in the current set of 200 on the visible page of results) may be drag-assigned.
- the Selection view, where individual Instances and/or Paths, groups of Instances and/or Paths, or all Instances and/or Paths in the selection set (if the titled branch nodes themselves are dragged, even the Instances/Paths not in the current set of 200 on the visible page of results) may be drag-assigned.
- the Critical Paths view, where individual Paths or groups of paths may be drag-assigned.
- the Clock Domains view, where clock domains may be drag-assigned to include all applicable Instances from that clock domain in the assignment.
- the Netlist Browser view, where any node of the tree may be dragged, and all child nodes are included.

Mouse drag-assign actions can end at:

- An individual Placement Region row in the table within the Placement Regions View. After the assignment of the dropped Core/Boundary Instances completes, the site utilization counts are updated.
- A visible Placement Region overlay in the Floorplanner view, if the Placement Region Tool is active in the Floorplanner. After the assignment of the dropped Core/Boundary Instances completes, the site utilization counts in the Placement Regions view for that region are updated.

(i) Note

#### **Overlapped Placement Regions**

If multiple placement regions overlap visibly in the Floorplanner view, any Instances dropped within the visibly overlapping area are ignored. In such cases, instances must either be dropped in the Placement Regions view, or dropped in the Floorplanner view where there is no visible overlap (Placement Region overlays may be disabled from the Placement Regions view to eliminate visible overlaps — in these cases, constraint assignment occurs to whichever placement region remains visible at the Floorplanner drop location).

# Listing all Objects Constrained to a Placement Region

The count of total sites of each type within each placement region is listed in the Placement Regions view (page 114), along with the count of each Instance type for the sites.

If there are more instances constrained to a region than there are sites for that region, the corresponding cell in the Placement Regions view table turns red to indicate the problem.

To view a list in the Tcl Console view (page 146) of all objects constrained to a placement region, do one of the following:

- Use the get\_region\_insts (page 660) Tcl command.
- Right-click the desired Placement region in the Placement Regions view and select **Print Instances**.

# Removing a Placement Region Constraint from an Object

Placement region constraints may be removed from individual core/boundary instances, or from all instances assigned to a region at once.

To un-assign a placement region constraint for individual core instances, use the **remove\_region\_insts** (page 677) Tcl command.

To remove all instance constraints from a placement region, use the same Tcl command, or in the **Placement Regions view** (page 114), right-click the desired placement region, and select **Clear Placement Region**.

# Saving Placement Region Definitions and Placement Region Constraints

Placement region constraints may be saved:

- From the Floorplanner view (page 45) with the "Save Pre-placement Constraints" action (which displays the Save Placement dialog (page 185))
- From the Placement Regions view (page 114) with the "Save Placement Regions" action (which displays the Save Placement Regions dialog (page 187))

• By using the save\_regions (page 709) Tcl command directly

### (i) Note

#### Important Consideration When Saving Placement Region Constraints

Only the final list of all individual instances being constrained is saved. The individual Tcl commands which built up the final list of constraints (including "find" commands, the extraction of instances from critical paths, or from clock domains) is lost. The saved PDC file may be edited to replace explicit lists of instances with find commands or clock domain names.

### **Deleting Placement Regions**

Unwanted Placement Regions may be deleted from the **Placement Regions view** (page 114) by right-clicking the region in the table and selecting **Remove Placement Region**.

Alternately, the remove\_region (page 677) Tcl command may be called directly.

# Running the HW Demo

The HW Demo facility is primarily intended as an aide to Achronix field application engineers (FAEs) that allows them to conveniently demonstrate particular features of Achronix FPGAs. Demonstration designs built into the ACE GUI software can easily be loaded into the attached board/device and executed. As the demonstration design is executing, the status of the design can be monitored in real-time, and visually represented within the HW Demo display.

The HW Demo facility uses fully functional designs (not included within an ACE installation, but provided as directory overlays) to demonstrate the real world application of hardened IP blocks. A given design may consist of a single IP block type, but typically they combine several IP block types working in a coordinated manner. These prebuilt designs are also useful to new ACE users as a way to gain experience setting up the Bitporter and prototyping environments.

## Installing HW Demo Designs

Each HW demo or reference design (including bitstreams, additional software, documentation, and source files when possible) is packaged into and delivered in a single tarball, ZIP, or Windows installer file, downloadable from the Achronix support site. A set of installation instructions is provided as a separate document (not here) as the details may vary for each design. Installation might require several steps, depending on the software tools and drivers needed.

There are expected to be two types of designs available. Reference designs are meant to be modified, while demo designs are black boxes. Reference designs typically are installed into the user home directory (to encourage editing), while demo designs may be installed into the <ace\_install> directory (which often has read-only permissions to discourage accidental overwrites). Both design types use the same framework within ACE, and both are presented through the HW Demo view in the ACE GUI.

Ask your FAE for further details about acquiring and installing the HW demo and reference designs for your specific development kit.

### HW Demo Installation Paths

By default, when ACE starts up, it searches for installed HW demos in the following paths:

- <userhome>/achronix/ref\_designs/
- <ace\_install>/ref\_designs/

After downloading a design tarball or zip, the design should be unpacked into either of those directories.

# Selecting The Target Device And Demo

At the top of the HW Demo view (page 60) are controls for selecting the target device and an associated demonstration design. After selecting a target device (or the default device matches the device you are working with) the list of available designs is accessible in the **Demo Design** control.

| <ul> <li>Demo Selection</li> </ul>                           | on and Download                                  |  |  |  |  |  |  |  |
|--------------------------------------------------------------|--------------------------------------------------|--|--|--|--|--|--|--|
| Select the demonstration design and download it to the chip. |                                                  |  |  |  |  |  |  |  |
| Target Device:                                               | AC22iHD1000ES0                                   |  |  |  |  |  |  |  |
| Demo Design:                                                 | Basic Fabric 1                                   |  |  |  |  |  |  |  |
| Download                                                     | Bitstream File: demo_bf1.jam Created: 2013/03/30 |  |  |  |  |  |  |  |

### Figure 174 • Demo Design Control Example

#### (i) Note

If no demos are installed, these controls remain disabled (which indicates the lack of installed designs).

### Loading The Demo JAM File

After selecting the target device and demonstration design, the name of the \*. j am file appears to the right of the **Download** button. Click the **Download** button to initiate loading of the the design into the attached FPGA device. Any designs that are running when **Download** is clicked are terminated without warning. If there are any errors or problems during the download process, a pop up dialog will be displayed with an explanatory message. When the selected design has been loaded and started, monitoring of the attached FPGA device is initiated using the DCC connection.



Figure 175 • Demonstration Design Download Example

# **Displaying Board Status**

After a design has been loaded and started running, ACE may monitor the status of the demonstration board LEDs and DIP switches, as well as key internal conditions such as core voltage, temperature, etc. Clicking the visualization of an LED in the HW Demo view causes the corresponding actual LED (on the demonstration board) to toggle state.

#### (i) Note

The visualized DIP switches are only used for reporting the state of the corresponding actual switch on the demonstrations board. The physical DIP switch cannot be set by clicking its image in ACE.

|       | a dem<br>DIP sv |       |   | _ |   |   |   | section will display                      | y the status of the boa  |
|-------|-----------------|-------|---|---|---|---|---|-------------------------------------------|--------------------------|
| LED   | State           |       |   |   |   |   |   | Device State                              |                          |
| 0     | 1               | 2     | 3 | 4 | 5 | 6 | 7 | Status:<br>Demo Version:<br>Core Voltage: | 0.0 V                    |
| DIP S | Switch          | State | 3 | 4 | 5 | 6 | - | Current:<br>Power:<br>Temperature:        | 0.0 mA<br>0.0 W<br>0.0 C |



## Control of Running Demonstration Design

While the Snapshot Debugger has extensive facilities for collecting data samples from a running design, it does not currently provide any direct mechanisms for controlling or interacting with a design. The HW Demo view (page 60) may provide a simple set of on-screen controls for reading and writing register values in some demo designs. In a demo similar to the example shown below, to read a register value, enter its address and click the **Read** button. The current value of the specified register appears in the **Data:** field to the right. Likewise, to modify a register value, enter its address and new value in the provided fields, and click the **Write** button.

| Register Access       Data:         Read       Address:       10000000         Write       Address:       0 | switches, and LED states. It she | <b>mo Basic Fabric 1</b><br>es the SnapShot debugger hooked up to a running co<br>ws the state of the DIP Switches and LEDs on the boar<br>Iso allows single-address register reads and writes. |  |
|-------------------------------------------------------------------------------------------------------------|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                                                                                             | Register Access                  |                                                                                                                                                                                                 |  |
| Write Address: 0 Data: 0                                                                                    | Read Address: 10000000           | Data:                                                                                                                                                                                           |  |
|                                                                                                             | Write Address: 0                 | Data: 0                                                                                                                                                                                         |  |

Figure 177 • HW Demo View Example

# Using Incremental Compilation (Partitions)

This section begins with a high-level overview, and then continues with detailed tutorials.

## **Overview of Incremental Compilation and Partitions**

Upstream synthesis tools have the ability to break a design up into smaller logical units (see: *Synplify Pro for Achronix User Guide*, Chapter 11: Working with Compile Points). Within ACE these smaller logical units are called "Partitions". These partitions can each be thought of as a nearly independent block — each partition can potentially be synthesized, optimized, placed, and routed independently. Because of this independence, when only one partition changes, only that partition needs to be re-run through the flow, leading to a significant runtime savings.

### **Defining Partitions**

It is expected that partitions are defined primarily by the upstream synthesis tool. The synthesis tool typically exports a partition definition/constraint file. For example, the file below is an example of a \*.prt file exported by Synplify Pro for Achronix.

### Example partition definition (\*.prt) file

```
set_partition_info -name "/fpu_top" -view "fpu_top" -timestamp "1476335212" -cp_type
"hard"
set_partition_info -name "/fpu_top/fpu_inst[0].i_fpu/fpu_out/fpu_out_ctl" -view
"fpu_out_ctl" -timestamp "1476335212" -cp_type "locked"
set_partition_info -name "/fpu_top/fpu_inst[0].i_fpu/fpu_out" -view "fpu_out" -timestamp
"1476335212" -cp_type "locked"
set_partition_info -name "/fpu_top/fpu_inst[0].i_fpu/fpu_div/fpu_div_ctl" -view
"fpu_div_ctl" -timestamp "1476335212" -cp_type "locked"
set_partition_info -name "/fpu_top/fpu_inst[0].i_fpu/fpu_div" -view "fpu_div" -timestamp
"1476335212" -cp_type "locked"
set_partition_info -name "/fpu_top/fpu_inst[0].i_fpu/fpu_mul/fpu_mul_exp_dp" -view
"fpu_mul_exp_dp" -timestamp "1476335212" -cp_type "locked"
set_partition_info -name "/fpu_top/fpu_inst[0].i_fpu/fpu_mul/fpu_mul_ctl" -view
"fpu_mul_ctl" -timestamp "1476337611" -cp_type "locked"
set_partition_info -name "/fpu_top/fpu_inst[0].i_fpu/fpu_mul" -view "fpu_mul" -timestamp
"1476337611" -cp_type "locked"
set_partition_info -name "/fpu_top/fpu_inst[0].i_fpu/fpu_in/fpu_in_ctl" -view
"fpu_in_ctl" -timestamp "1476335212" -cp_type "locked"
set_partition_info -name "/fpu_top/fpu_inst[0].i_fpu/fpu_in" -view "fpu_in" -timestamp
"1476335212" -cp_type "locked"
```

### **Enabling Incremental Compilation**

Enabling incremental compilation support within ACE is quite easy, assuming the partitions are already defined through the upstream synthesis tool:

- In the Projects view (page 120), add the partition definition file(s) to the ACE project (see Adding Source Files (page 296)). The new partition definition file appears in the Projects view as a Constraints file and, in the Options view (page 100), in the Design Preparation section in the list of Constraints Files (and should already have its checkbox selected).
- 2. In the **Options View** (page 100), within the **Design Preparation** section, select the checkbox labeled **Enable Incremental Compile**.
- 3. In the Projects View, save the current project (page 293).

From this point forward, this Project/Implementation uses incremental compilation when running the flow.

#### (i) Note

The presence of the partition definition constraint file in the project, plus the checked **Enable Incremental Compile** implementation option, are the only configuration changes that distinguish the incremental compile flow from the standard non-incremental flow.

### **Tracking Partition Status**

ACE provides two main tools for checking the compilation state, timestamps, and other statistics of each partition.

### **Partitions Report**

The Partitions report (page 246), automatically generated (and opened in the GUI) during the **Run Prepare flow** step (page 235), shows the current status of each of the partitions, including resource counts and re-compilation states.

### **Partitions View**

Similar to the Partitions report, the Partitions view (page 111) shows the status of each partition and a variety of other statistics. Additionally, the view allows for ease of visualization of the partitions and their relationships to the instances and each other.

### Forcing an Unchanged Partition to Recompile

When using the Partitions view, ACE provides a mechanism to override the partition timestamp during the next pass through the flow (page 235). The column named **Force Re-compile on Next Run** displays the status of this override mechanism.

To mark a partition as needing forced compilation:

- 1. Click the partition in the Partitions view.
- 2. Right-click anywhere in the partition row to open the context menu, and choose Force Partition Changed.

A check mark appears in the **Force Re-compile on Next Run** column of the view in the row containing the partition. The next time the flow is executed, the partition is re-placed and re-routed, even if there were no RTL changes and it was not re-compiled in the upstream synthesis tool.

To remove the mark for forced recompilation:

- 1. Click the partition in the Partitions View.
- 2. Right-click anywhere in the partition row to open the context menu, and choose Un-Force Partition Changed.

The check mark disappears in the **Force Re-compile on Next Run** column of the view in the row containing the partition. The next time the Flow is executed, the partition is only re-placed and re-routed if the partition was re-compiled in the upstream synthesis tool.

#### (i) Note

The ACE forced recompilation flag is a one-time trigger. When compilation is completed, any force flags for that implementation are cleared.

#### 🕑 Tip

#### Forcing all Partitions to Re-compile

The easiest way to force all partitions to immediately be recompiled (run through the entire flow) is:

• Enter the following Tcl command in the Tcl Console view (page 146):

run -ic init

#### • Alternately:

- a. Change to the Projects Perspective.
- b. In the Flow view (page 55), enable and disable the optional Flow steps (page 235) as desired.
- c. Right-click any flow step, and select the context menu item Re-Run Flow with "-ic init".

See Running the Entire Flow (page 305) for additional details.

### **Viewing Instances In Partitions**

There are multiple ways to quickly see which instances belong to a given partition:

- The Search view (page 133) and the find (page 638) Tcl command can both be used to list all the instances within a partition or list of partitions, using the @partition filter. The Search Filter Builder dialog (page 189) might ease the building of the filter for the Search view.
- Adding all the instances within a partition to the ACE Selection set (using the Selection view (page 137), especially when populated with search results) is an easy way to see where members of a partition are within the Floorplanner view (page 45). When the Floorplanner layer for Selected Instance Flylines is enabled, the connectivity of the selected partition is also visible.
- The Netlist Browser view (page 81) is a table of the instances (and enclosing macros) making up the design, with a column indicating the partition for each instance. This table can be filtered by column values, thus the table can be filtered to include only the instances within a given partition.
- Using highlight colors assigned from any of the above views (especially using the Partitions view **Auto-Highlight** functionality) can make it easy to see how members of various partitions are placed in relation to each other in the Floorplanner.

The Floorplanner view also includes a new color in the **Instance states** (page 262) for the new "Locked" state relating to partitions. Instances that are locked are a member of a locked partition that has remained unchanged since the prior incremental compilation. ACE does not change the site assignment for that instance during the Placement phase of place-and-route.

10.1

### **Related Tcl Commands**

The following Tcl commands were created specifically to interact with partitions:

- get\_partition\_changed (page 652)
- get\_partition\_force\_changed (page 652)
- get\_partition\_info (page 652)
- get\_partition\_insts (page 653)
- get\_partition\_timestamp (page 653)
- get\_partition\_type (page 653)
- is\_incremental\_compile (page 667)
- report\_partitions (page 681)
- set\_partition\_force\_changed (page 712)
- set\_partition\_info (page 713)

Additionally, the following Tcl commands were enhanced with additional options specific to incremental compilation and/or partitions:

- run (page 690)
- filter (page 637)
- find (page 638)

### Incremental Compile Tutorial

### Overview

This tutorial demonstrates the process of running incremental design compile within ACE. This tutorial consists of two parts:

- Single-Process Incremental Compile Tutorial (page 408) covers how to process a single-pass incremental compile. This first tutorial must be run before the Multiprocess Incremental Compile tutorial
- Multiprocess Incremental Compile Tutorial (page 443) details how to run a set of changes in order to select an optimal implementation. This second tutorial expands upon concepts from the first and cannot be run standalone.

### **Tutorial Files**

#### (i) Note

The files needed for this tutorial are no longer available due to the their use of obsolete components. Despite this fact, the procedure outlined in the tutorial remains valid and is presented here to provide a detailed overview of the incremental compile procedure.

This is an advanced tutorial. It assumes that both Synplify Pro and ACE are installed in your system search path and that you are already familiar with the use of both tools. If that is not the case, start with an introductory tutorial for those tools.

# Single-Process Incremental Compile Tutorial

The goal of this tutorial is to illustrate the incremental compile flow from an initial version of RTL, through the following steps:

- 1. Synthesis in Synplify Pro.
- 2. ACE place and route.
- 3. A modification of the original RTL.
- 4. Back through the flow.

The goal of the flow is to help minimize the time it takes to make incremental changes to existing RTL and get those changes through ACE with the minimum amount of time and perturbation to the existing design implementation in ACE.



Figure 178 • Incremental Compile Flow Chart

### (i) Note

#### Legend

• = Step that is integral to the running of this tutorial.

Items that should be checked at this point in the tutorial to gain insight in to how the flow works and the feedback the tools are providing.

**Bold Text** = Text that can be found as a label to some GUI component including report table headings.

### Step 1: Obtaining the Files

The tutorial reference design ZIP file is no longer available. Please refer to the following tutorials for procedural details using your own design files.

| Directory |              | Description                                          |
|-----------|--------------|------------------------------------------------------|
|           | root>        | Root directory of ZIP file.                          |
|           | /ace         | ACE generated project, report and log files (empty). |
|           | /constraints | SDC, PDC and FDC constraint files.                   |
|           | /rtl         | Synplify Pro RTL project files.                      |
|           | /rtl_V1      | Synplify Pro RTL project files.                      |
|           | /rtl_V2      | Synplify Pro RTL project files.                      |
|           | /rtl_V3      | Synplify Pro RTL project files.                      |
|           | /rtl V4      | Synplify Pro RTL project files.                      |
|           | /syn         | Synplify project, log and output files (empty).      |

### Figure 179 • Tutorial Directory Structure

### Step 2: Set up the Synthesis Project

• Start the Synplify Pro GUI. For Linux:

```
% cd <your work area>/Speedcore_Incremental_Compile_RefDesign_RD012/synplify
% synplify_pro
```

For windows, double-click the Synplify Pro Icon.

• Create a new project with () Open Project  $\rightarrow$  New Project (or File  $\rightarrow$  New Project in Windows). Windows users need to ensure that the project is saved to the chosen work area (File  $\rightarrow$  Save As). To follow the directory structure used in this tutorial, use  $\langle your_work_area \rangle$ /Speedcore\_Incremental\_Compile\_RefDesign\_RD012/ synplify. The Synplify Pro home screen appears with an empty project named proj\_1 and an implementation named rev\_1, as in the following screen shot:

|                                                        | /Achronix/Speedcore_Incremental_Compile_RefDesign_RD012/synplify/proj_1.prj]                                    | -                             |                         |             |                |              |           |        |           | ⊐ ×       |
|--------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|-------------------------------|-------------------------|-------------|----------------|--------------|-----------|--------|-----------|-----------|
|                                                        | Run Analysis HDL-Analysi Options Window Web Help                                                                |                               |                         |             |                |              |           |        |           | _#×       |
| . 🖸 🗷 💷 🙆 🖉 🖉 🥢 🗌                                      | 〕 10 40 60 ₩ 60 ₩ 101 10 10 10 10 10 10 10 10 10 10 10 10                                                       |                               |                         |             |                |              |           |        |           |           |
| ◎Run                                                   | Synplify Pro®                                                                                                   |                               |                         |             |                |              |           |        |           |           |
|                                                        | Ready                                                                                                           |                               |                         |             |                |              |           |        | Search S  | SolvNet   |
| Copen Project                                          | Project Files Design Hierarchy proj_1 : rev_1 - Achronix Speedster16: - AC16t5C01HI01C : CORE : C1              | Project Status In             | mplementation Directory | Process Vie | w              |              |           |        |           |           |
| Close Project                                          | 😑 🧶 [proj 1] - C:\Achronix\Speedcore Incremental Compile RefDesian RD012\synplify\proj 1.pri                    | Θ                             |                         |             | F              | roject Setti | ings      |        |           |           |
| Add File                                               | tal rev_1                                                                                                       | Project Name                  |                         |             | Implemen       | ation Name   |           |        |           |           |
| Ba Change File                                         |                                                                                                                 | 0                             |                         |             |                | Run Statu    | 15        |        |           |           |
| Add Implementation                                     |                                                                                                                 | Job Name                      | Status                  | 0 🛝         | \rm \rm СРИ ТІ |              | Real Time | Memory | Date/Time |           |
| Manual Implementation Options                          |                                                                                                                 | Compile Input                 | out-of-date             |             |                |              |           |        |           |           |
| Add P&R Implementation                                 |                                                                                                                 | Pre-mapping<br>Map & Optimize | out-of-date             |             |                |              |           |        |           |           |
|                                                        |                                                                                                                 | iwap & Optimize               | ourondate               |             |                |              |           |        | 1         |           |
| Frequency (MHz):                                       |                                                                                                                 |                               |                         |             |                |              |           |        |           |           |
|                                                        |                                                                                                                 |                               |                         |             |                |              |           |        |           |           |
| Automatic Compile Point                                |                                                                                                                 |                               |                         |             |                |              |           |        |           |           |
| FSM Compiler                                           |                                                                                                                 |                               |                         |             |                |              |           |        |           |           |
| Resource Sharing 🗹<br>Pipelining 🗹                     |                                                                                                                 |                               |                         |             |                |              |           |        |           |           |
| Retiming V                                             |                                                                                                                 |                               |                         |             |                |              |           |        |           |           |
|                                                        |                                                                                                                 |                               |                         |             |                |              |           |        |           |           |
|                                                        |                                                                                                                 |                               |                         |             |                |              |           |        |           |           |
|                                                        |                                                                                                                 |                               |                         |             |                |              |           |        |           |           |
|                                                        |                                                                                                                 |                               |                         |             |                |              |           |        |           |           |
|                                                        |                                                                                                                 |                               |                         |             |                |              |           |        |           |           |
|                                                        |                                                                                                                 |                               |                         |             |                |              |           |        |           |           |
|                                                        |                                                                                                                 |                               |                         |             |                |              |           |        |           |           |
|                                                        |                                                                                                                 |                               |                         |             |                |              |           |        |           |           |
| Parel And                                              |                                                                                                                 |                               |                         |             |                |              |           |        |           |           |
| 🕑 proj_1.prj                                           |                                                                                                                 | which information             |                         |             |                |              |           |        |           | ····· 8 × |
|                                                        |                                                                                                                 | mormation                     |                         |             |                |              |           |        |           | •         |
|                                                        |                                                                                                                 |                               |                         |             |                |              |           |        |           |           |
| project -new C:/Synopsys/<br>C:\Synopsys\fpga_L-2016.0 | fpga_L=2016.03X-SP1-2/bin/proj_1.prj                                                                            |                               |                         |             |                |              |           |        |           |           |
| project -save proj_1 C:/A                              | <pre>ssassi (bin(proj_1.pr)<br/>chronix/Speedcore_Incremental_Compile_RefDesign_RD012/synplify/proj_1.prj</pre> |                               |                         |             |                |              |           |        |           | ÷         |
| 8                                                      |                                                                                                                 |                               |                         |             |                |              |           |        |           | -         |
| TCL Script Messages                                    |                                                                                                                 |                               |                         |             |                |              |           |        |           |           |
|                                                        |                                                                                                                 |                               |                         |             |                |              |           |        |           | < 10      |

### Figure 180 • Synplify Pro Home Screen

• Select **Project** → **Add Source File** to bring up the **Add Files to Project** dialog box. click the blue ( ▲ ) button to navigate up to the parent directory. In the "Files of type:" combo-box, select **All Files (\*)**. Then doubleclick constraints to navigate to that directory and click the **<-Add All** button to add all of the constraint files. Click the blue up-arrow to navigate up one level and add all of the Verilog files in the rtl directory; click **OK**.

|                            | ct Pager Bake systematic line on Pager res                                           | <u> </u>                             |
|----------------------------|--------------------------------------------------------------------------------------|--------------------------------------|
| ook in:                    | ] C:\Achronix\Speedcore_Iesign_RD012\constraints 🔽 🧿 🗿 📑 📰 🗏                         |                                      |
| Ny Comp                    | open_sparc_fpu_icf_demo.fdc open_sparc_fpu_icf_demo.sdc                              |                                      |
| ile name:<br>iles of type: | "open_sparc_fpu_icf_demo.sdc" "open_sparc_fpu_icf_demo.fdc"          All Files (*.*) |                                      |
| HDL/Verilog lib:           |                                                                                      |                                      |
| iles to add to pro         | ject: (2 file(s) selected)                                                           |                                      |
|                            | en_sparc_fpu_icf_demo.fdc<br>en_sparc_fpu_icf_demo.sdc                               | <- Add All<br><- Add<br>Remove All - |

Figure 181 • Add Files to Project Dialog Box

• All of the files just added are now listed under the proj\_1 project in the Project Files tab (click + to expand each file type).

• Ensure that the file  $fpu\_top.v$  (the top-level module) appears last in the list of Verilog files. If it does not, correct the order by using the mouse to select the file name and drag it to the end of the list. For Windows users, the Result Base Name is set to the project name used earlier, the default being Proj\_1. To have the file names match this document exactly, manually change the **Project**  $\rightarrow$  **Implementation Options**  $\rightarrow$  **Implementation Results**  $\rightarrow$  **Result Base Name** to "open\_sparc\_fpu\_icf\_demo", and click OK.

| Synplify Pro L-2016.03X-SP1-2 - [C://                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Achronix/Speedcore_Incremental_Compile_RefDesign_RD012/synplify/proj_1.prj *]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 200                                  | 8.08.r                   |                     |                | -              |                     |              | 2212        | _ 0 <mark>_ X</mark> |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--------------------------|---------------------|----------------|----------------|---------------------|--------------|-------------|----------------------|
| 🖻 🕅 File Edit View Project I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Run Analysis HDL-Analyst Options Window Web Help                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                      |                          |                     |                |                |                     |              |             | _8>                  |
| 🕑 🖸 🔲 🙆 🖬 🎒 🔦 🚺                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ) 10 aq                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                      |                          |                     |                |                |                     |              |             |                      |
| - <b>D</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Synplify Pro®                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                      |                          |                     |                |                |                     |              |             |                      |
| ©Run                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Ready                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                      |                          |                     |                |                |                     |              |             | Search SolvNet       |
| 没 Open Project                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Project Files Design Hierarchy                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Project Status                       | Implementa               | ation Direc         | ctory          | P              | rocess View         |              |             |                      |
| Close Project                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | proj_1 : rev_1 - Achronix Speedster16t : AC16tSC01HI01C : CORE : C1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | $\odot$                              |                          |                     |                | F              | Project Setting     | qs           |             |                      |
| Add File                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | fpu_div_frac_dp.v [work]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Project Name                         |                          |                     |                | Imple          | mentation Nan       | ne           |             |                      |
| 🗞 Change File                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | - 🙀 fpu_in.v [work]<br>🙀 fpu_in2_gt_in1_2b.v [work]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                      |                          |                     |                |                |                     |              |             |                      |
| Add Implementation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | $\Theta$                             | 0                        |                     |                |                | Run Status          | 0.171        |             | D ( 171              |
| Implementation Options                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | fpu_in2_gt_in1_frac.v [work]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Job Name<br>Compile Input            | Status<br>out-of-date    | 0                   |                |                | CPU Time            | Real Time    | Memory      | Date/Time            |
| BR Add P&R Implementation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 🖞 fpu_in_ctl.v [work]<br>🖞 fpu_in_dp.v [work]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Pre-mapping                          | out-of-date              |                     | +              | $\vdash$       |                     |              |             |                      |
| 📐 View Log                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | fpu_mul.v [work]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Map & Optimize                       | out-of-date              |                     |                |                |                     |              | -           |                      |
| Frequency (MH2):<br>200 2 2 440 Const.<br>Automatic Comple Point<br>Continue on Eror<br>FSM Compler<br>Resource Shaing<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V<br>Retiming<br>V | Si fpu_mul_cit v (work)     Si fpu_mul_sep_dv (work)     Si fpu_mul_sep_dv (work)     Si fpu_mul_sep_dv (work)     Si fpu_adt_cit v (work)     Si fpu_adt_cit v (work)     Si fpu_adt_cit v (work)     Si fpu_pdr_macros v (work)     Si fpu_pdr_m |                                      |                          |                     |                |                |                     |              |             |                      |
| proj_1.prj *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                      |                          |                     |                |                |                     |              |             |                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Infor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | rmation                              |                          |                     |                |                |                     |              |             |                      |
| <pre>set_option -result_file C:<br/>set_option -write_verilog</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | test_stub_scan.v<br>i1.v<br>hronix/Speedcore_Incremental_Compile_RefDesign_RD012/rtl,<br>:/Achronix/Speedcore_Incremental_Compile_RefDesign_RD012;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | /fpu_top.v" "C:,<br>/synplify/rev_1, | /Achronix/<br>/open_spar | Speedco<br>cc_fpu_i | ore_1<br>icf_c | Incre<br>iemo. | emental_Comp<br>.vm | pile_RefDesi | .gn_RD012/1 |                      |
| %                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                      |                          |                     |                |                |                     |              |             |                      |
| TCL Script Messages                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                      |                          |                     |                |                |                     |              |             |                      |

Figure 182 • Synplify Pro Home Screen After File Additions

• Depending on how Synplify Pro is installed, the locations of the Achronix macro libraries may need to be specified. Open the Implementation Options window and then click the Verilog tab (**Project**  $\rightarrow$  **Implementation Options**  $\rightarrow$  **Verilog**). Ensure that <*ACE install location*>/libraries is present in the Include Path Order box. If not, add them by clicking the green + and navigating to the <*ACE install location*>/libraries directory. Click **Choose**, then click **OK**.

| Device Options Constraints                                   | Implementation Results       | Timing Report Verilog | GCC Place and      | Implementations: |
|--------------------------------------------------------------|------------------------------|-----------------------|--------------------|------------------|
| Top Level Module:                                            | Compiler Directives and Pa   | rameters              |                    | rev_1            |
|                                                              | Parameter Name               |                       | Override Value     |                  |
| Verilog Language                                             | L                            |                       |                    |                  |
| System Verilog                                               |                              |                       |                    |                  |
| ✓ Push Tristates                                             | L                            |                       |                    |                  |
| Allow Duplicate Modules                                      |                              |                       | Extract Parameters |                  |
| Multiple File Compilation Unit     Beta Features for Verilog | Compiler Directives: e.g. S  | IZE=8                 |                    | ,                |
| Loop Limit 2000                                              |                              |                       |                    |                  |
| Include Path Order: (Relative to Pr                          | oject File)                  |                       | i o i              | I                |
| C:\Program Files\Achronix CAD Er                             | vironment\Achronix\libraries | l .                   |                    |                  |
| Library Directories or Files:                                | I                            |                       |                    |                  |
|                                                              |                              |                       |                    |                  |
| Library Extensions (space separate                           | d)                           |                       |                    |                  |
|                                                              |                              |                       |                    |                  |

### Figure 183 • Implementation Options Window

• Ensure that the Verilog file <*ACE install location*>/libraries/device\_models/16t\_synplify.v has been added to the project. If it has not, use the **Project**  $\rightarrow$  **Add Source File** dialog box again to add it. Then drag this file to the top of the Verilog files listed to ensure that it is the first one read in.

● Finally, select the Achronix technology and part name. Open the Implementation Options Device tab (**Project** → **Implementation Options** → **Device**) and select the **Technology:** and **Part:** name.

413

| echnology: Part                      |             |          |                  |          |      | rev 1 |
|--------------------------------------|-------------|----------|------------------|----------|------|-------|
| echnology. Fail.                     | F           | Package: | Sp               | eed:     |      |       |
| Achronix Speedster16t - AC16ts       | SC01HI01C 🔻 | CORE     | ▼ C <sup>2</sup> | 1        | -    |       |
| Device Mapping Options               |             |          |                  |          |      |       |
|                                      |             |          |                  | <u> </u> |      |       |
| Option                               |             |          |                  | Value    |      |       |
| Fanout Guide                         |             |          |                  | 10000    |      |       |
| Disable I/O Insertion                |             |          |                  | <        |      |       |
| Update Compile Point Timing Data     |             |          |                  |          |      |       |
| Automatic Read/Write Check Insertion | on for RAM  |          |                  |          |      |       |
| Time Borrowing                       |             |          |                  |          |      |       |
| Retime Registers Forward             |             |          |                  |          |      |       |
| Annotated Properties for Analyst     |             |          |                  | •        |      |       |
| Resolve Mixed Drivers                |             |          |                  |          |      |       |
|                                      |             |          |                  |          |      |       |
|                                      |             |          |                  |          |      |       |
| 1                                    |             |          |                  |          |      |       |
|                                      |             |          |                  |          | = 11 |       |
| Click on an option for description   |             |          |                  |          |      |       |
|                                      |             |          |                  |          |      |       |

Figure 184 • Implementation Option Device Tab

### Step 3: Compile the Design in Synplify Pro

• Select  $Run \rightarrow Compile Only$  (or click F7) to parse the Verilog and constraints files and enable viewing. If this is the first time the design was compiled and the project has not been saved yet, Synplify Pro may ask to save the project file. Click **Save** to continue.

In order to see the nine compile point constraints defined for this project, open the constraints/ open\_sparc\_fpu\_icf\_demo.fdc file as a text file by navigating to the **Project Files** tab, expand the **Logic Constraints (FDC)** section, and left-mouse click the open\_spacr\_fpu\_icf\_demo.fdc file, and **Open as Text**. All nine of them are of type locked, as in the example below:



Figure 185 · Contents of the

Each compile point becomes a partition in the ACE tool. If one or more RTL source files are later edited and changed, Synplify Pro and ACE only need to recompile the partitions that have changed, rather than the whole design.

Optionally; instead of adding the open\_sparc\_fpu\_icf\_demo.fdc file to define the compile points, constraints can also be created or edited using the SCOPE tool. To manually add a new constraint file, click the (ID) **New constraint file** button, and then click the **Compile Points** tab. To open the

existing open\_sparc\_fpu\_icf\_demo.fdc file in the SCOPE tool, double-click the file name in the **Project Files** tab, and then click the **Compile Points** tab. Then, to add a new Compile Point, select the first blank row in the table, double-click in the View field to bring up a drop-down list of available view names, and select the one desired. Then double-click in the Type field to set the compile-point type. ACE treats all compile points as locked for purposes of placement and routing, but soft or hard compile points can be used in synthesis if locked results in poor QoR.

| 5 S                                   | nplify Pro                           | o L-2016 | .03X-SP1-2 - [C:/A  | chronix/Speedcore | _Incremental_Co | mpile_RefDesig  | n_RD012/constrain | ts/open       | <b>x</b> |  |  |  |
|---------------------------------------|--------------------------------------|----------|---------------------|-------------------|-----------------|-----------------|-------------------|---------------|----------|--|--|--|
| 1                                     | File                                 | Edit \   | /iew Project R      | tun Analysis Hl   | DL-Analyst Op   | tions Window    | w Web Help        |               | _B×      |  |  |  |
| : 😰                                   | <b>\$</b> 🔲                          | 2        | 🗏 🎒 🔦 D             | n n 🕅             | 🏠 🕑 🕑 🛛         | ≣ \$\$ <b>\</b> | 🥹 <b>vcs</b> 💿 E  | <b>■</b>      |          |  |  |  |
| Cum                                   | Current Design: <top level=""></top> |          |                     |                   |                 |                 |                   |               |          |  |  |  |
|                                       | Enable                               |          | View                | Туре              |                 |                 | Comment           |               |          |  |  |  |
| 1                                     | ◄                                    | v:work.  | .fpu_mul            | locked            |                 |                 |                   |               |          |  |  |  |
| 2                                     | •                                    | v:work.  | .fpu_div            | locked            |                 |                 |                   |               |          |  |  |  |
| 3                                     | •                                    | v:work   | .fpu_in             | locked            |                 |                 |                   |               |          |  |  |  |
| 4                                     | ◄                                    | v:work   | .fpu_out            | locked            |                 |                 |                   |               |          |  |  |  |
| 5                                     | ◄                                    | v:work   | .fpu_mul_ctl        | locked            |                 |                 |                   |               |          |  |  |  |
| 6                                     | ◄                                    | v:work   | .fpu_mul_exp        | locked            |                 |                 |                   |               |          |  |  |  |
| 7                                     | •                                    | v:work.  | .fpu_div_ctl        | locked            |                 |                 |                   |               |          |  |  |  |
| 8                                     | •                                    | v:work   | .fpu_in_ctl         | locked            |                 |                 |                   |               |          |  |  |  |
| 9                                     | •                                    | v:work   | .fpu_out_ctl        | locked            |                 |                 |                   |               |          |  |  |  |
| 10                                    |                                      |          |                     |                   |                 |                 |                   |               | <b>•</b> |  |  |  |
| cks                                   | Colle                                | ctions   | Inputs/Outputs      | s Registers       | Delay Paths     | Attributes      | I/O Standards     | Compile Point | ts 🕩     |  |  |  |
| B                                     | proj_1.pr                            | j 🏼      | open_sparc_fpu      | _icf_demo.fdc     |                 |                 |                   |               |          |  |  |  |
|                                       |                                      |          |                     |                   |                 |                 |                   |               |          |  |  |  |
| <b>-</b>                              | 16110.51                             | 5        |                     |                   |                 |                 |                   |               |          |  |  |  |
| compiler Completed Return Code: 0     |                                      |          |                     |                   |                 |                 |                   |               |          |  |  |  |
| Rur                                   | n Time:                              | 00h:0    | 0m:06s              |                   |                 |                 |                   |               |          |  |  |  |
| 8                                     |                                      |          |                     |                   |                 |                 |                   |               | -        |  |  |  |
| · · · · · · · · · · · · · · · · · · · | L Script                             |          | sages               |                   |                 |                 |                   |               |          |  |  |  |
| SCO                                   | OPE - Loa                            | aded ne  | tlist file C:\Achro | nix\Speedcore_In  | cremental_Con   | npile_RefDesig  | gn_RD012\synplify | y\rev_1       |          |  |  |  |

Figure 186 • Compile Points Tab Within the Synplify Pro SCOPE View

Close the SCOPE View window and do not save any changes.

#### (i) Note

Synplify-Pro can be configured to create the compile points automatically. To experiment with this option, open the Implementation Options window, select the Options tab, and check the **Auto Compile Point** option. This option uses various heuristics (such as the sizes of the modules, the number of pins and the presence of timing constraints) to select a set of module views as compile points. These may be in addition to any compile points manually specified as constraints.

For this tutorial, ensure that the **Auto Compile Point** option is un-checked, then click **OK** to close the Implementation Options window.

• Lastly, click **Run** to complete the mapping of the design.

For more information see Chapter 11, "Working with Compile Points" in the document Synopsys FPGA Synthesis Synplify Pro for Achronix User Guide, located in the Synplify Pro installation directory under /doc.

#### A Caution!

Windows users may encounter an error with m\_generic.exe while using compile points. This condition is caused by an issue with parallel synthesis jobs in the current version of Synplify Pro for Achronix. This situation is being addressed by Synopsys and is expected to be rectified in an upcoming release. If Synplify encounters this error, select **Options**  $\rightarrow$  **Configure Compile Point Process**, change the "4" in the box to "1" as shown below.

| S Configure Compile Point Process                                |                   |
|------------------------------------------------------------------|-------------------|
| Maximum number of parallel synthesis jobs:                       | 1                 |
| Continue on Error<br>Copy Previous Compile-Point Netlists to New | v Implementations |
| View the application note about Multiprocessing                  | OK Cancel         |

Figure 187 • Configure Compile Point Process Dialog Box

### Step 4: Review Synplify Results

This step reviews some of the files and features available to better understand the behavior of Synplify Pro with compile-point constraints.

### Synplify-Pro Log File

✓ Using either the Synplify Pro GUI or another text editor, open the Synplify Pro log file Speedcore\_Incremental\_Compile\_RefDesign\_RD012/synplify/rev\_1/ open\_sparc\_fpu\_icf\_demo.srr and search for the section titled "Summary of Compile Points".

| 1113       Summary of Compile Points :         1113       Summary of Compile Points :         1114       Mame       Status       Reason       Start Time       End Time         1115       Name       Status       Reason       Start Time       End Time         1116       fpu_in_fpu_in       Mapped       No database       Wed Dec 20       13:05:12       2017       Wed Dec 20       13:05:25       2017         1116       fpu_in_ctl       Mapped       No database       Wed Dec 20       13:05:27       2017       Wed Dec 20       13:05:26       2017         112       fpu_int_ctl       Mapped       No database       Wed Dec 20       13:05:36       2017       Wed Dec 20       13:05:26       2017         112       fpu_div_tl       Mapped       No database       Wed Dec 20       13:05:36       2017       Wed Dec 20       13:05:26       2017         112       fpu_div_ctl       Mapped       No database       Wed Dec 20       13:05:26       2017       Wed Dec 20       13:06:20       2017       Wed Dec 20       13:06:20       2017       Wed Dec 20       13:06:23       2017       Wed Dec 20       13:06:32       2017       Wed Dec 20       13:06:35       2017       Wed Dec 20 </th <th></th> <th>Multiprocessing finished at : Wed</th> <th></th> <th></th> <th></th> <th></th>                                                                                                                                                                                                              |    | Multiprocessing finished at : Wed  |             |                    |                          |                          |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|------------------------------------|-------------|--------------------|--------------------------|--------------------------|
| Summary of Com       Spile Points :         Summary of Com       Status       Reason       Statu Time       End Time         Name       Status       Reason       Statu Time       End Time         Top_in_fpu_in_fu       Mapped       No database       Wed Dec 20 13:05:19 2017       Wed Dec 20 13:05:20 2017       Wed Dec 20 13:05:36 2017       Wed Dec 20 13:05:20 |    | Multiprocessing cook on.obm.528 10 | satchne, on | . 12m. 508 cpucime |                          |                          |
| 14       ************************************                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |    | Summary of Combile Points :        |             |                    |                          |                          |
| 16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 14 |                                    |             |                    |                          |                          |
| 17       fpu_in_fpu_in       Mapped       No database       Wed Dec 20       13:05:19       2017       Wed Dec 20       13:05:19       2017         18       fpu_in_ctl       Mapped       No database       Wed Dec 20       13:05:20       2017       Wed Dec 20       13:05:20       2017         19       fpu_mul_exp_dp       Mapped       No database       Wed Dec 20       13:05:27       2017       Wed Dec 20       13:05:27       2017       Wed Dec 20       13:05:27       2017       Wed Dec 20       13:05:32       2017         20       fpu_div_fpu_div       Mapped       No database       Wed Dec 20       13:05:27       2017       Wed Dec 20       13:05:35       2017         21       fpu_div_ctl       Mapped       No database       Wed Dec 20       13:05:43       2017       Wed Dec 20       13:05:23       2017         21       fpu_div_ctl       Mapped       No database       Wed Dec 20       13:05:42       2017       Wed Dec 20       13:05:23       2017         21       fpu_uit_fpu_out       Mapped       No database       Wed Dec 20       13:05:43       2017       Wed Dec 20       13:06:32       2017         21       fpu_uit_fpu_mul_exp_dp       Mapped       No database <th>15</th> <th>Name</th> <th>Status</th> <th>Reason</th> <th>Start Time</th> <th>End Time</th>                                                                                                                                                                                                         | 15 | Name                               | Status      | Reason             | Start Time               | End Time                 |
| 18       fpu_in_ctl       Mapped       No database       Wed Dec 20       13:05:20       2017       Wed Dec 20       13:05:20       2017         19       fpu_mul_exp_dp_fpu_mul_exp_dp       Mapped       No database       Wed Dec 20       13:05:20       2017       Wed Dec 20       13:05:36       2017       Wed Dec 20       13:05:36       2017       Wed Dec 20       13:05:36       2017       Wed Dec 20       13:06:32       2017         21       fpu_out_fpu_out       Mapped       No database       Wed Dec 20       13:05:58       2017       Wed Dec 20       13:06:32       2017         25       fpu_out_fpu_out       Mapped       No database       Wed Dec 20       13:05:58       2017       Wed Dec 20       13:06:32       2017         26       fpu_mul_exp_dp_fpu_mul_exp_dp       Mapped       No database       Wed Dec 20       13:06:05       2017       Wed Dec 20       13:06:32       2017       Wed Dec 20                                                                                                                                                                                                                                                                            |    | fou in fou in                      | Manned      | No database        | Wed Dec 20 13:05:19 2017 | Wed Dec 20 13:05:25 2017 |
| 19       fpu_mul_exp_dp_fpu_mul_exp_dp       Mapped       No database       Wed Dec 20       13:05:27       2017       Wed Dec 20       13:05:27       2017         20       fpu_mul_ctl       Mapped       No database       Wed Dec 20       13:05:27       2017       Wed Dec 20       13:05:27       2017       Wed Dec 20       13:05:27       2017       Wed Dec 20       13:05:62       2017         21       fpu_div_fpu_div       Mapped       No database       Wed Dec 20       13:05:23       2017       Wed Dec 20       13:05:32       2017       Wed Dec 20       13:05:32       2017       Wed Dec 20       13:05:32       2017         21       fpu_out_fpu_out       Mapped       No database       Wed Dec 20       13:05:20       2017       Wed Dec 20       13:06:23       2017         25       fpu_in.fpu_fin_0       Mapped       No database       Wed Dec 20       13:06:21       2017       Wed Dec 20       13:06:22       2017         26       fpu_mul_exp_dp_fpu_mul_exp_dp_0       Mapped       No database       Wed Dec 20       13:06:52       2017       Wed Dec 20       13:06:52       2017         27       fpu_div_fpu_div_0       Mapped       No database       Wed Dec 20       13:06:52       2017                                                                                                                                                                                                                                                                                        |    |                                    |             |                    |                          |                          |
| 20       fpu_nul_ctl       Mapped       No database       Wed Dec 20       13:05:27       2017       Wed Dec 20       13:05:43       2017       Wed Dec 20       13:05:36       2017       Wed Dec 20       13:05:20       2017       Wed Dec 20       13:05:20       2017       Wed Dec 20       13:05:20       2017       Wed Dec 20       13:06:21       2017       Wed Dec 20       13:06:22       2017         26       fpu_in_fpu_in_0       Mapped       No database       Wed Dec 20       13:06:21       2017       Wed Dec 20       13:06:32       2017         27       fpu_uin_fpu_in_0       Mapped       No database       Wed Dec 20       13:06:21       2017       Wed Dec 20       13:06:32       2017         27       fpu_uit_fpu_div_0       Mapped       No database       Wed Dec 20       13:06:21       2017       Wed Dec 20       13:06:35       2017         27       fpu_uit_fpu_div_0       Mapped       No database       Wed Dec 20       13:06:35       2017       Wed Dec 20       13:06:35 <t< td=""><td></td><td></td><td></td><td></td><td></td><td></td></t<>                                                                                                                                                                                                             |    |                                    |             |                    |                          |                          |
| 21       fpu_div_fpu_div       Mapped       No database       Wed Dec 20       13:05:36       2017       Wed Dec 20       13:05:36       2017         22       fpu_div_ctl       Mapped       No database       Wed Dec 20       13:05:36       2017       Wed Dec 20       13:05:36       2017         21       fpu_out_fpu_out       Mapped       No database       Wed Dec 20       13:05:36       2017       Wed Dec 20       13:05:20       2017       Wed Dec 20       13:06:22       2017         25       fpu_in_fpu_in_0       Mapped       No database       Wed Dec 20       13:06:21       2017       Wed Dec 20       13:06:32       2017         26       fpu_out_ctl       Mapped       No database       Wed Dec 20       13:06:52       2017       Wed Dec 20       13:06:52       2017 <td></td> <td></td> <td></td> <td></td> <td></td> <td>Wed Dec 20 13:05:42 2017</td>                                                                                                                                                                                             |    |                                    |             |                    |                          | Wed Dec 20 13:05:42 2017 |
| 22       fpu_div_ctl       Mapped       No database       Wed Dec 20 13:05:43 2017       Wed Dec 20 13:05:63 2017         23       fpu_out_fpu_out       Mapped       No database       Wed Dec 20 13:05:53 2017       Wed Dec 20 13:05:20 2017         24       fpu_nut_fpu_mul       Mapped       No database       Wed Dec 20 13:05:50 2017       Wed Dec 20 13:06:22 2017         25       fpu_nt_fpu_in_0       Mapped       No database       Wed Dec 20 13:06:21 2017       Wed Dec 20 13:06:22 2017         26       fpu_nt_fpu_in_0       Mapped       No database       Wed Dec 20 13:06:21 2017       Wed Dec 20 13:06:32 2017         26       fpu_nut_exp_dp_fpu_mul_exp_dp_0       Mapped       No database       Wed Dec 20 13:06:05 2017       Wed Dec 20 13:06:65 2017         27       fpu_out_ctl       Mapped       No database       Wed Dec 20 13:06:05 2017       Wed Dec 20 13:06:05 2017         27       fpu_out_fpu_out_0       Mapped       No database       Wed Dec 20 13:06:05 2017       Wed Dec 20 13:07:02 2017         27       fpu_out_fpu_out_0       Mapped       No database       Wed Dec 20 13:07:05 2017       Wed Dec 20 13:07:02 2017         37       fpu_nul_fpu_mul_exp_dp_1       Mapped       No database       Wed Dec 20 13:07:05 2017       Wed Dec 20 13:07:01 2017         37       fpu_ou                                                                                                                                                                                       |    |                                    |             |                    |                          |                          |
| 23       fpu_out_fpu_out       Mapped       No database       Wed Dec 20       13:05:58       2017       Wed Dec 20       13:05:52       2017         26       fpu_in_fpu_div_0       Mapped       No database       Wed Dec 20       13:05:52       2017       Wed Dec 20       13:06:52       2017         27       fpu_div_fu_div_0       Mapped       No database       Wed Dec 20       13:06:52       2017       Wed Dec 20       13:06:52       2017         27       fpu_div_fu_div_0       Mapped       No database       Wed Dec 20       13:06:52       2017       Wed Dec 20       13:07:12       2017         27       fpu_ui_fpu_ui_fpu_mi_gu_div_fnu       Mapped <td></td> <td></td> <td></td> <td></td> <td></td> <td>Wed Dec 20 13:06:03 2017</td>                                                                                                                                                                                    |    |                                    |             |                    |                          | Wed Dec 20 13:06:03 2017 |
| 24       fpu_mul_fpu_mul       Mapped       No database       Wed Dec 20       13:06:22       2017       Wed Dec 20       13:06:23       2017         25       fpu_in_fpu_in_0       Mapped       No database       Wed Dec 20       13:06:21       2017       Wed Dec 20       13:06:23       2017         26       fpu_in_fpu_in_0       Mapped       No database       Wed Dec 20       13:06:27       2017       Wed Dec 20       13:06:32       2017         26       fpu_out_ctl       Mapped       No database       Wed Dec 20       13:06:52       2017       Wed Dec 20       13:06:32       2017         27       fpu_out_ctl       Mapped       No database       Wed Dec 20       13:06:55       2017       Wed Dec 20       13:06:52       2017         26       fpu_in_fpu_in_1       Mapped       No database       Wed Dec 20       13:06:55       2017       Wed Dec 20       13:06:52       2017         27       fpu_out_fpu_out_0       Mapped       No database       Wed Dec 20       13:06:52       2017       Wed Dec 20       13:07:02       2017         26       fpu_nul_exp_dp_fpu_mul_exp_dp_1       Mapped       No database       Wed Dec 20       13:07:02       2017       Wed Dec 20       13:07:02 <td></td> <td></td> <td></td> <td>No database</td> <td>Wed Dec 20 13:05:58 2017</td> <td>Wed Dec 20 13:06:20 2017</td>                                                                                                                                                                          |    |                                    |             | No database        | Wed Dec 20 13:05:58 2017 | Wed Dec 20 13:06:20 2017 |
| 25       fpu_in.fpu_in_fpu_in_0       Mapped       No database       Wed Dec 20       13:06:22       2017       Wed Dec 20       13:06:22       2017         26       fpu_unul_exp_dp_fpu_unul_exp_dp_0       Mapped       No database       Wed Dec 20       13:06:27       2017       Wed Dec 20       13:06:35       2017       Wed Dec 20       13:06:57       2017       Wed Dec 20       13:07:02       2017         37       fpu_unul_fpu_unul_exp_dp_1       Mapped       No database       Wed Dec 20       13:07:05       2017       Wed Dec 20       13:07:02       2017         37       fpu_uit_fpu_uit_g0       Mapped       No database       Wed Dec 20       13:07:05       2017       Wed Dec 20       13:07:02       2017         36       fpu_uit_fpu_uit_g0       Mapped       No database       Wed Dec 20       13:07:02       2017       Wed Dec 20       13:07:017       2017       Wed De                                                                                                                                                                                                                                                            |    |                                    | Mapped      | No database        | Wed Dec 20 13:05:20 2017 | Wed Dec 20 13:06:23 2017 |
| 26       fpu_nul_exp_dp_dp_unul_exp_dp_0       Mapped       No database       Wed Dec 20       13:06:27       2017       Wed Dec 20       13:06:32       2017       Wed Dec 20       13:06:35       2017       Wed Dec 20       13:07:32       2017       10:13                                                                                                                                                                                                                                           | 25 | fpu in fpu in 0                    |             | No database        | Wed Dec 20 13:06:21 2017 | Wed Dec 20 13:06:25 2017 |
| 28       fpu_div_fpu div_0       Mapped       No database       Wed Dec 20       13:06:35       2017       Wed Dec 20       13:06:55       2017         29       fpu_in_fpu_in_fu       Mapped       No database       Wed Dec 20       13:06:35       2017       Wed Dec 20       13:06:55       2017         29       fpu_in_fpu_in_fu       Mapped       No database       Wed Dec 20       13:06:57       2017       Wed Dec 20       13:07:04       2017       Wed Dec 20       13:07:05       2017       Wed Dec 20       13:07:07:01       2017       Wed Dec 20       13:07:07:01 <t< td=""><td>26</td><td>fpu mul exp dp fpu mul exp dp 0</td><td></td><td>No database</td><td>Wed Dec 20 13:06:27 2017</td><td>Wed Dec 20 13:06:34 2017</td></t<>                                                                                        | 26 | fpu mul exp dp fpu mul exp dp 0    |             | No database        | Wed Dec 20 13:06:27 2017 | Wed Dec 20 13:06:34 2017 |
| 29         fpu_in_fpu_n1_         Mapped         No database         Wed Dec 20         13:06:57         2017         Wed Dec 20         13:07:02         2017           30         fpu_out_fpu_out_0         Mapped         No database         Wed Dec 20         13:06:57         2017         Wed Dec 20         13:07:02         2017           30         fpu_out_fpu_out_0         Mapped         No database         Wed Dec 20         13:06:57         2017         Wed Dec 20         13:07:02         2017           31         fpu_mul_fpu_mul_0         Mapped         No database         Wed Dec 20         13:06:25         2017         Wed Dec 20         13:07:02         2017           31         fpu_in_fpu_in_0         Mapped         No database         Wed Dec 20         13:07:012         2017         Wed Dec 20         13:07:012         2017           31         fpu_in_fpu_in_2         Mapped         No database         Wed Dec 20         13:07:012         2017         Wed Dec 20         13:07:012         2017           35         fpu_out_fpu_out_1         Mapped         No database         Wed Dec 20         13:07:012         2017         Wed Dec 20         13:07:012         2017           36         fpu_out_fpu_out_1         Mapped                                                                                                                                                                                                                                         | 27 | fpu out ctl                        | Mapped      | No database        | Wed Dec 20 13:06:05 2017 | Wed Dec 20 13:06:43 2017 |
| 30       fpu_out_fpu_out_0       Mapped       No database       Wed Dec 20       13:06:44       2017       Wed Dec 20       13:07:16:42       2017         31       fpu_mul_exp_dp_fpu_mul_exp_dp_1       Mapped       No database       Wed Dec 20       13:07:05       2017       Wed Dec 20       13:07:12       2017         31       fpu_div_fpu_div_1       Mapped       No database       Wed Dec 20       13:07:05       2017       Wed Dec 20       13:07:12       2017         33       fpu_div_fpu_div_1       Mapped       No database       Wed Dec 20       13:07:13       2017       Wed Dec 20       13:07:13       2017         34       fpu_in_fpu_in_2       Mapped       No database       Wed Dec 20       13:07:32       2017       Wed Dec 20       13:07:52       2017         35       fpu_unul_exp_dp_fpu_mul_exp_dp_2       Mapped       No database       Wed Dec 20       13:07:52       2017       Wed Dec 20       13:07:52       2017         36       fpu_mul_fpu_mul_fpu_mul_fpu_mul_fpu_mul_fpu_mul_gpu_d       No database       Wed Dec 20       13:07:52       2017       Wed Dec 20       13:07:52       2017         37       fpu_mul_fpu_mul_fpu_mul_gpu_div_gpu_div_gpu_div_gpu_div_gpu_div_gpu_div_gpu_div_gpu_div_gpu_div_gpu_div_gpu_div_gpu_div_gpu_div_gpu_div_gpu_                                                                                                                                                                                                                     | 28 | fpu div fpu div 0                  | Mapped      | No database        | Wed Dec 20 13:06:35 2017 | Wed Dec 20 13:06:55 2017 |
| 31       fpu_mul_exp_dp_fpu_mul_exp_dp_1       Mapped       No database       Wed Dec 20       13:07:05       2017       Wed Dec 20       13:07:05       2017         2       fpu_mul_fpu_mul_0       Mapped       No database       Wed Dec 20       13:07:05       2017       Wed Dec 20       13:07:12       2017         3       fpu_in_fpu_mul_0       Mapped       No database       Wed Dec 20       13:07:13       2017       Wed Dec 20       13:07:13       2017         4       fpu_in_fpu_in_2       Mapped       No database       Wed Dec 20       13:07:13       2017       Wed Dec 20       13:07:13       2017         3       fpu_in_fpu_in_2       Mapped       No database       Wed Dec 20       13:07:13       2017       Wed Dec 20       13:07:07:02       2017         3       fpu_in_fpu_mul_exp_dp_fpu_mul_exp_dp_2       Mapped       No database       Wed Dec 20       13:07:01       Wed Dec 20       13:07:01       2017       Wed Dec 20       13:07:01       20                                                                                                                                                                                                                                                                    | 29 | fpu in fpu in 1                    | Mapped      | No database        | Wed Dec 20 13:06:57 2017 | Wed Dec 20 13:07:02 2017 |
| 32       fpu_mul_fpu_mul_0       Image       No       database       Wed Dec 20       13:66:25       2017       Wed Dec 20       13:07:28       2017         33       fpu_div_fpu_div_1       Mapped       No       database       Wed Dec 20       13:07:13       2017       Wed Dec 20       13:07:31       2017         34       fpu_div_fpu_div_1       Mapped       No       database       Wed Dec 20       13:07:32       2017       Wed Dec 20       13:07:37       2017         35       fpu_out_fpu_out_1       Mapped       No       database       Wed Dec 20       13:07:32       2017       Wed Dec 20       13:07:37       2017         36       fpu_out_fpu_out_1       Mapped       No       database       Wed Dec 20       13:07:32       2017       Wed Dec 20       13:07:35       2017         37       fpu_mul_exp_dp_fpu_mul_exp_dp_2       Mapped       No       database       Wed Dec 20       13:07:52       2017       Wed Dec 20       13:07:52       2017         37       fpu_mul_fpu_mul_1       Mapped       No       database       Wed Dec 20       13:07:52       2017       Wed Dec 20       13:08:17       2017       Wed Dec 20       13:08:15       2017       Wed Dec 20       13:08:1                                                                                                                                                                                                                                                                                                       | 30 | fpu out fpu out 0                  | Mapped      | No database        | Wed Dec 20 13:06:44 2017 | Wed Dec 20 13:07:04 2017 |
| 33       fpu_dir_fpu_div_l       Mapped       No database       Wed Dec 20       13:07:13       2017       Wed Dec 20       13:07:13       2017         4       fpu_in_fpu_in_fpu_in_2       Mapped       No database       Wed Dec 20       13:07:32       2017       Wed Dec 20       13:07:32       2017         5       fpu_out_fpu_out_1       Mapped       No database       Wed Dec 20       13:07:32       2017       Wed Dec 20       13:07:30       2017       Wed Dec 20       13:07:50       2017       Wed Dec 20       13:08:10       2017       Wed Dec 20       13:08:10       2017       Wed Dec 20       13:08:10       2017       Wed Dec 20       13:08:140       2017       Wed Dec 20       13:08:140       2017       Wed Dec 20       13:08:16       2017       Wed Dec 20       13:08:18       2017       Wed Dec 20       13:08:18       2017                                                                                                                                                                                                                                                             | 31 | fpu mul exp dp fpu mul exp dp 1    | Mapped      | No database        | Wed Dec 20 13:07:05 2017 | Wed Dec 20 13:07:12 2017 |
| 34       fpu_in_fpu_n_2       Mapped       No database       Wed Dec 20       13:07:32       2017       Wed Dec 20       13:07:37       2017         35       fpu_out_fpu_out_1       Mapped       No database       Wed Dec 20       13:07:32       2017       Wed Dec 20       13:07:37       2017         36       fpu_out_fpu_out_1       Mapped       No database       Wed Dec 20       13:07:32       2017       Wed Dec 20       13:07:35       2017         37       fpu_mul_exp_dp_fpu_mul_1       Mapped       No database       Wed Dec 20       13:07:04       2017       Wed Dec 20       13:07:05       2017         37       fpu_mul_fpu_mul_1       Mapped       No database       Wed Dec 20       13:07:04       2017       Wed Dec 20       13:07:08:10       2017         36       fpu_div_fpu_div_2       Mapped       No database       Wed Dec 20       13:08:10       2017       Wed Dec 20       13:08:10       2017         37       fpu_uul_fpu_mul_2       Mapped       No database       Wed Dec 20       13:08:10       2017       Wed Dec 20       13:08:10       2017         37       fpu_mul_fpu_mul_2       Mapped       No database       Wed Dec 20       13:08:10       2017       Wed Dec 20 <td< td=""><td>32</td><td>fpu_mul_fpu_mul_0</td><td>Mapped</td><td>No database</td><td>Wed Dec 20 13:06:25 2017</td><td>Wed Dec 20 13:07:28 2017</td></td<>                                                                                                                                       | 32 | fpu_mul_fpu_mul_0                  | Mapped      | No database        | Wed Dec 20 13:06:25 2017 | Wed Dec 20 13:07:28 2017 |
| 35       fpu_out_fpu_out_1       Mapped       No database       Wed Dec 20       13:07:30       2017       Wed Dec 20       13:07:30       2017         36       fpu_mul_exp_dp_fpu_mul_exp_dp_2       Mapped       No database       Wed Dec 20       13:07:32       2017       Wed Dec 20       13:07:35       2017         36       fpu_mul_fpu_mul_exp_dp_fpu_mul_exp_dp_for       Mapped       No database       Wed Dec 20       13:07:32       2017       Wed Dec 20       13:07:37       2017       Wed Dec 20       13:08:17       2017       Wed Dec 20       13:08:17       2017       Wed Dec 20       13:08:19       2017       Wed Dec 20       13:08:19       2017       Wed Dec 20       13:08:19       2017       Wed Dec 20       13:08:10       2017       Wed Dec 20       13:                                                                                                                                                                                                                                            | 33 | fpu_div_fpu_div_1                  | Mapped      | No database        | Wed Dec 20 13:07:13 2017 | Wed Dec 20 13:07:31 2017 |
| 36         fpu_mul_exp_dp_fpu_mul_exp_dp_2         Mapped         No         database         Wed Dec 20         13:07:52         2017         Wed Dec 20         13:07:52         2017           37         fpu_mul_fpu_mul_1         Mapped         No         database         Wed Dec 20         13:07:52         2017         Wed Dec 20         13:07:52         2017         Wed Dec 20         13:07:52         2017         Wed Dec 20         13:08:12         2017                                                                                                                                                                                         |    |                                    | Mapped      | No database        | Wed Dec 20 13:07:32 2017 | Wed Dec 20 13:07:37 2017 |
| 37         fpu_mul_fu_mul_i         Mapped         No database         Wed Dec 20         13:07:04         2017         Wed Dec 20         13:08:17         2017           36         fpu_div_fpu_div_2         Mapped         No database         Wed Dec 20         13:08:01         2017         Wed Dec 20         13:08:10         2017           37         fpu_div_fpu_div_2         Mapped         No database         Wed Dec 20         13:08:01         2017         Wed Dec 20         13:08:02         2017           39         fpu_mul_fpu_mul_2         Mapped         No database         Wed Dec 20         13:08:10         2017         Wed Dec 20         13:08:02         2017           40         fpu_mul_fpu_mul_2         Mapped         No database         Wed Dec 20         13:08:10         2017         Wed Dec 20         13:08:40         2017           41         fpu_top         Mapped         No database         Wed Dec 20         13:08:13         2017         Wed Dec 20         13:08:43         2017           42                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 35 | fpu_out_fpu_out_1                  | Mapped      | No database        | Wed Dec 20 13:07:30 2017 | Wed Dec 20 13:07:50 2017 |
| 38         fpu_div_fpu_div_2         Mapped         No database         Wed Dec 20         13:08:01         2017         Wed Dec 20         13:08:19         2017           96         fpu_out_fpu_out_2         Mapped         No database         Wed Dec 20         13:08:01         2017         Wed Dec 20         13:08:01         2017         Wed Dec 20         13:08:05         2017         Wed Dec 20         13:08:05         2017         Wed Dec 20         13:08:05         2017         Ved Dec 20         13:08:05 <td>36</td> <td>fpu_mul_exp_dp_fpu_mul_exp_dp_2</td> <td>Mapped</td> <td>No database</td> <td>Wed Dec 20 13:07:52 2017</td> <td>Wed Dec 20 13:07:59 2017</td>                     | 36 | fpu_mul_exp_dp_fpu_mul_exp_dp_2    | Mapped      | No database        | Wed Dec 20 13:07:52 2017 | Wed Dec 20 13:07:59 2017 |
| 39         fpu_out_fpu_out_2         Mapped         No database         Wed Dec 20         13:08:18         2017         Wed Dec 20         13:08:40         2017           40         fpu_mul_fpu_mul_2         Mapped         No database         Wed Dec 20         13:07:39         2017         Wed Dec 20         13:08:40         2017           41         fpu_top         Mapped         No database         Wed Dec 20         13:05:19         2017         Wed Dec 20         13:08:43         2017           42                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |    |                                    |             |                    |                          |                          |
| 40         fpu_mul_fpu_mul_2         Mapped         No database         Wed Dec 20         13:07:39         2017         Wed Dec 20         13:08:50         2017           41         fpu_top         Mapped         No database         Wed Dec 20         13:05:19         2017         Wed Dec 20         13:08:50         2017           41         fpu_top         Mapped         No database         Wed Dec 20         13:05:19         2017         Wed Dec 20         13:08:43         2017           42                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |                                    |             | No database        |                          |                          |
| 41 fpu_top Mapped No database Wed Dec 20 13:05:19 2017 Wed Dec 20 13:08:43 2017<br>42<br>43 Total number of compile points: 25                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |    |                                    |             |                    |                          |                          |
| 42<br>43 Total number of compile points: 25                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 40 |                                    |             |                    |                          |                          |
| 43 Total number of compile points: 25                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |    |                                    |             |                    |                          |                          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |    |                                    |             |                    |                          |                          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |    |                                    |             |                    |                          |                          |
| 44                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 44 |                                    | ==          |                    |                          |                          |

Figure 188 • Synplify-Pro Log File Showing Summary of Compile Points Section

The log file rev\_1/synlog/open\_sparc\_fpu\_icf\_demo\_fpga\_mapper.srr lists a summary line for each of the defined compile points. Each compile point is an instance of the modules defined in the FDC file. All of these compile points are marked as **Mapped** (in this case "No database" because the design is being mapped for the first time). The timestamp of the last compile for each indicate they are all mapped at about the same time. Immediately below that section is a reference to a separate .srr log file file for each compile point.

#### (i) Note

The "**Summary of Compile Points**" section may contain different **Name** entries than those that were defined in the FDC file. These can be instances of those modules.

The log file may contain the following warnings:

@N: MF104 :|Found compile point of type locked on View view:work.fpu\_in\_ctl(verilog) @N: MF104 :|Found compile point of type locked on View view:work.fpu\_in(verilog) @N: MF104 :|Found compile point of type locked on View view:work.fpu\_mul\_ctl(verilog) @N: MF104 :|Found compile point of type locked on View view:work.fpu\_mul\_exp\_dp(verilog) @N: MF104 :|Found compile point of type locked on View view:work.fpu\_mul(verilog) @N: MF104 :|Found compile point of type locked on View view:work.fpu\_mul(verilog) @N: MF104 :|Found compile point of type locked on View view:work.fpu\_mul(verilog) @N: MF104 :|Found compile point of type locked on View view:work.fpu\_div(verilog)
@N: MF104 :|Found compile point of type locked on View view:work.fpu\_out\_ctl(verilog)
@N: MF104 :|Found compile point of type locked on View view:work.fpu\_out(verilog)

These warnings are due to a a caveat when using attributes with compile points. Attributes can be used when setting constraints for compile points. However, when using syn\_hier on a compile point, the only valid value is *flatten*. All other values of this attribute (e.g., hard) are ignored for compile points. The syn\_hier attribute behaves normally for all other module boundaries not defined as compile points.

### ACE Partitioning Constraints File

The file synplyfy/rev\_1/open\_sparc\_fpu\_icf\_demo\_partition.prt is written by Synplify for inclusion in the ACE project. This file contains TCL commands that define the Synplify-Pro compile points as partitions in ACE. Each command contains both the instance and view names of each partition, as well as its timestamp and compile-point type. There are many more partitions (37) listed in the .prt file than there were compile points listed in the Synplify log file because the partitions represent instances, while the compile points represent modules (many of the modules are instantiated multiple times in this design). The number of these instances match the number of the compile points found in the "Summary of Compile Points" section.

| 1 set partition info -name "/fpu top" -view "fpu top" -timestamp "1513803914" -cp type "hard"                        | -     |
|----------------------------------------------------------------------------------------------------------------------|-------|
| 2 set partition info -name "/fpu top/fpu inst[0].i fpu/fpu out/fpu out ctl" -view "fpu out ctl" -timestamp "1513803  |       |
| 3 set partition info -name "/fpu top/fpu inst[0].i fpu/fpu out" -view "fpu out" -timestamp "1513803914" -cp type "l  |       |
| 4 set partition info -name "/fpu top/fpu inst[0].i fpu/fpu div/fpu div ctl" -view "fpu div ctl" -timestamp "1513803  |       |
| 5 set partition info -name "/fpu top/fpu inst[0].i fpu/fpu div" -view "fpu div" -timestamp "1513803914" -cp type "l  |       |
| 6 set partition info -name "/fpu top/fpu inst[0].i fpu/fpu mul/fpu mul exp dp" -view "fpu mul exp dp" -timestamp "1  |       |
| 7 set partition info -name "/fpu top/fpu inst[0].i fpu/fpu mul/fpu mul ctl" -view "fpu mul ctl" -timestamp "1513803  |       |
| 8 set partition info -name "/fpu top/fpu inst[0].i fpu/fpu mul" -view "fpu mul" -timestamp "1513803914" -cp type "l  |       |
| 9 set partition info -name "/fpu top/fpu inst[0].i fpu/fpu in/fpu in ctl" -view "fpu in ctl" -timestamp "1513803914  |       |
| 10 set partition info -name "/fpu top/fpu inst[0].i fpu/fpu in" -view "fpu in" -timestamp "1513803914" -cp type "loc |       |
| 11 set partition info -name "/fpu top/fpu inst[1].i fpu/fpu out/fpu out ctl" -view "fpu out ctl" -timestamp "1513803 |       |
| 12 set_partition_info -name "/fpu_top/fpu_inst[1].i_fpu/fpu_out" -view "fpu_out" -timestamp "1513803914" -cp_type "l |       |
| 13 set_partition_info -name "/fpu_top/fpu_inst[1].i_fpu/fpu_div/fpu_div_ctl" -view "fpu_div_ctl" -timestamp "1513803 |       |
| 14 set_partition_info -name "/fpu_top/fpu_inst[1].i_fpu/fpu_div" -view "fpu_div" -timestamp "1513803914" -cp_type "l |       |
| 15 set_partition_info -name "/fpu_top/fpu_inst[1].i_fpu/fpu_mul/fpu_mul_exp_dp" -view "fpu_mul_exp_dp" -timestamp "1 |       |
| 16 set_partition_info -name "/fpu_top/fpu_inst[1].i_fpu/fpu_mul/fpu_mul_ctl" -view "fpu_mul_ctl" -timestamp "1513803 |       |
| 17 set_partition_info -name "/fpu_top/fpu_inst[1].i_fpu/fpu_mul" -view "fpu_mul" -timestamp "1513803914" -cp_type "l |       |
| 18 set_partition_info -name "/fpu_top/fpu_inst[1].i_fpu/fpu_in/fpu_in_ctl" -view "fpu_in_ctl" -timestamp "1513803914 |       |
| 19 set_partition_info -name "/fpu_top/fpu_inst[1].i_fpu/fpu_in" -view "fpu_in" -timestamp "1513803914" -cp_type "loc |       |
| 20 set_partition_info -name "/fpu_top/fpu_inst[2].i_fpu/fpu_out/fpu_out_ctl" -view "fpu_out_ctl" -timestamp "1513803 |       |
| 21 set_partition_info -name "/fpu_top/fpu_inst[2].i_fpu/fpu_out" -view "fpu_out" -timestamp "1513803914" -cp_type "l |       |
| 22 set_partition_info -name "/fpu_top/fpu_inst[2].i_fpu/fpu_div/fpu_div_ctl" -view "fpu_div_ctl" -timestamp "1513803 |       |
| 23 set_partition_info -name "/fpu_top/fpu_inst[2].i_fpu/fpu_div" -view "fpu_div" -timestamp "1513803914" -cp_type "l |       |
| 24 set_partition_info -name "/fpu_top/fpu_inst[2].i_fpu/fpu_mul/fpu_mul_exp_dp" -view "fpu_mul_exp_dp" -timestamp "1 |       |
| 25 set_partition_info -name "/fpu_top/fpu_inst[2].i_fpu/fpu_mul/fpu_mul_ctl" -view "fpu_mul_ctl" -timestamp "1513803 |       |
| 26 set_partition_info -name "/fpu_top/fpu_inst[2].i_fpu/fpu_mul" -view "fpu_mul" -timestamp "1513803914" -cp_type "l |       |
| 27 set_partition_info -name "/fpu_top/fpu_inst[2].i_fpu/fpu_in/fpu_in_ctl" -view "fpu_in_ctl" -timestamp "1513803914 |       |
| 28 set_partition_info -name "/fpu_top/fpu_inst[2].i_fpu/fpu_in" -view "fpu_in" -timestamp "1513803914" -cp_type "loc |       |
| 29 set_partition_info -name "/fpu_top/fpu_inst[3].i_fpu/fpu_out/fpu_out_ctl" -view "fpu_out_ctl" -timestamp "1513803 |       |
| 30 set_partition_info -name "/fpu_top/fpu_inst[3].i_fpu/fpu_out" -view "fpu_out" -timestamp "1513803914" -cp_type "l |       |
| 31 set_partition_info -name "/fpu_top/fpu_inst[3].i_fpu/fpu_div/fpu_div_ctl" -view "fpu_div_ctl" -timestamp "1513803 |       |
| 32 set_partition_info -name "/fpu_top/fpu_inst[3].i_fpu/fpu_div" -view "fpu_div" -timestamp "1513803914" -cp_type "l |       |
| 33 set_partition_info -name "/fpu_top/fpu_inst[3].i_fpu/fpu_mul/fpu_mul_exp_dp" -view "fpu_mul_exp_dp" -timestamp "1 |       |
| 34 set_partition_info -name "/fpu_top/fpu_inst[3].i_fpu/fpu_mul/fpu_mul_ctl" -view "fpu_mul_ctl" -timestamp "1513803 |       |
| 35 set_partition_info -name "/fpu_top/fpu_inst[3].i_fpu/fpu_mul" -view "fpu_mul" -timestamp "1513803914" -cp_type "l |       |
| 36 set_partition_info -name "/fpu_top/fpu_inst[3].i_fpu/fpu_in/fpu_in_ctl" -view "fpu_in_ctl" -timestamp "1513803914 | -     |
| 37 set_partition_info -name "/fpu_top/fpu_inst[3].i_fpu/fpu_in" -view "fpu_in" -timestamp "1513803914" -cp_type "loc | _     |
|                                                                                                                      |       |
| Ln 1 Col 1 Total 37 Ovr                                                                                              | Block |
|                                                                                                                      |       |

Figure 189 • Contents of the open\_sparc\_fpu\_icf\_demo\_partition.prt File

### **Technology View**

• Click the (P) **Technology View** button to open the design schematic, then select one of the fpu\_inst instances. These instances can be identified by expanding the Instances/Groups folder and then left-mouse click one to select it. The selected instance is highlighted with a red boundary in the Tech popup view.



Figure 190 • Synplify Pro Initial Technology View Top-level Schematic, with no instance selected



Figure 191 • Note how the selected instance (fpu\_3) is highlighted in red

• Use the right mouse button to push into that level of the hierarchy. The schematic then updates. The locked and hard partitions have a green background color while the default instance background color is yellow. In the schematic area, use the right mouse button now to either push or pop hierarchy levels, depending on where the mouse is located when clicked.



Figure 192 • Synplify Pro Technology View

• Exit from Synplify Pro. Next, the design must be placed and routed in ACE.

### Step 5: Set up the ACE Project

• Start the ACE GUI. Under Linux, execute:

```
% cd <your work area>/Speedcore_Incremental_Compile_RefDesign_RD012/ace
% ace
```

Under Windows, double click the ACE icon.

● Then create a new project with **File** → **Create Project**. Click **Browse** to navigate through the filesystem to ensure that the project is created under the subdirectory Speedcore\_Incremental\_Compile\_RefDesign\_RD012/ ace and click **OK**. Use proj\_1 for the project name, and impl\_1 for the implementation name. Click **Finish**.

The ACE home screen appears with an empty project named proj\_1 and an implementation named impl\_1, as in the following screen shot:

| ACE - Achronix CAD Environment - Version HS1.1 - proj 1->impl 1 (AG                                                                                                                                                                                                                                                   | 1655C01HI01C)                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                      |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| File Edit Actions Window Help                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                      |
|                                                                                                                                                                                                                                                                                                                       | 3                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                      |
| C Projects X  C C C C C C C C C C C C C C C C C C                                                                                                                                                                                                                                                                     | E Options 🛛                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                      |
|                                                                                                                                                                                                                                                                                                                       | Project: proj_1<br>Implementation: impl_1                                                                                                                                                                                                                                                                                                                  |                                                                                                                                      |
|                                                                                                                                                                                                                                                                                                                       | Design Preparation                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                      |
|                                                                                                                                                                                                                                                                                                                       | Advanced Design Preparation                                                                                                                                                                                                                                                                                                                                |                                                                                                                                      |
|                                                                                                                                                                                                                                                                                                                       | Place and Route                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                      |
|                                                                                                                                                                                                                                                                                                                       | Timing Analysis                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                      |
| 🎭 Flow 🛛 🕨 🕨 🔳 🖓 🗖                                                                                                                                                                                                                                                                                                    | Bitstream Generation                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                      |
| Prepare     A Run Prepare                                                                                                                                                                                                                                                                                             | FPGA Download                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                      |
| Run Prepare A Run Estimated Timing Analysis                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                      |
| Generate Pre-Placed Simulation Netlist     Generate Route                                                                                                                                                                                                                                                             | 📮 Tcl Console 🛛                                                                                                                                                                                                                                                                                                                                            | ► ≩ 🗎 <sup>-</sup> 🗆                                                                                                                 |
| C Place and Acoute     C Place and Acoute     A Run Placement Timing Analysis     A Run Post-Placement Timing Analysis     A Run Post-Pocces Design     A Run Final DRC Checks     A Run Final Simulation Netlist     G Post-Pocces     G Cenerate Binal Simulation Netlist     G Cenerate Ristream     A Post Pocces | ACC Achroniz CAD Environment Version MSL1 Gui<br>(C) Copyright 2006-2016 Achroniz Sentonductor Corp<br>- all messages Logged in file C:/Users/mikeriepe/.achroni<br>MFO: License ace-VL0 on server cod21 (2055) of 9800 Lier<br>cmd ace_internal:renable_reserved all<br>cmd create_project "C:/Ahronix/Speedcore_Incremental_Con<br>cmd save_projectno_db | ll rights reserved.<br>x/ace_2016_10_12_12_43_35.log, created at 12:43:35 on 10/12<br>ses available). Running on SJC-4184-MRB (x64). |
|                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                      |
|                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                            | +                                                                                                                                    |
|                                                                                                                                                                                                                                                                                                                       | •                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                      |
| <b>0</b> *                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                            | 16M pf 33M                                                                                                                           |

Figure 193 • ACE Home Screen

• Select File  $\rightarrow$  Add Project Source Files..., then click Speedcore\_Incremental\_Compile\_RefDesign\_RD012 in the pathname bar to locate the source files and open the following dialog box:

| ganize 🔻 New folder                 |             |                  |             |      | • |
|-------------------------------------|-------------|------------------|-------------|------|---|
| ' Favorites                         | A Name      | Date modified    | Туре        | Size |   |
| Desktop                             | 🔒 ace       | 10/12/2016 12:47 | File folder |      |   |
| 🗼 Downloads                         | constraints | 10/12/2016 11:55 | File folder |      |   |
| 🕏 Dropbox                           | 🔒 rti       | 10/12/2016 11:55 | File folder |      |   |
| 📙 Google Drive                      | 📕 rtl_V1    | 10/12/2016 11:55 | File folder |      |   |
| Recent Places                       | \mu rtl_V2  | 10/12/2016 11:55 | File folder |      |   |
|                                     | \mu rtl_V3  | 10/12/2016 11:55 | File folder |      |   |
| Libraries                           | ≡ 🍑 rtl_V4  | 10/12/2016 11:55 | File folder |      |   |
| Documents                           | synplify    | 10/12/2016 11:57 | File folder |      |   |
| 🖞 Music                             |             |                  |             |      |   |
| Pictures                            |             |                  |             |      |   |
| Videos                              |             |                  |             |      |   |
| Computer                            |             |                  |             |      |   |
| 🏜 OS (C:)                           |             |                  |             |      |   |
| 🖉 General (\\watt) (G:)             |             |                  |             |      |   |
| 🛫 general (\\TAHOE) (U:)            |             |                  |             |      |   |
| 📲 mikeriepe (\\BOB\views) (V:)      |             |                  |             |      |   |
| 😿 billteng (\\itchy4\scratch1) (W:) |             |                  |             |      |   |
| mike (\itchw(\scratch1) (Y))        | Ŧ           |                  |             |      |   |

Figure 194 • Design Source Files Dialog

• Navigate to the constraints directory, select the open\_sparc\_fpu\_icf\_demo.sdc file, and then click **OK**. Bring up the Add Project Source Files dialog box again, navigate to the directory synplify/rev\_1/, control-click to select the files open\_sparc\_fpu\_icf\_demo.vm and open\_sparc\_fpu\_icf\_demo\_partition.prt, and click **OK** to add them to the project.

• Finally, in the Options tab under "Design Preparation", verify that the **Target Device** is the same device name used in Synplify, and verify that the **Enable Incremental Compile** implementation option checkbox is checked. All of the files just added appear under the ace/Netlists and ace/Constraints folders of the Projects tab.

# ✓ Tip In the Projects Perspective → Projects View click the triangle next to Constraints to list out the constraint files, etc.

| ACE - Achronix CAD Environment - Version HS1.1 - proj_1->impl_1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | (AC16tSC01HI01C)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                         |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|
| File Edit Actions Window Help                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                         |
| à 🖉 🐃 🕫 🗈 😰 🖉 📲 🖀 🔮                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                         |
| 🙆 Projects 😂 🖆 😂 🖏 🛯 🤀 🖏 🛛 😭 🖉 🖓 🗶 🦮 "                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Deptions 🛙                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                         |
| <pre></pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Project         proj.l           Implementation: impl.l         Design Preparation           Target Device         ACLESSCOLHBIC         •           Package         CORE         •           Speed Grade         CI         •           Core Voltage         0.80         •           Junction Temperature         0         •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                         |
| Op. Flow:     Image: Construct Timing Analysis       Image: Construct Timing Analysis     Image: Construct Timing Analysis | Flow Mode     Evaluation       Incremental Compile     Incremental Compile       Incremental Compile     Incremental Compile       Incremental Compile     Incremental Compile       Constraint Files     Image: |                                                                                                                         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | <pre>cmd&gt; add_project_netlist -project "proj_1" "C:/Achronix/Speedcore_I</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | hts reserved.<br>2016/10/12/12/43/35.log, created at 12:43:35 on 10/12/2016<br>silable). Running on 53C-4184-NRB (x64). |
| C:\Achronix\Speedcore_Incremental_Compile_RefDesign                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | K0012\ace\proi 1.acmri                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 22M of 33M                                                                                                              |

Figure 195 • ACE Projects Tab

• Recall from Step 4 (page 417) that the open\_sparc\_fpu\_icf\_demo\_partition.prt file (added to the project above) contains the partition definitions exported from Synplify Pro. The presence of this constraint file and the Enable Incremental Compile implementation option are the only configuration changes that distinguish the incremental compile flow from the standard non-incremental flow.

• Immediately under the **Enable Incremental Compile** implementation option checkbox is a drop-down box for the **Incremental Compile Mode** implementation option. Available values are strict and smart. Strict mode ensures that placement of locked instances in unchanged partitions are completely preserved. Smart mode (the default) allows ACE to try to intelligently preserve placement in locked partitions for better design performance.

### Step 6: Compile the Design in ACE

• In the Flow tab, uncheck the Run Sign-off Timing Analysis and Generate Bitstream flow step checkboxes to save

some runtime. Then click the green triangle ( ) in the upper-right corner of the Flow view to run the prepare, placement, and routing flow. When the ACE flow completes, a green check mark appears by the **Run Final DRC Checks** flow step in the Flow view.

### **Step 7: Review ACE Results**

Next is a review of some of the features available to help in understanding and optimizing the partition constraints.

### **Partition Report**

• While the ACE flow is running, the Partition Report can be viewed at any time after the completion of the Run Prepare flow step. In the ACE GUI, the report opens automatically in the Editor Area of the Project perspective.

| 3 4 4 4                                                                                                               |                 |                    |                  |                                   |          |           |          |       |       |       |       |      |      |      |      |       |       |          |          |                        |                            |                          |                           |                        |                            |                           |                            |                           |                            |                    |
|-----------------------------------------------------------------------------------------------------------------------|-----------------|--------------------|------------------|-----------------------------------|----------|-----------|----------|-------|-------|-------|-------|------|------|------|------|-------|-------|----------|----------|------------------------|----------------------------|--------------------------|---------------------------|------------------------|----------------------------|---------------------------|----------------------------|---------------------------|----------------------------|--------------------|
| Clock/Reset Report — f                                                                                                | pu_top 🚳        | Utilization Re     | port - Prepar    | ea — tpu_top                      |          | Partition | n report | — tpu | tob S | ·     | _     | -    | _    |      | _    | _     | _     |          |          |                        |                            |                          |                           |                        |                            |                           |                            |                           |                            |                    |
| Partition Rep                                                                                                         | ort             |                    |                  |                                   |          |           |          |       |       |       |       |      |      |      |      |       |       |          |          |                        |                            |                          |                           |                        |                            |                           |                            |                           |                            |                    |
| ACE – Achronix CAD E<br>Design: proj_1 - impl_1<br>Device: AC16tSC01HID<br>Generated on Wed Oct<br>Host: sjc-4184-mrb | - fpu_top<br>1C |                    | 3uild 95834      | Date 2016-10-1                    | 11 00:38 |           |          |       |       |       |       |      |      |      |      |       |       |          |          |                        |                            |                          |                           |                        |                            |                           |                            |                           |                            |                    |
| Summary                                                                                                               |                 |                    |                  |                                   |          |           |          |       |       |       |       |      |      |      |      |       |       |          |          |                        |                            |                          |                           |                        |                            |                           |                            |                           |                            |                    |
| Number of partition     Number of instance     Number of nets: 62                                                     | s: 51103 (511   | 11 belomoiled 10   | 0 00%)           |                                   |          |           |          |       |       |       |       |      |      |      |      |       |       |          |          |                        |                            |                          |                           |                        |                            |                           |                            |                           |                            |                    |
| Details                                                                                                               | 323 (02323 10   | -completed, 100.00 |                  |                                   |          |           |          |       |       |       |       |      |      |      |      |       |       |          |          |                        |                            |                          |                           |                        |                            |                           |                            |                           |                            |                    |
| Partition Na                                                                                                          | me              | Module Name        | Re-<br>Compiled? | Timestamp                         | Туре     | Nets      | Insta    | LUTS  | Flops | MUX4s | MUX8s | ALUS | LRAM | BRAM | DSPe | IPINs | OPINs | CLK_IPIN | CLK_OPIN | Boundary<br>Input Nets | Boundary<br>Output<br>Nets | Registered<br>Input Nets | Registered<br>Output Nets | Constant<br>Input Nets | Constant<br>Output<br>Nets | Floating<br>Input<br>Nets | Floating<br>Output<br>Nets | Dangling<br>Input<br>Nets | Dangling<br>Output<br>Nets | Feedthroug<br>Nets |
| //pu_top                                                                                                              |                 | fpu_top            | Yes              | Wed 12 Oct<br>2016<br>03:41:11 PM | Hard     | 23167     | 19739    | 13436 | 5321  | 155   | 0     | 308  | 0    | 0    | 0    | 364   | 154   | 1        | 0        | 0                      | 0                          | 0                        | 0                         | 0                      | 0                          | 0                         | 0                          |                           | 0                          | 0                  |
| //pu_top/fpu_inst(0).i_f                                                                                              | putpu_mul       | fpu_mul            | Yes              | Wed 12 Oct<br>2016<br>03:41:11 PM | Locked   | 4352      | 3485     | 2641  | 774   | 0     | 0     | 64   | 0    | o    | 6    | 0     | 0     | 0        | 0        | 113                    | 53                         | 1                        | 0                         | 0                      | 1                          | 0                         | 0                          | 0                         | 1                          | 0                  |
| //pu_top/fpu_inst[1].i_f                                                                                              | putpu_mul       | fpu_mul            | Yes              | Wed 12 Oct<br>2016<br>03:41:11 PM | Locked   | 4352      | 3485     | 2641  | 774   | 0     | 0     | 64   | 0    | o    | 6    | 0     | 0     | 0        | 0        | 113                    | 53                         | 1                        | 0                         | 0                      | 1                          | 0                         | 0                          | 0                         | 1                          | 0                  |
| //pu_top/fpu_inst[2].i_f                                                                                              | putpu_mul       | fpu_mul            | Yes              | Wed 12 Oct<br>2016<br>03:41:11 PM | Locked   | 4352      | 3485     | 2641  | 774   | 0     | 0     | 64   | 0    | o    | 6    | o     | 0     | 0        | 0        | 113                    | 53                         | 1                        | 0                         | 0                      | 1                          | 0                         | 0                          | 0                         | 1                          | 0                  |
| //pu_top/fpu_inst[3].i_f                                                                                              | outpu_mul       | fpu_mul            | Yes              | Wed 12 Oct<br>2016<br>03:41:11 PM | Locked   | 4352      | 3485     | 2641  | 774   | 0     | 0     | 64   | 0    | o    | 6    | o     | 0     | 0        | 0        | 113                    | 53                         | 1                        | 0                         | 0                      | 1                          | 0                         | 0                          | 0                         | 1                          | 0                  |
| //pu_top/fpu_inst[1].i_f                                                                                              | putpu_div       | fpu_div            | Yes              | Wed 12 Oct<br>2016<br>03:41:11 PM | Locked   | 2121      | 1829     | 1316  | 491   | 0     | 0     | 22   | 0    | o    | 0    | o     | 0     | 0        | o        | 129                    | 65                         | 1                        | 0                         | 0                      | 1                          | 0                         | 0                          | 0                         | 1                          | •                  |
| //pu_top/fpu_inst(0).i_f                                                                                              | pultpu_div      | fpu_div            | Yes              | Wed 12 Oct<br>2016<br>03:41:11 PM | Locked   | 2121      | 1829     | 1316  | 491   | 0     | 0     | 22   | 0    | 0    | ۰    | 0     | 0     | 0        | 0        | 129                    | 65                         | 1                        | 0                         | 0                      | 1                          | 0                         | 0                          | 0                         | 1                          | •                  |
| //pu_top/fpu_inst(2).i_f                                                                                              | pulfpu_div      | fpu_div            | Yes              | Wed 12 Oct<br>2018<br>03:41:11 PM | Locked   | 2121      | 1829     | 1316  | 491   | 0     | 0     | 22   | 0    | 0    | ٥    | 0     | 0     | 0        | 0        | 129                    | 65                         | 1                        | 0                         | 0                      | 1                          | 0                         | 0                          | 0                         | 1                          | ٥                  |
| //pu_top/fpu_inst[3].i_f                                                                                              | pulfpu_div      | fpu_div            | Yes              | Wed 12 Oct<br>2018<br>03:41:11 PM | Locked   | 2121      | 1829     | 1316  | 491   | 0     | 0     | 22   | 0    | ٥    | ٥    | 0     | 0     | 0        | ٥        | 129                    | 65                         | 1                        | 0                         | 0                      | 1                          | 0                         | 0                          | 0                         | 1                          | ۰                  |
| //pu_top//pu_inst[1].i_f                                                                                              | outpu_in        | fpu_in             | Yes              | Wed 12 Oct<br>2016<br>03:41:11 PM | Locked   | 877       | 789      | 484   | 305   | 0     | 0     | 0    | 0    | 0    | •    | o     | 0     | 0        | 0        | 83                     | 311                        | 82                       | 0                         | 1                      | 1                          | 0                         | 0                          | 0                         | 1                          | •                  |
| //pu_top/fpu_inst[2];i_f                                                                                              | ou¶pu_in        | fpu_in             | Yes              | Wed 12 Oct<br>2016<br>03:41:11 PM | Locked   | 877       | 789      | 484   | 305   | 0     | 0     | 0    | 0    | o    | 0    | o     | 0     | 0        | 0        | 83                     | 311                        | 82                       | 0                         | 1                      | 1                          | 0                         | 0                          | 0                         | 1                          | •                  |
| //pu_top/fpu_inst[3].i_f                                                                                              | ou¶pu_in        | fpu_in             | Yes              | Wed 12 Oct<br>2016<br>03:41:11 PM | Locked   | 877       | 789      | 454   | 305   | 0     | 0     | 0    | 0    | o    | 0    | o     | 0     | 0        | 0        | 63                     | 311                        | 62                       | 0                         | 1                      | 1                          | 0                         | 0                          | 0                         | 1                          | 0                  |
| //pu_top/fpu_inst(0).i_f                                                                                              | outpu_in        | fpu_in             | Yes              | Wed 12 Oct<br>2016<br>03:41:11 PM | Locked   | 877       | 789      | 464   | 305   | 0     | 0     | 0    | 0    | 0    | ۰    | 0     | 0     | 0        | 0        | 63                     | 311                        | 82                       | 0                         | 1                      | 1                          | 0                         | 0                          | 0                         | 1                          | •                  |
| //pu_top/fpu_inst<br>[1].i_fpu/fpu_mul/fpu_r                                                                          | nul_ct          | fpu_mul_ctl        | Yes              | Wed 12 Oct<br>2016<br>03:41:11 PM | Locked   | 548       | 404      | 218   | 184   | 0     | 0     | 2    | 0    | 0    | ۰    | 0     | 0     | 0        | 0        | 133                    | 78                         | 3                        | 7                         | 1                      | 1                          | 0                         | 0                          | 0                         | 0                          | 3                  |
| //pu_top/fpu_inst<br>[3].i_fpu/fpu_mul/fpu_r                                                                          | nul_ct          | fpu_mul_ctl        | Yes              | Wed 12 Oct<br>2016<br>03:41:11 PM | Locked   | 548       | 404      | 218   | 184   | 0     | 0     | 2    | 0    | 0    | ۰    | 0     | 0     | 0        | 0        | 133                    | 78                         | 3                        | 7                         | 1                      | 1                          | 0                         | 0                          | 0                         | 0                          | 3                  |
| /fpu_top/fpu_inst<br>[2].i_fpu/fpu_mui/fpu_m                                                                          | nul cit         | fpu_mul_ctl        | Yes              | Wed 12 Oct<br>2016<br>03:41:11 PM | Locked   | 548       | 404      | 218   | 184   | 0     | 0     | 2    | 0    | 0    | ٥    | 0     | 0     | 0        | 0        | 133                    | 78                         | 3                        | 7                         | 1                      | 1                          | 0                         | 0                          | 0                         | 0                          | 3                  |

Figure 196 • ACE Partition Report After First Incremental Compile Iteration

• First look at the Summary section. The report shows the total number of partitions and the number that were recompiled (in this case 100% because this was the first pass through the flow). Also listed are the number of instances and nets that are owned by a partition, plus the number that were recompiled by ACE (again, 100% of each). Placement runtimes are proportional to the number of recompiled instances, and routing runtimes are proportional to the number of recompiled instances.

• The Details section displays a table with one row for each partition. Columns are printed as follows:

- · Partition Name (which are the same as the instance name in the unflattened RTL)
- Module Name (derived from the module name in the RTL)

- Re-Compiled? column ("yes" or "no")
- Timestamp (time and date when it was last compiled in Synplify Pro)
- Type (only "Hard" and "Locked" are supported by ACE)
- The number of nets and instances owned by the partition
- A series of columns with instance counts for LUTs, Flops (DFFs), ALUs, LRAMs, BRAMs, etc.

The final eleven columns in the Details section provide information about the boundary nets of each partition. This information is useful in analyzing the suitability of each module for partitioning and to suggest ways in which the design may be improved to make it more amenable to partitioning. These include:

- Two columns counting the number of input nets and output nets crossing the boundary. These correspond to the ports of the original RTL module that have been flattened away. An input net has its driver outside the partition, while an output net has its driver inside the partition. The larger the ratio of boundary nets to instances in a partition, the more likely it is that the placement and routing of the partition is disturbed when neighboring partitions are recompiled (this is a corollary of Rent's Rule).
- Two columns with the number of input and output boundary nets that are registered. Registering boundary ports is always a good idea as it can be harder to maintain timing closure of cross-boundary paths when a partition or its parent needs to be recompiled.
- Two columns with the number of input and output boundary nets driven by a constant. Designers often tie-off unused inputs or outputs of a block and assume that those constants are optimized away by the logic synthesis tools. However, logic synthesis must assume that those constants may change in the future, so constant propagation cannot be performed across locked partition boundaries. Locking can result in a netlist that is much larger than expected. It is better to define a compile point on an RTL wrapper module that encloses input pin constants inside the partition and output-pin constants outside the partition. This method provides logic synthesis with the freedom to eliminate gates made redundant by the constants.
- Four columns with the number of input and output boundary nets that are floating and dangling, respectively. Floating nets have input pin loads with no driver, and dangling nets have a driver with no input pin loads. Similarly to constant boundary nets, logic synthesis is not able to optimize away floating and dangling logic across locked partition boundaries. Again, if a design has pins on a module that can logically be left unconnected, it is usually best to create a wrapper module so that unconnected inputs are enclosed within the partition and unconnected outputs are outside the partition, and then define the wrapper module as the partition instead.
- One column with the number of feedthrough nets. A feedthrough net enters an input pin of a module and exits through an output pin without driving any logic inside the partition. Again because logic synthesis cannot optimize logic across Locked partition boundaries, and it cannot eliminate pins on either Locked or Hard partition boundaries, it is best to eliminate feedthrough nets from the design. Feedthroughs impose constraints on synthesis, placement, and routing that can results in unnecessary delay and routing congestion.

#### i Note

The table is sorted so that partitions with a recompiled state of "Yes" appear first, then sorted by number of instances.

### **Floorplan View**

• After the Routing flow step has completed, switch to the Floorplanner perspective to view the results. In the **Floorplanner View** (page 45) flyout palette, under the Layers section, turn on visibility for Instances, but turn off visibility for Sites, Clock Routes, and Non-clock Routes.



Figure 197 • ACE Floorplanner Perspective After First Incremental Compile Iteration

• Switch to the Partitions View (page 111) to see a table with one row for each partition name. Columns exist for the Partition Timestamp; Re-Compiled status (a check-mark or not); the number of Flops, LUTs, ALUs, BRAMs, LRAMs, and Others (IOs, sources, etc); and the number of Cumulative Flops, LUTs, ALUs, BRAMs, LRAMs, and Others. The number of instances of each type includes only those instances directly owned by the given partition. The number of cumulative instances of each type includes instances owned by the given partition, as well as all child partitions below that partition in the RTL hierarchy.

The column named Force Recompile on Next Run provides a mechanism to override the partition timestamp during the *next* pass through ACE. Right-click anywhere in the row for a partition and select **Force Partition Changed**. A check mark appears in the Force Recompile on Next Run column, and the partition is re-placed and re-routed the next time the flow is run during this ACE session, even if there were no RTL changes nor recompilation in Synplify-Pro. Right-click again and select **Un-Force Partition Changed** to remove the check mark, or else the checkmark is removed automatically when the flow is run later in this ACE session.

• The column named Highlight Color displays a box with the partition highlight color. It should currently be empty. Right-click the row for a partition and select Highlight Partition to highlight the partition instances in the

Floorplanner view with the current highlight color for the Partition tab. In the toolbar above the table, click the (□) Choose Highlight Color tool to change the highlight color to be used in the next Highlight command. Right-click the partition row and select **Un-Highlight Partition** to disable highlighting of the partition instances. Alternatively, the (

I Highlight Partition and () Un-Highlight Partition tools in the toolbar can be used to highlight the currently selected partition in the table.

• Finally, ensure that none of the partitions are highlighted, and click the ( 🥒 ) Auto-Highlight Partitions tool in the toolbar to highlight all of the partitions with an automatically selected color:



Figure 198 • Highlighting Partitions in ACE After First Incremental Compile Iteration

The ( ) auto-highlight feature is an extremely powerful tool in understanding the logical and physical connectivity relationships between partitions. Generally, instances in a partition are placed in close proximity to each other if the connectivity within the partition is stronger than the connectivity outside (i.e., Rent's Rule: the number of ports on the partition being much smaller than the number of instances). The instances in one partition are generally placed close to the instances of other partitions with strong connectivity between them, and farther away from other partitions with weak connectivity. Specifically, if a partition has instances scattered over a wide area, it means that the instances are more strongly connected to other partitions than they are to each other. It may be better to remove that partition from the partition constraints. Placement and routing QoR may improve if that partition is recompiled every time the RTL is recompiled, allowing those instances to adapt to changes in their neighbors. This behavior may even be a sign that the RTL should be re-architected to absorb those glue logic instances into the top-level block or their neighboring instances.

Tools also exist in the toolbar to zoom (see Zooming the Floorplanner In and Out (page 338)) to the instances of the selected partition, search for the instances of the selected partition (this generates the appropriate Tcl find (page 638) command to populate the Search View (page 133)), and add the instances of the selected partition to the selection set (done with the Tcl select (page 709) command, with results displayed in the Selection View (page 137)).

• The partition table includes filtering functionality, which can be used to control visibility of the partition rows. To enable filtering, click the (22) Toggle Filter Row Visibility button. The filter row allows a content-appropriate filter to

be applied to one or more table columns. Numeric columns filter based upon number ranges, while name columns

filter based upon string matching or even regular expressions. For example, clicking the ( $\square$ ) filter icon above the LUTs column allows viewing only partitions with, for example, greater than 3,000 LUTs. This filter functionality is most useful when there are a large number of partitions.

#### 🕑 Tip

After using the ( ) Placement Region Tool in the Floorplanner view to create a new placement region, if using partitions, drag-and-drop a row from the Partitions view onto the newly created placement region (either the appropriate row of the table in the **Placement Regions View** (page 114), or directly into the placement region painted in the Floorplanner view). This action generates the correct add\_region\_find\_insts (page 613) command to add all instances in the dragged partition to the designated placement region.

#### **Netlist Browser**

• The Netlist Browser View (page 81) also contains several features dedicated to the Incremental Compile Flow. There is a column (Partition) naming which partition owns all instances represented by that row in the table. No partition name is given if the instances are not owned by a partition, or if they are split between two or more partitions. When a partition is highlighted in the Partitions view, that highlight color is also present in the Highlight Color column of the Netlist Browser in all rows owned by the given partition.

| 물 👜   🞺 🗞 🛍 🏦   😨 🜮   🗄 🖪 😁 🗗 두   <        | \$ \$ \$ |           |          |      |     |                                    |   |
|--------------------------------------------|----------|-----------|----------|------|-----|------------------------------------|---|
| 🛿 Netlist Browser 🔀 🔯 Clock Domains        |          |           |          |      |     | 🗉 🖃 🔪 🌽 📕 😪 🏹                      | - |
| Instance Name                              | Hi       | Cell Type | Clock Do | Core | IOR | Partition                          |   |
| 🖶 const0_fpu_inst[1]                       |          |           |          | ~    |     | /fpu_top                           |   |
| 🗉 🌐 i_fpu                                  |          |           |          | ~    |     | /fpu_top                           |   |
| 🖶 const0_fpu_inst[2]                       |          |           |          | 4    |     | /fpu_top                           |   |
| 🖶 const0_fpu_inst[3]                       |          |           |          | ~    |     | /fpu_top                           |   |
| 🖶 fpu_inst[0]                              |          |           | gclk     | ~    |     | /fpu_top                           |   |
| 🗆 🌐 i_fpu                                  |          |           | gclk     | ~    |     | /fpu_top                           |   |
| 🗉 🌐 cluster_header                         |          |           | gclk     | ~    |     | /fpu_top                           |   |
| 🗆 🌐 fpu_add                                |          |           | gclk     | ~    |     | /fpu_top                           |   |
| 🗉 🌐 fpu_add_ctl                            |          |           | gclk     | ~    |     | /fpu_top                           |   |
| 🗉 🌐 fpu_add_exp_dp                         |          |           | gclk     | ~    |     | /fpu_top                           |   |
| 🗉 🌐 fpu_add_frac_dp                        |          |           | gclk     | ~    |     | /fpu_top                           |   |
| 🖃 🌐 fpu_div                                |          |           | gclk     | ~    |     | /fpu_top                           |   |
| 🗉 🌐 fpu_div_ctl                            |          |           | gclk     | ~    |     | /fpu_top                           |   |
| # 🚦 fpu_div_exp_dp                         |          |           | gclk     | / 🖌  |     | /fpu_top                           |   |
| 🗉 🌐 fpu_div_frac_dp                        |          |           | gclk     | ~    |     | /fpu_top                           |   |
| ✓ div_exp1_expadd1_i                       |          | LUT4      | gclk     | 4    |     | /fpu_top/fpu_inst[0].i_fpu/fpu_div |   |
| ✓ilconst0_RR2                              |          | LUT4      |          | ~    |     | /fpu_top/fpu_inst[0].i_fpu/fpu_div |   |
| 🗆 🌐 fpu_in                                 |          |           | gclk     | ~    |     | /fpu_top                           |   |
| 🗉 🌐 fpu_in_ctl                             |          |           | gclk     | ~    |     | /fpu_top                           |   |
| 🗉 🌐 fpu_in_dp                              |          |           | gclk     | ~    |     | /fpu_top                           |   |
| ✓i1const0_RR2                              |          | LUT4      |          | ~    |     | /fpu_top/fpu_inst[0].i_fpu/fpu_in  |   |
| 🖃 🌐 fpu_mul                                |          |           | gclk     | ~    |     | /fpu_top                           |   |
| 🗉 🌐 fpu_mul_ctl                            |          |           | gclk     | ~    |     | /fpu_top                           |   |
| 🗉 🌐 fpu_mul_exp_dp                         |          |           | gclk     | ~    |     | /fpu_top                           |   |
| fou mul frac do                            |          |           | gclk     | ~    |     | /fpu_top                           |   |
| .fpu_inst[0].i_fpu.fpu_mul.fpu_mul_frac_dp |          |           | gclk     | ~    |     | /fpu_top                           |   |
| ✓i2const0_RR2                              |          | LUT4      |          | ~    |     | /fpu_top/fpu_inst[0].i_fpu/fpu_mul | _ |
| 🗆 🌐 fpu_out                                |          |           | gclk     | ~    |     | /fpu_top                           |   |
| ⊞ fpu_out_ctl                              |          |           | gclk     | ~    |     | /fpu_top                           | _ |
| ⊞  ⊕ fpu_out_dp                            |          |           | gclk     | ~    |     | /fpu_top                           | _ |
| ✓i1const0_RR2                              |          | LUT4      |          | ~    |     | /fpu_top/fpu_inst[0].i_fpu/fpu_out | _ |
| ⊕ test_stub                                |          |           |          | ~    |     | /fpu_top                           | _ |
| ✓ilconst0_RR2                              |          | LUT4      |          | ~    |     | /fpu_top                           |   |
| ✓inq_in2_i[55]                             |          | LUT4      | gclk     | ~    |     | /fpu_top                           | _ |
| ✓inq_in2_i[56]                             |          | LUT4      | gclk     | ~    |     | /fpu_top                           | _ |
| ✓inq_in2_i[57]                             |          | LUT4      | gclk     | ~    |     | /fpu_top                           | _ |
| ✓inq_in2_i[58]                             |          | LUT4      | gclk     | ~    |     | /fpu_top                           | _ |
| ✓inq_in2_i[59]                             |          | LUT4      | gclk     | ~    |     | /fpu_top                           | _ |
| ✓inq_in2_i[60]                             |          | LUT4      | gclk     | ~    |     | /fpu_top                           | _ |
| ✓inq_in2_i[61]                             |          | LUT4      | gclk     | ~    |     | /fpu_top                           | _ |
| ✓inq_in2_i[62]                             |          | LUT4      | gclk     | ~    |     | /fpu_top                           | _ |
| # fpu_inst[1]                              |          |           | gclk     | ~    |     | /fpu_top                           | _ |
| fpu_inst[2]                                |          |           | gclk     | ~    |     | /fpu_top                           | _ |
| #fpu_inst[3]                               |          | IDIN      | gclk     | ~    |     | /fpu_top                           |   |

| Figure 199 • AC | E Netlist | <b>Browser</b> |
|-----------------|-----------|----------------|
|-----------------|-----------|----------------|

### End of the First Pass of ACE Place and Route

• At this point, exit out of ACE if desired.

### (i) Note

ACE can stay in memory and "incremental" runs can be implemented in the same ACE session because ACE recognizes that inputs to the ACE flows have changed, and runs incremental flows appropriately.

## Step 8: Change the RTL (rtl\_V1)

It is at this point where the utility of the Incremental Compile Flow begins to become apparent. The next steps simulate the actions of a product development team in the middle of a design iteration by modifying the RTL for one of the partitions, and then rerunning Synthesis, Prepare, Placement, and Routing (SPP&R).

• First, navigate to the top-level directory of the tutorial project and start Synplify-Pro if it is no longer running. Under Linux, execute:

```
% cd <your work area>/ Speedcore_Incremental_Compile_Reference_Design_RD012
% synplify_pro
```

Under Windows, double-click the Synplify Pro icon.

• This step simulates an RTL change by replacing the source file  $rtl/fpu_mul_ctl.v$  with the version in the directory  $rtl_V1$ . To do this in Synplify Pro, in the Project Files tab, navigate to the Verilog folder and left click the file to be changed to select it by clicking its name, in this case  $fpu_mul_ctl.v$ , and then right-click to bring up popup menu followed by **Change File...** or select **Project**  $\rightarrow$  **Change File**. In the dialog box that appears, use the drop-down box of the Look in field and navigate from the directory rtl to the directory  $rtl_V1$ . Then double-click the file fpu\_mul\_ctl.v, or select it and click **OK**. The old version of the file is then removed from the project and replaced by the modified version. Diff the old and new versions of the file to see the changes:

```
$ diff rtl_V1/fpu_mul_ctl.v rtl
```

(i) Note

A flop has been added to the 5-bit wire mul\_exc\_out.

## Step 9: Recompile the Design in Synplify Pro (rtl\_V1)

• Click **Run** on the Synplify Pro home screen to recompile and remap the design.

#### (i) Note

Runtime is much faster than in the first iteration because only the changed module needs to be recompiled.

## Step 10: Review Synplify Results (rtl\_V1)

### Synplify Pro Log File (rtl\_v1)

Once again, open the Synplify Pro log

file Speedcore\_Incremental\_Compile\_Reference\_Design\_RD012/synplify/rev\_1/

open\_sparc\_fpu\_icf\_demo.srr and search for the section titled "Summary of Compile Points". All of the partitions have a status of "unchanged" except for the partition fpu\_mul\_ctl and its parent partition, which have status "remapped" and a reason of "design changed". The timestamp of the remapped partitions have also been advanced.

| Multiprocessing finished at : Wed   |                 |                |                                            |
|-------------------------------------|-----------------|----------------|--------------------------------------------|
| Multiprocessing took 0h:00m:16s r   | ealtime, Oh:OOn | m:24s cputime  |                                            |
| 70                                  |                 |                |                                            |
| 1 Summary of Compile Points :       |                 |                |                                            |
| 72 ******                           |                 |                |                                            |
| 73 Name                             | Status          | Reason         | Start Time                                 |
| 74<br>75 fpu mul ctl                | Remapped        | Design changed | Wed Dec 20 14:21:11                        |
| 6 fpu in fpu in                     | Unchanged       | Design changed | Wed Dec 20 14:21:11<br>Wed Dec 20 13:05:19 |
| 7 fpu in ctl                        | Unchanged       | -              | Wed Dec 20 13:05:19<br>Wed Dec 20 13:05:20 |
| 78 fpu mul fpu mul                  | Unchanged       | -              | Wed Dec 20 13:05:20<br>Wed Dec 20 13:05:20 |
| 79 fpu mul exp dp fpu mul exp dp    | Unchanged       | -              | Wed Dec 20 13:05:20<br>Wed Dec 20 13:05:27 |
| 50 fpu div fpu div                  | Unchanged       | -              | Wed Dec 20 13:05:27                        |
| fpu div ctl                         | Unchanged       | _              | Wed Dec 20 13:05:30<br>Wed Dec 20 13:05:43 |
| 32 fpu out fpu out                  | Unchanged       | _              | Wed Dec 20 13:05:43<br>Wed Dec 20 13:05:58 |
| 33 fpu out ctl                      | Unchanged       | -              | Wed Dec 20 13:05:55<br>Wed Dec 20 13:06:05 |
| 4 fpu in fpu in 0                   | Unchanged       | _              | Wed Dec 20 13:06:21                        |
| 5 fpu mul fpu mul 0                 | Unchanged       | _              | Wed Dec 20 13:06:25                        |
| 6 fpu mul exp dp fpu mul exp dp 0   | Unchanged       | _              | Wed Dec 20 13:06:27                        |
| fpu div fpu div 0                   | Unchanged       | -              | Wed Dec 20 13:06:35                        |
| 88 fpu out fpu out 0                | Unchanged       | -              | Wed Dec 20 13:06:44                        |
| 39 fpu in fpu in 1                  | Unchanged       | -              | Wed Dec 20 13:06:57                        |
| pu mul fpu mul 1                    | Unchanged       | _              | Wed Dec 20 13:07:04                        |
| fpu mul exp dp fpu mul exp dp 1     | Unchanged       | -              | Wed Dec 20 13:07:05                        |
| 2 fpu div fpu div 1                 | Unchanged       | -              | Wed Dec 20 13:07:13                        |
| 3 fpu out fpu out 1                 | Unchanged       | -              | Wed Dec 20 13:07:30                        |
| 4 fpu in fpu in 2                   | Unchanged       | -              | Wed Dec 20 13:07:32                        |
| 5 fpu mul fpu mul 2                 | Unchanged       | -              | Wed Dec 20 13:07:39                        |
| 6 fpu mul exp dp fpu mul exp dp 2   | Unchanged       | -              | Wed Dec 20 13:07:52                        |
| 7 fpu div fpu div 2                 | Unchanged       | -              | Wed Dec 20 13:08:01                        |
| 8 fpu out fpu out 2                 | Unchanged       | -              | Wed Dec 20 13:08:18                        |
| 9 fpu top                           | Unchanged       | -              | Wed Dec 20 13:05:19                        |
| 0                                   | -               |                |                                            |
| 1 Total number of compile points: 2 | 5               |                |                                            |
| 12                                  |                 |                |                                            |

Figure 200 • Synplify Pro Log File Showing Changed Compile Points

### ACE Partitioning Constraints File (rtl\_V1)

| J |                                                                                                                                                          |
|---|----------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | 1 set partition info -name "/fpu top" -view "fpu top" -timestamp "1513803914" -cp type "hard"                                                            |
|   | 2 set partition info -name "/fpu top/fpu inst[0].i fpu/fpu out/fpu out ctl" -view "fpu out ctl" -timestamp "1513803914" -cp type "locked"                |
| 1 | 3 set partition info -name "/fpu top/fpu inst[0].i fpu/fpu out" -view "fpu out" -timestamp "1513803914" -cp type "locked"                                |
|   | 4 set partition info -name "/fpu top/fpu inst[0].i fpu/fpu div/fpu div ctl" -view "fpu div ctl" -timestamp "1513803914" -cp type "locked"                |
|   | 5 set partition info -name "/fpu top/fpu inst[0].i fpu/fpu div" -view "fpu div" -timestamp "1513803914" -cp type "locked"                                |
|   | 6 set partition info -name "/fpu top/fpu inst[0].i fpu/fpu mul/fpu mul exp dp" -view "fpu mul exp dp" -timestamp "1513803914" -cp type "locked"          |
|   | 7 set partition info -name "/fpu top/fpu inst[0].i fpu/fpu mul/fpu mul ctl" -view "fpu mul ctl" -timestamp "1513808464" -cp type "locked"                |
|   | 8 set partition info -name "/fpu top/fpu inst[0].i fpu/fpu mul" -view "fpu mul" -timestamp "1513803914" -cp type "locked"                                |
|   | 9 set partition info -name "/fpu top/fpu inst[0].i fpu/fpu in/fpu in ctl" -view "fpu in ctl" -timestamp "1513803914" -cp type "locked"                   |
| 1 | 10 set partition info -name "/fpu top/fpu inst[0].i fpu/fpu in" -view "fpu in" -timestamp "1513803914" -cp type "locked"                                 |
| 1 | 11 set partition info -name "/fpu top/fpu inst[1].i fpu/fpu out/fpu out ctl" -view "fpu out ctl" -timestamp "1513803914" -cp type "locked"               |
| 1 | 12 set partition info -name "/fpu top/fpu inst[1].i fpu/fpu out" -view "fpu out" -timestamp "1513803914" -cp type "locked"                               |
|   | 13 set partition info -name "/fpu top/fpu inst[1].i fpu/fpu div/fpu div ctl" -view "fpu div ctl" -timestamp "1513803914" -cp type "locked"               |
|   | 14 set partition info -name "/fpu top/fpu inst[1].i fpu/fpu div" -view "fpu div" -timestamp "1513803914" -cp type "locked"                               |
| 1 | 15 set partition info -name "/fpu top/fpu inst[1].i fpu/fpu mul/fpu mul exp dp" -view "fpu mul exp dp" -timestamp "1513803914" -cp type "locked"         |
|   | 16 set partition info -name "/fpu top/fpu inst[1].i fpu/fpu mul/fpu mul ctl" -view "fpu mul ctl" -timestamp "1513808464" -cp type "locked"               |
| 1 | 17 set partition info -name "/fpu top/fpu inst[1].i fpu/fpu mul" -view "fpu mul" -timestamp "1513803914" -cp type "locked"                               |
| 1 | 18 set partition info -name "/fpu top/fpu inst[1].i fpu/fpu in/fpu in ctl" -view "fpu in ctl" -timestamp "15]3803914" -cp type "locked"                  |
| 1 | 19 set partition info -name "/fpu top/fpu inst[1].i fpu/fpu in" -view "fpu in" -timestamp "1513803914" -cp type "locked"                                 |
|   | 20 set partition info -name "/fpu top/fpu inst[2].i fpu/fpu out/fpu out ctl" -view "fpu out ctl" -timestamp "1513803914" -cp type "locked"               |
| 2 | 21 set partition info -name "/fpu top/fpu inst[2].i fpu/fpu out" -view "fpu out" -timestamp "1513803914" -cp type "locked"                               |
| 2 | 22 set partition info -name "/fpu top/fpu inst[2].i fpu/fpu div/fpu div ctl" -view "fpu div ctl" -timestamp "1513803914" -cp type "locked"               |
| 2 | 23 set partition info -name "/fpu top/fpu inst[2].i fpu/fpu div" -view "fpu div" -timestamp "1513803914" -cp type "locked"                               |
| 2 | 24 set partition info -name "/fpu top/fpu inst[2].i fpu/fpu mul/fpu mul exp dp" -view "fpu mul exp dp" -timestamp "1513803914" -cp type "locked"         |
| 2 | 25 set partition info -name "/fpu top/fpu inst[2].i fpu/fpu mul/fpu mul ctl" -view "fpu mul ctl" -timestamp "1513808464" -cp type "locked"               |
|   | 26 set_partition_info -name "/fpu_top/fpu_inst[2].i_fpu/fpu_mul" -view "fpu_mul" -timestamp "1513803914" -cp_type "locked"                               |
| 2 | 27 set partition info -name "/fpu top/fpu inst[2].i fpu/fpu in/fpu in ctl" -view "fpu in ctl" -timestamp "1513803914" -cp type "locked"                  |
| 2 | 28 set_partition_info -name "/fpu_top/fpu_inst[2].i_fpu/fpu_in" -view "fpu_in" -timestamp "1513803914" -cp_type "locked"                                 |
| 2 | 29 set_partition_info -name "/fpu_top/fpu_inst[3].i_fpu/fpu_out/fpu_out_ctl" -view "fpu_out_ctl" -timestamp "1513803914" -cp_type "locked"               |
| 3 | 30 set_partition_info -name "/fpu_top/fpu_inst[3].i_fpu/fpu_out" -view "fpu_out" -timestamp "1513803914" -cp_type "locked"                               |
| 3 | 31 set partition info -name "/fpu top/fpu inst[3].i fpu/fpu div/fpu div ctl" -view "fpu div ctl" -timestamp "1513803914" -cp type "locked"               |
|   | 32 set_partition_info -name "/fpu_top/fpu_inst[3].i_fpu/fpu_div" -view "fpu_div" -timestamp "1513803914" -cp_type "locked"                               |
|   | 33 set_partition_info -name "/fpu_top/fpu_inst[3].i_fpu/fpu_mul/fpu_mul_exp_dp" -view "fpu_mul_exp_dp" -timestamp "1513803914" -cp_type "locked"         |
|   | 34 set_partition_info -name "/fpu_top/fpu_inst[3].i_fpu/fpu_mul/fpu_mul_ctl" -view "fpu_mul_ctl" -timestamp " <mark>1513808464"</mark> -cp_type "locked" |
|   | 35 set_partition_info -name "/fpu_top/fpu_inst[3].i_fpu/fpu_mul" -view "fpu_mul" -timestamp "1513803914" -cp_type "locked"                               |
|   | 36 set_partition_info -name "/fpu_top/fpu_inst[3].i_fpu/fpu_in/fpu_in_ctl" -view "fpu_in_ctl" -timestamp "15]3803914" -cp_type "locked"                  |
| 3 | 37 set_partition_info -name "/fpu_top/fpu_inst[3].i_fpu/fpu_in" -view "fpu_in" -timestamp "1513803914" -cp_type "locked"                                 |
|   |                                                                                                                                                          |
|   |                                                                                                                                                          |
|   | Ln 25 Col 63 Total 37 Ovr. Bi                                                                                                                            |

Figure 201 • ACE Partitioning Constraints File: open\_sparc\_fpu\_icf\_demo\_partition.prt

• Use File → Close to close Synplify Pro, and click Save changes to project proj\_1.

## Step 11: Recompile the Design in ACE (rtl\_V1)

• If ACE was exited earlier, navigate to the same ace directory as before, and start ACE again. Otherwise, continue on from the current ACE session.

Ensure that this tutorial project is the active project. Again, uncheck the Run Sign-off Timing Analysis and Generate Bitstream flow steps to save some runtime.

• Click the green triangle ( ) in the upper-right corner of the Flow view to rerun the Prepare, Placement, and Routing flow.

#### (i) Note

The runtime of the flow is also significantly reduced over the first non-incremental compile.

In this second pass, ACE reads the new open\_sparc\_fpu\_icf\_demo.vm netlist file and the new open\_sparc\_fpu\_icf\_demo\_partition.prt constraints file from the synplify directory. During the run\_prepare flow step, ACE then executes an operation called Tear & Stitch. Each partition which has not been recompiled during synthesis is *torn* out of the database, and a copy from the previous pass is *stitched* back in. The copy from the previous run contains the complete set of placement and routing data. The placement of all stitched

instances are locked, and all routes are marked as preroutes to prevent their modification when the remainder of the netlist is placed and routed.

## Step 12: Review ACE Results (rtl\_V1)

### Partition Report (rtl\_V1)

• Maximize the Partition Report tab in the Editor Area of the Projects perspective. In the summary section, only 4 of the 37 partitions (10.81%) were recompiled by ACE, resulting in 3.05% of the instances being re-placed and 3.33% of the nets being rerouted. Also note in the Details section that only 4 fpu\_mul\_ctl partitions were recompiled, and their new timestamps are displayed. The counts of instances and nets in those partitions have changed by a small amount.

| 📓 👜   🎺 🤝 🤞                                                                                          | -                                                              |                    |             |          |          | - 6-11 C                             |        |       |        | la a b' |        |         |        |      | ) They' |         |        | . the set | 6 m     |           | Dentitien T  |                           |                            |                          |                              |     |
|------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|--------------------|-------------|----------|----------|--------------------------------------|--------|-------|--------|---------|--------|---------|--------|------|---------|---------|--------|-----------|---------|-----------|--------------|---------------------------|----------------------------|--------------------------|------------------------------|-----|
| Clock/Reset Rep                                                                                      | ort'— fpu_to                                                   | p 📔 Utili:         | zation Rep  | oort - I | Routed   | l — fpu_top                          |        | Pow   | er Dis | ipatio  | in Rep | ort — f | pu_top |      | Timin   | g Repor | t - Ro | uted –    | - fpu_t | op 📄      | Partition Re | eport — fi                | pu_top 🛙                   |                          |                              |     |
| ACE Achronix C<br>Design: proj_1 - im<br>Device: AC16tSC0<br>Generated on Thu<br>Host: fe23.achronic | D Environment<br>b[_1 - fpu_top<br>IHI01C<br>Dec 21 06:06:34 F |                    | Build 11095 | 56 Da    | te 2017- | 12-07 18:46                          |        |       |        |         |        |         |        |      |         |         |        |           |         |           |              |                           |                            |                          |                              |     |
| • Number of part<br>• Number of inst<br>• Number of nets<br>• Number of nets                         | ances: 53447 (163                                              | 32 re-compiled, 3. | 05%)        |          |          |                                      |        |       |        |         |        |         |        |      |         |         |        |           |         |           |              |                           |                            |                          |                              |     |
| Partition Name                                                                                       | Module Name                                                    | Re-Compiled?       | Imported?   | Top?     | Leaf?    | Timestamp                            | Туре   | Nets  | Insts  | LUTS    | Flops  | MUX4s   | MUX8s  | ALUs | LRAMs   | BRAMs   | DSPs   | IPINs     | OPINs   | CLK_IPINs | CLK_OPINs    | Boundary<br>Input<br>Nets | Boundary<br>Output<br>Nets | Registered<br>Input Nets | Registered<br>Output<br>Nets | Col |
| /fpu_top<br>/fpu_inst[0].i_tpu<br>/fpu_mul<br>/fpu_mul_ctl                                           | tpu_mul_ctl                                                    | Yes                | No          | No       | Yes      | Wed 20<br>Dec 2017<br>02:21:04<br>PM | Locked | 552   | 408    | 218     | 188    | 0       | 0      | 2    | o       | 0       | 0      | 0         | 0       | 0         | 0            | 133                       | 78                         | 3                        | 7                            | 1   |
| Лрu_top<br>Лрu_inst[1].i_fpu<br>Лрu_mul<br>Лрu_mul_ctl                                               | tpu_mul_ctl                                                    | Yes                | No          | No       | Yes      | Wed 20<br>Dec 2017<br>02:21:04<br>PM | Locked | 552   | 408    | 218     | 188    | 0       | 0      | 2    | 0       | 0       | 0      | 0         | 0       | 0         | 0            | 133                       | 78                         | 3                        | 7                            | 1   |
| /fpu_top<br>/fpu_inst[2].i_fpu<br>/fpu_mul<br>/fpu_mul_ctl                                           | fpu_mul_ctl                                                    | Yes                | No          | No       | Yes      | Wed 20<br>Dec 2017<br>02:21:04<br>PM | Locked | 552   | 408    | 218     | 188    | 0       | o      | 2    | o       | o       | 0      | o         | 0       | 0         | 0            | 133                       | 78                         | 3                        | 7                            | 1   |
| Лри_top<br>Лри_inst[3].i_fpu<br>Лри_mul<br>Лри_mul_ctl                                               | fpu_mul_ctl                                                    | Yes                | No          | No       | Yes      | Wed 20<br>Dec 2017<br>02:21:04<br>PM | Locked | 552   | 408    | 218     | 188    | 0       | o      | 2    | o       | o       | 0      | 0         | 0       | 0         | 0            | 133                       | 78                         | 3                        | 7                            | 1   |
| /fpu_top                                                                                             | fpu_top                                                        | No                 | No          | Yes      | No       | Wed 20<br>Dec 2017<br>01:05:14<br>PM | Hard   | 24704 | 21254  | 13675   | 6426   | 154     | 0      | 308  | 0       | o       | 0      | 536       | 154     | 1         | 0            | 0                         | 0                          | 0                        | 0                            | 0   |
| /fpu_top<br>/fpu_inst[2].i_fpu<br>/fpu_mul                                                           | fpu_mul                                                        | No                 | No          | No       | No       | Wed 20<br>Dec 2017<br>01:05:14<br>PM | Locked | 4939  | 3683   | 2833    | 772    | 0       | 0      | 69   | 0       | 0       | 9      | 0         | 0       | 0         | 0            | 113                       | 53                         | 1                        | 0                            | 0   |
| /fpu_top<br>/fpu_inst(3).i_fpu<br>/fpu_mul                                                           | fpu_mul                                                        | No                 | No          | No       | No       | Wed 20<br>Dec 2017<br>01:05:14<br>PM | Locked | 4939  | 3683   | 2833    | 772    | 0       | 0      | 69   | 0       | 0       | 9      | 0         | 0       | 0         | 0            | 113                       | 53                         | 1                        | 0                            | 0   |
| /fpu_top<br>/fpu_inst[1].i_fpu<br>/fpu_mul                                                           | fpu_mul                                                        | No                 | No          | No       | No       | Wed 20<br>Dec 2017<br>01:05:14<br>PM | Locked | 4898  | 3642   | 2792    | 772    | 0       | 0      | 69   | 0       | 0       | 9      | 0         | 0       | 0         | 0            | 113                       | 53                         | 1                        | 0                            | 0   |
| /fpu_top<br>/fpu_inst[0].i_fpu<br>/fpu_mul                                                           | tpu_mul                                                        | No                 | No          | No       | No       | Wed 20<br>Dec 2017<br>01:05:14<br>PM | Locked | 4868  | 3612   | 2762    | 772    | 0       | 0      | 69   | o       | 0       | 9      | 0         | 0       | 0         | 0            | 113                       | 53                         | 1                        | 0                            | 0   |
| /fpu_top                                                                                             | tpu_div                                                        | No                 | No          | No       | No       | Wed 20<br>Dec 2017                   | Locked |       | 1849   | 1285    | 542    | 0       | 0      | 22   | 0       | 0       | 0      | 0         | 0       | 0         | 0            | 129                       | 65                         | 1                        | 0                            |     |

Figure 202 • ACE Partition Report After the rtl\_V1 Incremental Compile Iteration

### Floorplanner View (rtl\_V1)

• Switch to the ( ) Floorplanner perspective. In the Floorplanner view, compared to figure above (see figure 197) from the first iteration, about 3% fewer instances are now drawn with a locked fill color (dark yellow by default).

The locked placement state is just one of several potential placement states (see Instance States (page 262)) that an instance can have when painted in the Floorplanner. This locked placement state is somewhat similar in concept to the fixed placement state. (Instances with fixed placement status, shown in the Floorplanner with a light yellow fill color by default, are instances with user-assigned placement constraints, usually defined in a .pdc file. These fixed

instances are not allowed to be moved from their constrained placements during the flow.) The locked placement state indicates instances that are locked in place because they are in a partition that was not recompiled. Only instances with the default (or soft) placement state (light-grey fill color by default) were allowed to have their placement changed during the flow.

✓ The visibility of the instance locked placement state and the associated locked fill color can be chosen within the ACE GUI preferences. To see/edit these, select Window → Preferences → Floorplanner View Colors. In particular, ensure the Instances → Show Locked Color on Instances with Locked Placement box is checked, and that the Locked Instances View Color is set to the desired color (dark yellow by default).



### Figure 203 • ACE Floorplanner Perspective After the rtl\_V1 Incremental Compile Iteration

• To get a feel for the amount of re-routing that was required, select (add to the ACE Selection Set) the instances in the partitions that were recompiled and then view the flylines representing the nets for those instances. To do this, check the **Selected Instance Flylines** box in the Floorplanner view fly-out palette. Then in the Partitions view, choose the rows for the partitions that were recompiled, and click (\*) **Add Instances to Selection** in the Partitions View toolbar. Blue flylines are drawn for the nets of the selected instances (or rather for the first 200 selected instances, since the selection set contains more than 200 objects). In the **Selection View** (page 137) click the gold left-arrow (\*)

and right-arrow ( ♣) buttons in the view header to cycle visibility between different subsets of 200 of the selection set instances at a time.

#### (i) Note

There are many more than 200 nets that are actually re-routed. However, by using the selection set to filter the visible connectivity in this manner, the amount of visible change to the design has been minimized to just the instances of the module that was changed.

This information is helpful in understanding the effect of any placement and routing changes during the second pass. Instances in a failing critical path with wayward placement could indicate that changes in the RTL were too extensive for effective incremental recompilation. This situation can occur when one of the partitions grows significantly in size and no longer fits in the area between locked neighboring partitions, for example. The placement for this recompiled partition may be squeezed into an undesirable aspect ratio, forcing long routing detours. In situations such as this, it may be best to force the entire design to be recompiled by enabling **Force Recompile on Next Run** for all of the partitions in the Partitions View.



Figure 204 • ACE Floorplanner Perspective with Selected Instance Flylines (rtl\_V1)

### Partitions View (rtl\_V1)

In the Partitions View (page 111) of the ( □) Floorplanner Perspective, note that only 4 of the 37 partitions have a check mark in the Re-Compiled column.

Click () Deselect all in the Selection view to remove the routing flylines, and then click () Auto-Highlight Partitions in the Partitions View to observe any changes in the placement of the changed partitions. Unchanged

partitions can also be manually unhighlighted to only see (highlight) those that were not re-placed. This technique can help in understanding the effectiveness of incremental compilation on the design.



Figure 205 • Highlighting Partitions in ACE After Second Incremental Compile Iteration

## Step 13: Additional Incremental Iterations

• Steps 8–12 can be rerun with additional RTL changes if desired. This tutorial design contains additional directories with additional RTL change examples. Or modify the existing RTL files by adding or deleting module pins, add or remove partitions from the .fdc file, or rename module instances, to further explore the incremental compile flow.

| Directory | Changes                                                                          |
|-----------|----------------------------------------------------------------------------------|
| rtl_V1    | Flopped the signal mul_exc_out in fpu_mul_ctl.v                                  |
| rti V2    | Reverts the changes from rtl_V1, adds a new 6-bit counter in place of a constant |

|  | Table 148 | Additional | <b>Tutorial</b> | <b>Examples</b> |
|--|-----------|------------|-----------------|-----------------|
|--|-----------|------------|-----------------|-----------------|

| Directory | Changes                                                      |
|-----------|--------------------------------------------------------------|
| rtl_V3    | Modifies the partition fpu_div_ctl by adding an enable check |
| rtl_V4    | Modifies the top-level partition fpu.v by inverting one net  |

## Step 14: Review ACE Results (rtl\_V2)

After rerunning the synplify\_pro and ace flows, review the perturbation of the design in ace by looking at the Partition Report and the Floorplanner views with and without flylines.

### Partition Report (rtl\_V2)

• Maximize the Partition Report tab in the Editor Area of the Projects perspective. In the summary section, only 4 of the 37 partitions (10.81%) were recompiled by ACE, resulting in 3.12% of the instances being re-placed and 3.54% of the nets being rerouted. Also note in the Details section that only 4 fpu\_mul\_ctl partitions were recompiled, and their new timestamps are displayed. The counts of instances and nets in those partitions have changed by a small amount.

|                                                                                                  | 5 0 0 v                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                          |              |             |       |          |                                      |        |       |         |         |       |          |        |      |         |         |         |        |         |           |              |                           |                            |                          |                              |   |
|--------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|--------------|-------------|-------|----------|--------------------------------------|--------|-------|---------|---------|-------|----------|--------|------|---------|---------|---------|--------|---------|-----------|--------------|---------------------------|----------------------------|--------------------------|------------------------------|---|
| CI                                                                                               | ock/Reset Rep                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | port — fpu_to                                                            | p 📄 Utili    | zation Rep  | ort - | Routed   | I — fpu_top                          |        | Pow   | er Diss | sipatio | n Rep | ort — fi | pu_top | 0    | ) Timin | g Repor | t - Rou | ited - | - fpu_t | op 🗈      | Partition Re | eport — fp                | ou_top 🛿                   |                          |                              | _ |
| A<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C | Activition Re<br>Activition Re<br>Activition Research<br>Activition Research | AD Environment<br>sl_1 - fpu_top<br>IHI01C<br>Dec 21 07:45:10 F<br>Jocal | PST 2017     | Build 11095 | 96 Dr | te 2017- | 12-07 18:46                          |        |       |         |         |       |          |        |      |         |         |         |        |         |           |              |                           |                            |                          |                              |   |
|                                                                                                  | Number of inst     Number of nets ails                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                          |              | 12%)        |       |          |                                      |        |       |         |         |       |          |        |      |         |         |         |        |         |           |              |                           |                            |                          |                              |   |
|                                                                                                  | Partition Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Module Name                                                              | Re-Compiled? | Imported?   | Тор?  | Leaf?    | Timestamp                            | Туре   | Nets  | Insts   | LUTS    | Flops | MUX4s    | MUX8s  | ALUS | LRAMs   | BRAMs   | DSPs    | IPINs  | OPINs   | CLK_IPINs | CLK_OPINs    | Boundary<br>Input<br>Nets | Boundary<br>Output<br>Nets | Registered<br>Input Nets | Registered<br>Output<br>Nets | C |
|                                                                                                  | Npu_top<br>Npu_inst(0),i_tpu<br>Npu_mul<br>Npu_mul_ctl                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | fpu_mul_cd                                                               | Yes          | No          | No    | Yes      | Thu 21 Dec<br>2017<br>07:38:27<br>AM | Locked | 587   | 417     | 221     | 190   | 0        | 0      | 6    | 0       | 0       | 0       | 0      | 0       | 0         | 0            | 133                       | 78                         | 3                        | 7                            | 1 |
|                                                                                                  | Mpu_top<br>Mpu_inst[1].i_tpu<br>Mpu_mul<br>Mpu_mul_ctl                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | fpu_mul_ctl                                                              | Yes          | No          | No    | Yes      | Thu 21 Dec<br>2017<br>07:38:27<br>AM | Locked | 587   | 417     | 221     | 190   | 0        | 0      | 6    | o       | 0       | 0       | 0      | 0       | 0         | 0            | 133                       | 78                         | 3                        | 7                            | 1 |
|                                                                                                  | Mpu_top<br>Mpu_inst[2].i_tpu<br>Mpu_mul<br>Mpu_mul_ctl                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | fpu_mul_ctl                                                              | Yes          | No          | No    | Yes      | Thu 21 Dec<br>2017<br>07:38:27<br>AM | Locked | 587   | 417     | 221     | 190   | 0        | 0      | 6    | 0       | 0       | 0       | 0      | 0       | 0         | 0            | 133                       | 78                         | 3                        | 7                            | 1 |
|                                                                                                  | Npu_top<br>Npu_inst[3],i_tpu<br>Npu_mul<br>Npu_mul_ctl                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | fpu_mul_ctl                                                              | Yes          | No          | No    | Yes      | Thu 21 Dec<br>2017<br>07:38:27<br>AM | Locked | 587   | 417     | 221     | 190   | 0        | 0      | 6    | 0       | 0       | 0       | 0      | 0       | 0         | 0            | 133                       | 78                         | 3                        | 7                            | 1 |
|                                                                                                  | Mpu_top                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | fpu_top                                                                  | No           | No          | Yes   | No       | Wed 20<br>Dec 2017<br>01:05:14<br>PM | Hard   | 24704 | 21254   | 13675   | 6426  | 154      | 0      | 308  | 0       | 0       | 0       | 536    | 154     | 1         | 0            | 0                         | 0                          | 0                        | 0                            | 0 |
| - P                                                                                              | Npu_top<br>Npu_inst(2).i_tpu<br>Npu_mul                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | fpu_mul                                                                  | No           | No          | No    | No       | Wed 20<br>Dec 2017<br>01:05:14<br>PM | Locked | 4939  | 3683    | 2833    | 772   | 0        | 0      | 69   | o       | 0       | 9       | 0      | 0       | 0         | 0            | 113                       | 53                         | 1                        | 0                            | 0 |
| - D                                                                                              | Mpu_top<br>Mpu_inst[3].i_tpu<br>Mpu_mul                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | fpu_mul                                                                  | No           | No          | No    | No       | Wed 20<br>Dec 2017<br>01:05:14<br>PM | Locked | 4939  | 3683    | 2833    | 772   | 0        | 0      | 69   | 0       | 0       | 9       | 0      | 0       | 0         | 0            | 113                       | 53                         | 1                        | 0                            | 0 |
| - IX                                                                                             | Npu_top<br>Npu_inst[1].i_tpu<br>Npu_mul                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | fpu_mul                                                                  | No           | No          | No    | No       | Wed 20<br>Dec 2017<br>01:05:14<br>PM | Locked | 4898  | 3642    | 2792    | 772   | 0        | 0      | 69   | 0       | 0       | 9       | 0      | 0       | 0         | 0            | 113                       | 53                         | 1                        | 0                            | 0 |
| - P                                                                                              | Npu_top<br>Npu_inst(0).i_tpu<br>Npu_mul                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | fpu_mul                                                                  | No           | No          | No    | No       | Wed 20<br>Dec 2017<br>01:05:14<br>PM | Locked | 4868  | 3612    | 2762    | 772   | 0        | 0      | 69   | o       | 0       | 9       | 0      | 0       | 0         | 0            | 113                       | 53                         | 1                        | 0                            | 0 |
| - 14                                                                                             | Mpu_top<br>Mpu_inst[0].i_tpu<br>Mpu_div                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | fpu_div                                                                  | No           | No          | No    | No       | Wed 20<br>Dec 2017<br>01:05:14<br>PM | Locked | 2141  | 1849    | 1285    | 542   | 0        | 0      | 22   | 0       | 0       | 0       | 0      | 0       | 0         | 0            | 129                       | 65                         | 1                        | 0                            | 0 |
|                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                          |              |             |       |          | Wed 20                               |        |       |         |         |       |          |        |      |         |         |         |        |         |           |              |                           |                            |                          |                              |   |

Figure 206 • ACE Partition Report After the rtl\_V2 Incremental Compile Iteration

### Floorplanner View (rtl\_V2)



Figure 207 • ACE Floorplanner Perspective After rtl\_V2 Incremental Compile Iteration



Figure 208 • ACE Floorplanner Perspective with Selected Instance Flylines (rtl\_V2)

# Step 15: Review ACE Results (rtl\_V3)

After rerunning the synplify\_pro and ace flows, review the perturbation of the design in ace by looking at the Partition Report and the Floorplanner views with and without flylines.

### Partition Report (rtl\_V3)

| 🗟 👜 ] 🞺 🗞 🚽                                                                                             | 1                                                               | 🌮 📑 😫             | 8 6º 🖓     | ¢ 9     | > 🖑 -    |                                      |         |       |          |         |       |       |       |       |          |          |       |        |       |           |             |                           |                            |                          |                              |   |
|---------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|-------------------|------------|---------|----------|--------------------------------------|---------|-------|----------|---------|-------|-------|-------|-------|----------|----------|-------|--------|-------|-----------|-------------|---------------------------|----------------------------|--------------------------|------------------------------|---|
| Partition Report                                                                                        | t — fpu_top 8                                                   | Clock/R           | eset Repo  | rt — fj | ou_top   | 🔒 Ut                                 | lizatio | n Rep | ort - Ra | outed - | – fpu | top   | 📄 Po  | wer D | issipati | ion Repo | ort — | fpu_to | op    | 🗋 Timing  | Report - Ro | outed — f                 | pu_top                     |                          |                              |   |
| ACE Activonic C.<br>Design: proj_1 - im<br>Device: AC16tSC0<br>Generated on Thu<br>Host: fe23.activnoib | AD Environment -<br>p[_1 - fpu_top<br>1HI01C<br>Dec 21 08:48:05 |                   | Build 1109 | 56 Da   | te 2017- | 12-07 18:46                          |         |       |          |         |       |       |       |       |          |          |       |        |       |           |             |                           |                            |                          |                              |   |
| Summary                                                                                                 |                                                                 |                   |            |         |          |                                      |         |       |          |         |       |       |       |       |          |          |       |        |       |           |             |                           |                            |                          |                              |   |
| Number of part     Number of inst     Number of nets Details                                            | ances: 53479 (15                                                | 04 re-compiled 2. | 81%)       |         |          |                                      |         |       |          |         |       |       |       |       |          |          |       |        |       |           |             |                           |                            |                          |                              |   |
| Partition Name                                                                                          | Module Name                                                     | Re-Compiled?      | Imported?  | Top?    | Leaf?    | Timestamp                            | Туре    | Nets  | Insts    | LUTs    | Flops | MUX4s | MUX8s | ALUs  | LRAMs    | BRAMs    | DSPs  | IPINs  | OPINs | CLK_IPINs | CLK_OPINs   | Boundary<br>Input<br>Nets | Boundary<br>Output<br>Nets | Registered<br>Input Nets | Registered<br>Output<br>Nets | C |
| /fpu_top<br>/fpu_inst[0],i_fpu<br>/fpu_div<br>/fpu_div_ctl                                              | tpu_div_ctl                                                     | Yes               | No         | No      | Yes      | Thu 21 Dec<br>2017<br>08:32:32<br>AM | Locked  | 415   | 330      | 209     | 119   | 0     | o     | 2     | o        | 0        | 0     | 0      | 0     | 0         | 0           | 73                        | 80                         | 3                        | 0                            | 0 |
| /fpu_top<br>/fpu_inst[1].i_fpu<br>/fpu_div<br>/fpu_div_cti                                              | tpu_div_ctl                                                     | Yes               | No         | No      | Yes      | Thu 21 Dec<br>2017<br>08:32:32<br>AM | Locked  | 415   | 330      | 209     | 119   | o     | 0     | 2     | 0        | 0        | 0     | 0      | 0     | 0         | 0           | 73                        | 80                         | 3                        | 0                            | 0 |
| /tpu_top<br>/tpu_inst[2].i_tpu<br>/tpu_div<br>/tpu_div_ctl                                              | tpu_div_ctl                                                     | Yes               | No         | No      | Yes      | Thu 21 Dec<br>2017<br>08:32:32<br>AM | Locked  | 415   | 330      | 209     | 119   | 0     | 0     | 2     | 0        | 0        | 0     | 0      | 0     | 0         | 0           | 73                        | 80                         | 3                        | 0                            | 0 |
| /fpu_top<br>/fpu_inst[3],i_fpu<br>/fpu_div<br>/fpu_div_cti                                              | tpu_div_ctl                                                     | Yes               | No         | No      | Yes      | Thu 21 Dec<br>2017<br>08:32:32<br>AM | Locked  | 415   | 330      | 209     | 119   | 0     | o     | 2     | o        | 0        | 0     | 0      | 0     | 0         | 0           | 73                        | 80                         | 3                        | 0                            | 0 |
| /fpu_top<br>/fpu_inst(0).i_fpu<br>/fpu_out<br>/fpu_out_cti                                              | tpu_out_ctl                                                     | Yes               | No         | No      | Yes      | Thu 21 Dec<br>2017<br>08:32:32<br>AM | Locked  | 82    | 46       | 28      | 18    | 0     | 0     | 0     | o        | 0        | 0     | 0      | 0     | 0         | 0           | 36                        | 17                         | 3                        | 0                            | 0 |
| /fpu_top<br>/fpu_inst[1].i_fpu<br>/fpu_out<br>/fpu_out_ctl                                              | tpu_out_ctl                                                     | Yes               | No         | No      | Yes      | Thu 21 Dec<br>2017<br>08:32:32<br>AM | Locked  | 82    | 46       | 28      | 18    | 0     | 0     | 0     | 0        | 0        | 0     | 0      | 0     | 0         | 0           | 36                        | 17                         | 3                        | 0                            | 0 |
| /fpu_top<br>/fpu_inst[2],i_fpu<br>/fpu_out<br>/fpu_out_ctl                                              | tpu_out_ctl                                                     | Yes               | No         | No      | Yes      | Thu 21 Dec<br>2017<br>08:32:32<br>AM | Locked  | 82    | 46       | 28      | 18    | 0     | 0     | 0     | 0        | 0        | 0     | 0      | 0     | 0         | 0           | 36                        | 17                         | 3                        | 0                            | 0 |
| /fpu_top<br>/fpu_inst[3].i_fpu<br>/fpu_out<br>/fpu_out_ctl                                              | tpu_out_ctl                                                     | Yes               | No         | No      | Yes      | Thu 21 Dec<br>2017<br>08:32:32<br>AM | Locked  | 82    | 46       | 28      | 18    | 0     | o     | 0     | o        | 0        | 0     | 0      | 0     | 0         | 0           | 36                        | 17                         | 3                        | 0                            | 0 |
| Лри_top                                                                                                 | fpu_top                                                         | No                | No         | Yes     | No       | Wed 20<br>Dec 2017<br>01:05:14<br>PM | Hard    | 24704 | 21254    | 13675   | 6426  | 154   | 0     | 308   | 0        | 0        | 0     | 536    | 154   | 1         | 0           | 0                         | 0                          | 0                        | 0                            | 0 |
|                                                                                                         |                                                                 | No                | No         | No      | No       | Wed 20<br>Dec 2017                   |         | 4939  | 3683     | 2833    | 772   | 0     | 0     | 69    | 0        |          |       | 0      | 0     | 0         | 0           | 113                       | 53                         | 1                        | 0                            |   |

Figure 209 • ACE Partition Report After the rtl\_V3 Incremental Compile Iteration

### Floorplanner View (rtl\_V3)



Figure 210 • ACE Floorplanner Perspective After rtl\_V3 Incremental Compile Iteration



Figure 211 • ACE Floorplanner Perspective with Selected Instance Flylines (rtl\_V3)

# Step 16: Review ACE Results (rtl\_V4)

After rerunning the synplify\_pro and ACE flows, review the perturbation of the design in ACE by looking at the Partition Report and the Floorplanner views with and without flylines.

### Partition Report (rtl\_V4)

| 🖥 👜   🗇 👒                                                 | * 🗈 🗴 📀                                                               | 🌮 🖪 🖻               | 8 🗗 🥪 🛛     | (p) c    | > &      |                                      |          |       |        |         |       |         |        |      |       |         |        |        |         |           |             |               |                |                          |                |     |
|-----------------------------------------------------------|-----------------------------------------------------------------------|---------------------|-------------|----------|----------|--------------------------------------|----------|-------|--------|---------|-------|---------|--------|------|-------|---------|--------|--------|---------|-----------|-------------|---------------|----------------|--------------------------|----------------|-----|
| Clock/Reset I                                             | Report — fpu_to                                                       | op 🔒 Utili          | ization Rep | oort - I | Routed   | — fpu_top                            | <b>b</b> | Pow   | er Dis | sipatio | n Rep | ort — f | pu_top |      | Timin | g Repor | t - Ro | uted - | - fpu_1 | top 🔒     | Partition R | eport — f     | pu_top 83      |                          |                |     |
| Partition                                                 | Report                                                                |                     |             |          |          |                                      |          |       |        |         |       |         |        |      |       |         |        |        |         |           |             |               |                |                          |                |     |
| Design: proj_1 -<br>Device: AC16tS                        | hu Dec 21 09:37:43                                                    |                     | Build 1109  | 56 Da    | te 2017- | 12-07 18:46                          |          |       |        |         |       |         |        |      |       |         |        |        |         |           |             |               |                |                          |                |     |
| Summary                                                   |                                                                       |                     |             |          |          |                                      |          |       |        |         |       |         |        |      |       |         |        |        |         |           |             |               |                |                          |                |     |
| <ul> <li>Number of i</li> </ul>                           | artitions: 37 (4 re-or<br>nstances: 53479 (18<br>nets: 66381 (328 re- | 54 re-compiled, 0.3 | 3496)       |          |          |                                      |          |       |        |         |       |         |        |      |       |         |        |        |         |           |             |               |                |                          |                |     |
| Details                                                   |                                                                       |                     |             |          |          |                                      |          |       |        |         |       |         |        |      |       |         |        |        |         |           |             | Boundary      | Boundary       |                          | Registered     | ale |
| Partition Nan                                             | Module Name                                                           | Re-Compiled?        | Imported?   | Тор?     | Leaf?    | Timestamp                            | Туре     | Nets  | Insts  | LUTS    | Flops | MUX4s   | MUX8s  | ALUs | LRAMs | BRAMs   | DSPs   | IPINs  | OPINs   | CLK_IPINs | CLK_OPINs   | Input<br>Nets | Output<br>Nets | Registered<br>Input Nets | Output<br>Nets |     |
| /fpu_top<br>/fpu_inst[0].i_fp<br>/fpu_out<br>/fpu_out_ctl | <sup>U</sup> tpu_out_ctl                                              | Yes                 | No          | No       | Yes      | Thu 21 Dec<br>2017<br>09:30:41<br>AM | Locked   | 82    | 45     | 28      | 18    | o       | 0      | 0    | 0     | 0       | 0      | 0      | 0       | 0         | 0           | 36            | 17             | 3                        | 0              |     |
| /fpu_top<br>/fpu_inst[1].i_fp<br>/fpu_out<br>/fpu_out_ctl | u tpu_out_cti                                                         | Yes                 | No          | No       | Yes      | Thu 21 Dec<br>2017<br>09:30:41<br>AM | Locked   | 82    | 46     | 28      | 18    | o       | 0      | 0    | 0     | 0       | 0      | 0      | 0       | 0         | 0           | 36            | 17             | 3                        | 0              |     |
| /fpu_top<br>/fpu_inst[2].i_fp<br>/fpu_out<br>/fpu_out_ctl | <sup>u</sup> tpu_out_ctl                                              | Yes                 | No          | No       | Yes      | Thu 21 Dec<br>2017<br>09:30:41<br>AM | Locked   | 82    | 46     | 28      | 18    | 0       | 0      | 0    | 0     | 0       | 0      | 0      | 0       | 0         | 0           | 36            | 17             | 3                        | 0              |     |
| /fpu_top<br>/fpu_inst[3].i_fp<br>/fpu_out<br>/fpu_out_ctl | <sup>u</sup> tpu_out_ctl                                              | Yes                 | No          | No       | Yes      | Thu 21 Dec<br>2017<br>09:30:41<br>AM | Locked   | 82    | 46     | 28      | 18    | 0       | 0      | 0    | 0     | 0       | 0      | 0      | 0       | 0         | 0           | 36            | 17             | 3                        | 0              | 0   |
| /fpu_top                                                  | tpu_top                                                               | No                  | No          | Yes      | No       | Wed 20<br>Dec 2017<br>01:05:14<br>PM | Hard     | 24704 | 21254  | 13675   | 6426  | 154     | 0      | 308  | 0     | 0       | 0      | 536    | 154     | 1         | 0           | 0             | 0              | 0                        | 0              |     |
| /fpu_top<br>/fpu_inst[2].i_fp<br>/fpu_mul                 | u tpu_mul                                                             | No                  | No          | No       | No       | Wed 20<br>Dec 2017<br>01:05:14<br>PM | Locked   | 4939  | 3683   | 2833    | 772   | o       | 0      | 69   | 0     | 0       | 9      | 0      | 0       | 0         | 0           | 113           | 53             | 1                        | 0              |     |
| /fpu_top<br>/fpu_inst[3].i_fp<br>/fpu_mul                 | u tpu_mul                                                             | No                  | No          | No       | No       | Wed 20<br>Dec 2017<br>01:05:14<br>PM | Locked   | 4939  | 3683   | 2833    | 772   | 0       | 0      | 69   | 0     | 0       | 9      | 0      | 0       | 0         | 0           | 113           | 53             | 1                        | 0              | 0   |
| /fpu_top<br>/fpu_inst(1).i_fp<br>/fpu_mul                 | u tpu_mul                                                             | No                  | No          | No       | No       | Wed 20<br>Dec 2017<br>01:05:14<br>PM | Locked   | 4898  | 3642   | 2792    | 772   | 0       | 0      | 69   | 0     | 0       | 9      | 0      | 0       | 0         | 0           | 113           | 53             | 1                        | 0              |     |
| /fpu_top<br>/fpu_inst(0).i_fp<br>/fpu_mul                 | u tpu_mul                                                             | No                  | No          | No       | No       | Wed 20<br>Dec 2017<br>01:05:14<br>PM | Locked   | 4868  | 3612   | 2762    | 772   | o       | o      | 69   | o     | 0       | 9      | 0      | 0       | 0         | o           | 113           | 53             | 1                        | 0              | •   |
|                                                           |                                                                       |                     |             | No       | No       | Wed 20<br>Dec 2017                   | Locked   |       | 1849   | 1285    | 542   | 0       | 0      | 22   | 0     | 0       |        | 0      | 0       | 0         | 0           | 129           | 65             | 1                        | 0              |     |

Figure 212 • ACE Partition Report After rtl\_V4 Incremental Compile Iteration

### Floorplanner View (rtl\_V4)



Figure 213 • ACE Floorplanner Perspective After rtl\_V4 Incremental Compile Iteration



Figure 214 • ACE Floorplanner Perspective with Selected Instance Flylines (rtl\_V4)

### (i) Note

For details how to run a set of changes in order to select an optimal implementation, continue on the **Multiprocess Incremental Compile Tutorial** (page 443). This second tutorial expands upon concepts from this tutorial.

# Multiprocess Incremental Compile Tutorial

Using the incremental compile flow with the multiprocess GUI can be a powerful combination to help with timing closure. The Multiprocess GUI is used to try multiple experiments with different implementation options and/or sets of design constraints. The best implementation can then be selected to be the source for unchanged partitions in a subsequent incremental run. Across all implementations, the locked placement and routing data for all unchanged partitions is then merged from that best implementation. This merging is accomplished by copying the best\_impl/output/<design>.icdb file from the best implementation to all other implementations before starting the next incremental iteration. All file copying is handled automatically by the multiprocess GUI. If you have not yet completed the Single-Process Incremental Compile Tutorial (page 408), please complete Steps 1 through 5 of that tutorial now before proceeding.

Below are the step-by-step actions of using the multiprocess GUI inside the incremental compile flow.

## Step 1: Compile the Design in Synplify Pro or Clear the ACE Project

If you have previously completed the Single-Process Incremental Compile Tutorial (page 408), clear the ACE project and begin again from the beginning. Clear the project by deleting all of the files and subdirectories under the Ace directory of the tutorial work area. Otherwise, the first time ACE is run, it performs an incremental compile and the results do not match those described below.

## Step 2: Create Multiprocess Implementations and Run ACE

From the ACE Home Screen, Use **Window**  $\rightarrow$  **Show View**  $\rightarrow$  **Multiprocess** to open the multiprocess GUI. Then select the **Generate Implementations from Option Sets** radio button. This action generates a large set of implementations automatically using a number of predefined implementation option variables. Optionally, set the "Parallel Job Count" option and configure the job submission system in the Ace preferences. Next click the **RUN** button (three stacked green triangles) to start running all implementations in parallel in the background. See the following screenshot of the Multiprocess View menus.

| dit Actions Example Tools Window Help                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 1 4 4 4 1 1 1 0 % E E B # # #                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Multiprocess 😫                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                  | 7 en <i>s</i> i                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Execution Queue Management                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | s executed sim                                                                                                                   | ultaneously, and whether they are executed locally in the background, or submitted to an external cloud/grid/batch job system.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Parallel Job Count: 25                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Enable lob Submission System (configured in Prefer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | (ences)                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 5115522                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Multiprocess Flow Management                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                  | ultin an                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| In the Flow View, enable and disable the desired flow st<br>provides a means of stopping the flow early.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | eps that all m                                                                                                                   | ultiprocess implementations should follow. Then in the combo-box below, select how far through the flow the implementations should run. (This                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Stop Flow After: Run Post-Route Timing Analysis                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | <b>•</b>                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Force Selected Flow Step to be Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | abled                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Select Implementations                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Select which implementations within the Active Project                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | t should be qu                                                                                                                   | eved for execution. (Option Set Implementations will be created if they don't already exist, or will overwrite existing implementations with the same                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                  | nplementations will run using the current Flow configuration. When Incremental Compile is enabled, the user can optionally choose to copy the<br>tion to all the other implementations before running the flow. This allows you to lock down the best results from a previous run and copy the unchanged                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| partition place and route data to the other implace (active                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | i) implemental                                                                                                                   | tion to an the other implementations before running the now. This allows you to lock down the best results from a previous run and copy the unchanged                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Existing Implementations                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Generate Implementations from Option Sets                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Copy Incremental Flow DB From Template Impl                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| lementation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Execution Sta                                                                                                                    | te Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ) impl 1 acx cls pro seed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Selected                                                                                                                         | The template implementation itself.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| impl 1 acx cls pro seed acx all opt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Selected                                                                                                                         | This option set sets the pnr seed to 34, and evaluates mux transformations, post-routing timing optimizations, reduced target utilization, and rewiri                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| impl 1 acx cls pro seed acx cls pro ext                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Selected                                                                                                                         | This option enables fanout-based transformations, and Post-Routing Timing Optimization                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Selected                                                                                                                         | This option set enables pre-placement netlist resynthesis, High-effort Timing Optimization, and sets the pnr seed to 14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| impl_l_acx_cls_pro_seed_acx_cls_pro_seed<br>impl 1 acx cls pro seed acx cls util                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Selected                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <pre>l impl_1_acx_cls_pro_seed_acx_cls_util</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Selected<br>Selected                                                                                                             | This option set relaxes fanout-based optimization, enables dense placement, extra-effort timing optimization, and alters the placement seed.<br>This option set sets the onr seed to 82, reduces fanout limit to 500, and enables Post-Routing Timing Optimization                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Selected                                                                                                                         | This option set relaxes fanout-based optimization, enables dense placement, extra-effort timing optimization, and alters the placement seed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ) impl_lacx_cls_pro_seed_acx_cls_util<br>) impl_lacx_cls_pro_seed_acx_fan_pro_seed<br>) impl_lacx_cls_pro_seed_acx_fan_seed_util_bigblock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Selected                                                                                                                         | This option set relaxes fanout-based optimization, enables dense placement, extra-effort timing optimization, and alters the placement seed.<br>This option set sets the prin seed to 82, reduces fanout limit to 500, and enables Post-Routing Timing Optimization<br>This option set disables fanout cloning, sets the prise set or seed 31, alters target placement utilization, and enhances Big Block placement                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <pre>impl_1_acx_cls_pro_seed_acx_cls_util impl_1_acx_cls_pro_seed_acx_fan_pro_seed</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Selected<br>Selected                                                                                                             | This option set relaxes fanout-based optimization, enables dense placement, extra-effort timing optimization, and alters the placement seed.<br>This option set sets the pnr seed to 82, reduces fanout limit to 500, and enables Post-Routing Timing Optimization                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| ) impl_l_acx_cls_pro_seed_acx_cls_util<br>) impl_l_acx_cls_pro_seed_acx_fan_pro_seed<br>) impl_l_acx_cls_pro_seed_acx_fan_seed_util_bigblock<br>) impl_l_acx_cls_pro_seed_acx_fan500_seed_util<br>) impl_l_acx_cls_pro_seed_acx_gpm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Selected<br>Selected<br>Selected                                                                                                 | This option set relaxes fanout-based optimization, enables dense placement, extra-effort timing optimization, and alters the placement seed.<br>This option set sets the per seed to all endowed fanout limit to 500, and enables Post-Routing Timing Optimization<br>This option set adisables fanout cloning, sets the pri seed to seed 31, alters target placement utilization, and enhances Big Block placement<br>This option set alters fanout limits, pri seed, and target utilization<br>This option set alters fanout limits, pri seed, and target utilization<br>This option set and bes the GPM daming placement.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ) impl_lacx_cls_pro_seed_acx_cls_util<br>) impl_lacx_cls_pro_seed_acx_fan_pro_seed<br>) impl_lacx_cls_pro_seed_acx_fan_seed_util<br>) impl_lacx_cls_pro_seed_acx_fanSo0_seed_util<br>) impl_lacx_cls_pro_seed_acx_gpn<br>) impl_lacx_cls_pro_seed_acx_gpn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Selected<br>Selected<br>Selected<br>Selected                                                                                     | This option set relaxes fanout-based optimization, enables dense placement, extra-effort timing optimization, and alters the placement seed.<br>This option set sets the proseed to 82, reduces fanout limit to 300, and enables Post-Routing Timing Optimization<br>This options etalkables fanout cloning, sets the proseed to seed 51, alters target placement utilization, and enhances Big Block placement<br>This options et alters fanout limits, prosed, and target utilization                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| ) impl_l_acx_cls_pro_seed_acx_cls_util<br>) impl_l_acx_cls_pro_seed_acx_fan_pro_seed<br>) impl_l_acx_cls_pro_seed_acx_fan_seed_util_bigblock<br>) impl_l_acx_cls_pro_seed_acx_fan500_seed_util<br>) impl_l_acx_cls_pro_seed_acx_gpm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Selected<br>Selected<br>Selected<br>Selected<br>Selected                                                                         | This option set relaxes favout-based optimization, enables dense placement, extra-effort timing optimization, and afters the placement seed.<br>This option set sets the per seed to B2 reduces fanout time to 500, and enables Fost-Routing Timing Optimization<br>This option set sets the per seed b2. The per seed to seed 51, afters target placement utilization, and enhances Big Block placement<br>This option set deals fanout timins; presed, and target utilization<br>This option set enables the GPM during placement.<br>This option set enables the GPM during placement.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| ) imp[acc,cb_pro_seed_acc_cb_uti<br>) imp[_acc,cb_pro_seed_acc_fan_pro_seed<br>) imp[_acc,cb_pro_seed_acc_fan_pro_seed_uti<br>] imp[_acc,cb_pro_seed_acc_fan500_seed_uti<br>] imp[_acc,cb_pro_seed_acc_gpm<br>] imp[_acc,cb_pro_seed_acc_gpm_uti<br>] imp[_acc,cb_pro_seed_acc_gpm_uti                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected                                                             | This option set relaxes fanout-based optimization, enables dense placement, extra-effort timing optimization, and afters the placement seed.<br>This option set sets the per seed to BL endoes from time to 500, and enables Post-Routing Timing Optimization<br>This option set sets the per seed bL endoes to black the per seed to seed 51, afters target placement utilization, and enhances Big Block placement<br>This option set dense francu timits, presed, and target utilization<br>This option set enables the GPM during placement.<br>This option set enables the GPM during placement and enables enhanced Big Block Placement.<br>This option set enables the GPM during placement and enables enhanced Big Block Placement.<br>This option set enables the GPM during placement and enables the paraced to 91                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ) mp[1, acc, ds, pn ] sed acc, fn g mp ]<br>mp[1, acc, ds, pn ] sed acc, fn g mp ] sed<br>) mp[1, acc, ds, pn ] sed acc, fn g sed acl, bipblock<br>) mp[1, acc, ds, pn ] sed acc, fn ] sed acl, bipblock<br>) mp[1, acc, ds, pn ] sed acc, gpn<br>) mp[1, acc, ds, pn ] sed acc, gpn<br>) mp[1, acc, ds, pn ] sed acc, gpn<br>mp[1, acc, ds, pn ] sed acc, gpn, util<br>) mp[1, acc, ds, pn ] sed acc, ms, util sed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected                                                 | This option set relaxes fanout-based optimization, enables dense placement, extra-effort timing optimization, and afters the placement seed.<br>This option set sets the par seed to 2R endper fanout time 15 000, and enables Pest-Revittion Timing optimization<br>This option set disables fanout cloning, sets the par seed to seed 51, alters target placement utilization, and enhances Big Block placement<br>This option set disables fanout cloning, sets the par seed to seed 51, alters target placement utilization, and enhances Big Block placement.<br>This option set enables the GPM during placement and enables enhanced Big Block Placement.<br>This option set enables the GPM adving placement and afters the placement density.<br>This option set enables the GPM adving placement and readise the placement density.<br>This option set enables the GPM adving placement on sets the par seed to 51<br>This option set enables the GPM adving motion sets the par seed to 51                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| ) impl_i_scr_cts pro_seed_scr_cts uti<br>) impl_i_scr_cts pro_seed_scr_fm_pro_seed<br>) impl_i_scr_cts pro_seed_scr_fm_sced_uti<br>) impl_i_scr_cts pro_seed_scr_fm500_seed_util<br>) impl_i_scr_cts pro_seed_scr_gm<br>) impl_i_scr_sts pro_seed_scr_gm<br>) impl_i_scr_sts pro_seed_scr_gm_util<br>) impl_i_scr_sts pro_seed_scr_gm_util<br>) impl_i_scr_sts pro_seed_scr_gm_util<br>) impl_i_scr_sts pro_seed_scr_gm_util                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected                                     | This option set relaxes fanout-based optimization, enables dense placement, extra-effort timing optimization, and afters the placement seed.<br>This option set sets the per seed to 82: endoces from timing to 500, and enables Post-Rokuting Timing optimization<br>This option set sets the per seed to 82: endoces from timing to 500, and enables Post-Rokuting Timing optimization<br>This option set enables the GPM during placement et utilization<br>This option set enables the GPM during placement.<br>This option set enables the GPM during placement and enables enhanced Big Block Placement.<br>This option set enables the GPM during placement and enables enhanced Big Block Placement.<br>This option set enables the GPM during placement and enables enhanced Big Block Placement.<br>This option set enables the GPM during placement and enables enhanced Big Block Placement.<br>This option set enables the GPM during placement and enables enhanced Big Block Placement.<br>This option set enables the GPM during placement and enables the praced to 91                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| ) mp[1_acc(s) pro_sed_acc(s, uti<br>) mp[1_acc(s) pro_sed(acc(n) nor sed<br>) mp[1_acc(s) pro_sed(acc(n) nor sed<br>) mp[1_acc(s) pro_sed(acc(n) nor sed<br>) mp[1_acc(s) pro_sed(acc(n)<br>) mp[1_acc(s) pro_sed(acc(n))                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected                                     | This option set relaxes fanout-based optimization, enables dense placement, extra-effort timing optimization, and afters the placement seed.<br>This option set sets the per seed to BL endoes from time to 500, and enables Post-Routing Timing Optimization<br>This option set sets the per seed bL endoes to black the per seed to seed 51, afters target placement utilization, and enhances Big Block placement<br>This option set dense francu timits, presed, and target utilization<br>This option set enables the OPM during placement.<br>This option set enables the OPM during placement and enables enhanced Big Block Placement.<br>This option set enables the OPM during placement and enables enhanced Big Block Placement.<br>This option set enables the OPM during placement and enables the parsed to 51<br>This option set enables the OPM during placement and enables enhanced Big Block Placement.<br>This option set enables the OPM during placement and enables enhanced Big Block Placement.<br>This option set enables the OPM during placement and enables the parsed to 51<br>This option set enables the OPM during placement and enables the present of 51<br>This option set enables the OPM during placement and enables the option set enables the OPM during placement and enables the option set enables the OPM during placement and enables the option set enables the OPM during placement and sets the present of 51<br>This option set enables the OPM during the option set the present of 51<br>This option set enables the OPM during the option set the present of 52 and reduces target utilization to 70%<br>This option set enables the OPM during the placement during the option set the present of 51<br>This option set enables the OPM during the option set the present of 52 and reduces target utilization to 70%<br>This option set tandles to table the option placement and the option set the option set the present option set the option |
| ) mp[1_acc(s) pro seed acc(s, uti<br>) mp[1_acc(s) pro seed acc(n pro seed<br>) mp[1_acc(s) pro seed acc(n pro seed<br>) mp[1_acc(s) pro seed acc(n pro seed<br>) mp[1_acc(s) pro seed acc(pro seed acc(seed<br>) mp[1_acc(s) pro seed acc(seed)<br>) mp[1_acc(s) pro seed acc(seed)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected                         | This option set relaxes fanout-based optimization, enables dense placement, extra-effort timing optimization, and afters the placement seed.<br>This option set sets the par seed of all endparts of the part seed to seed 31, afters target placement utilization and enhances Big Block placement.<br>This option set disables fanout choing, sets the par seed to seed 31, afters target placement utilization, and enhances Big Block placement.<br>This option set disables fanout choing placement and enables enhanced Big Block Placement.<br>This option set enables the GPM during placement and enables enhanced Big Block Placement.<br>This option set enables the GPM during placement and enables enhanced Big Block Placement.<br>This option set enables the GPM during placement and enables enhanced big Block Placement.<br>This option set enables the GPM during placement and sets the par seed to 91<br>This option set enables must read/motion.<br>This option set elevables the GPM during block Placement density.<br>This option set elevables the GPM during block Placement density.<br>This option set elevables the GPM during block Placement density.<br>This option set elevables the GPM during block Placement density.<br>This option set elevables the GPM during block Placement density.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| ) mp[1,acc(s) pn] sed acc(s) sti<br>mp[1,acc(s) pn] sed acc(n) pn] sed<br>) mp[1,acc(s) pn] sed acc(n) pn] sed<br>) mp[1,acc(s) pn] sed acc(n) pnO) sed util<br>) mp[1,acc(s) pn] sed acc(n)<br>mp[1,acc(s) pn] | Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected                         | This option set relaxes fanout-based optimization, enables dense placement, extra-effort timing optimization, and afters the placement seed.<br>This option set sets the par seed of all endoses for the part seed to seed 31, alters target placement utilization, and enhances Big Block placement<br>This option set tarles fanout limits, part seed, and target utilization<br>This option set enables the OPM during placement and enables enhanced Big Block Placement.<br>This option set enables the OPM during placement and enables enhanced Big Block Placement.<br>This option set enables the OPM during placement and atters the placement density.<br>This option set enables the OPM during blacement and atters the placement density.<br>This option set enables the OPM during blacement and reases the part seed to 91<br>This option set enables may tandermolius, sets the part seed to 92<br>This option set escits a specific Parkements seed in conjunction with an extra Big Block placement pass<br>This option set sets the appresent of seed and atters the part seed to 92<br>This option set sets the specific sector and sets the part seed to 92<br>This option set sets the specific sectorements sets and the sets appresent sets the part seed to 93<br>This option set sets target of the sectorement seed in conjunction with an extra Big Block placement pass<br>This option set sets target or seed 31 and attempts carry transformations<br>This option set sets the part seed to seed 33 and attempts carry transformations                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| ) imp[1_acc(s) pro_sed_acc(s) sti<br>) imp[1_acc(s) pro_sed(acc(n) no sed<br>) imp[1_acc(s) pro_sed(acc(n) no sed<br>) imp[1_acc(s) pro_sed(acc(n) no sed(sti<br>) imp[1_acc(s) pro_sed(acc(n)<br>) imp[1_acc(s) pro_sed(acc(n))<br>] imp[1_acc(s) pro_sed(acc(n))<br>] imp[1_acc(s) pro_sed(acc(n))<br>] imp[1_acc(s) pro_sed(acc(n))<br>] imp[1_acc(s) pro_sed(acc(n))<br>] imp[1_acc(s) pro_sed(acc(n))<br>] imp[1_acc(s) pro_sed(acc(n))] | Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected             | This option set relaxes fanouc-based optimization, enables dense placement, extra-effort timing optimization, and afters the placement seed.<br>This option set sets the par seed ob 2. endoces fonou timing to 200, and enables Post-Noticini Timing optimization and<br>This option set sets the par seed ob 2. endoces fonou timing to 200, and enables Post-Noticini Timing optimization<br>This option set enables the OPM during placement at densibles enhanced Big Block Placement.<br>This option set enables the OPM during placement and enables enhanced Big Block Placement.<br>This option set enables the OPM during placement and enables enhanced Big Block Placement.<br>This option set enables the OPM during placement and enables enhanced Big Block Placement.<br>This option set enables the OPM during placement and enables enhanced Big Block Placement.<br>This option set enables the OPM during placement and enables enhanced Big Block Placement.<br>This option set enables the OPM during placement and enables enhanced Big Block Placement.<br>This option set enables the OPM during placement and enables the private of 0.5 and reduces target utilization to 70%<br>This option set enables the OPM during Placement seed in conjunction with an extra Big Block Placement pass<br>This option set set the par seed to seed 3.1 and attempts carry transformations<br>This option set sets the par seed to seed 3.2 and attempts extra-effort timing optimizations<br>This option set sets the par seed to seed 3.2 and attempts extra-effort timing optimizations<br>This option set sets the par seed to seed 3.2 and attempts the target utilization to 60%                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| ) mp[1, ac; ds; pro]sed ac; ds; sti<br>] mp[1, ac; ds; pro]sed ac; fn, pro]sed<br>] mp[1, ac; ds; pro]sed ac; fn, sed at] hiphock<br>] mp[1, ac; ds; pro]sed ac; fno]sed util<br>] mp[1, ac; ds; pro]sed ac; pro]<br>] mp[1, ac; ds; pro]sed ac; ms; util<br>] mp[1, ac; ds; pro]sed ac; ms; utilsed<br>] mp[1, ac; ds; pro]sed ac; sed match<br>] mp[1, ac; ds; pro]sed ac; sed match<br>] mp[1, ac; ds; pro]sed ac; sed match<br>] mp[1, ac; ds; pro]sed ac; sed match                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected<br>Selected | This option set relaxes fanout-based optimization, enables dense placement, extra-effort timing optimization, and afters the placement seed.<br>This option set sets the par seed of all endoses for the part seed to seed 31, afters target placement utilization and enhances Big Block placement<br>This option set disables fanout cloning, sets the par seed to seed 31, afters target placement utilization, and enhances Big Block placement<br>This option set enables the GPM during placement and enables enhanced Big Block Placement.<br>This option set enables the GPM during placement and afters the placement density.<br>This option set enables the GPM during blacement and afters the placement density.<br>This option set enables the GPM during blacement and reso the part seed to 31<br>This option set enables must resolve and sets the part seed to 51<br>This option set enables that GPM during blacement and resolve to 91<br>This option set extra sets the GPM during blacement and resolve to 91<br>This option set extra sets the GPM during blacement and resolve to 91<br>This option set extra sets the gPM externments when the set a Big Block placement pass<br>This option set tests tars performations, sets the part seed to 52, and reduces target utilization to 70%<br>This option set sets tars gord: The Setterment seed in conjunction with an extra Big Block placement pass<br>This option set sets tars performed to seed 33 and attempts extra-fifter timing optimizations                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

Figure 215 • Multiprocess View Menus

As in the single-process incremental compile flow, during the first pass through ACE, all implementations have their partitions compiled from scratch, as seen in the following screenshot of the partition report from one of the completed implementations.

|                                                                        |                                                                                                                          | n 🗈 🛛 🎯 🌾   |                                                                  |                                                 |        |          |         |       |       |        |        |       |        |       |       |        |        |            |            |           |                    |            |      |       |        |           |                    |       |           |     |
|------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|-------------|------------------------------------------------------------------|-------------------------------------------------|--------|----------|---------|-------|-------|--------|--------|-------|--------|-------|-------|--------|--------|------------|------------|-----------|--------------------|------------|------|-------|--------|-----------|--------------------|-------|-----------|-----|
| Partitic                                                               | on Report                                                                                                                | t — fpu_top | 😫 📄 Timir                                                        | ig Report -                                     | Route  | ed — f   | pu_to   | p     | Clo   | ck/Res | et Rep | ort — | fpu_to | p     | Utili | zation | n Repo | rt - Route | ed — fpu_t | op        |                    |            |      |       |        |           |                    |       |           |     |
| Design:<br>Device: a<br>General<br>Host ca<br>Summar<br>• Num<br>• Num | Achironix CAG<br>proj_1 - impl<br>AC18tSC01-<br>ted on Wed 0<br>id43 achironi<br>ry<br>ther of partiti<br>iter of instau | Environment | seed - tpu_top<br>DT 2016<br>mplied, 100.00%<br>W re-compiled, 1 | 00.00%                                          | Date 3 | 2016-10- | 12 14 5 | ,     |       |        |        |       |        |       |       |        |        |            |            |           |                    |            |      |       |        |           |                    |       |           |     |
| Details                                                                |                                                                                                                          | Module Name | Re-Compiled?                                                     | Timestamp                                       | Туре   | Nets     | Insts   | LUTS  | Flops | MUX4s  | MUX8s  | ALUS  | LRAMs  | BRAMs | DSPs  | IPINs  | OPINS  | CLK_IPINs  |            | Boundary  | Boundary<br>Output | Registered |      | Input | Output | Input     | Floating<br>Output | Input | Output    | Fee |
| /fpu_top                                                               | p 1                                                                                                                      | pu_top      | Ves                                                              | Wed 12 Oct 2016 10.05 52 PM                     | Hard   | 23135    | 19707   | 13406 | 5320  | 154    | 0      | 308   | 0      | 0     | 0     | 364    | 154    | 1          | 0          | Nets<br>0 | Nets               | 0          | Nets | Nets  | Nets   | Nets<br>0 | Nets               | Nets  | Nets<br>0 | 0   |
| Apu_top<br>Apu_ini<br>Apu_m                                            | st(0) (dpu   1                                                                                                           | pu_mul      | Yes                                                              | Wed 12 Oct 2016 10:05:52 PM                     | Locked | 4352     | 3485    | 2641  | 774   | 0      | 0      | 64    | 0      | 0     | 6     | 0      | 0      | 0          | 0          | 113       | 53                 | 1          | 0    | 0     | 1      | 0         | •                  | 0     | 1         | 0   |
| Apu top                                                                | p<br>st[11.1 tou 1                                                                                                       | pu_mul      | Ves                                                              | Wed 12 Oct<br>2016<br>10:05:52 PM               | Locked | 4352     | 3485    | 2641  | 774   | 0      | 0      | 64    | 0      | 0     | G     | •      | 0      | 0          | 0          | 113       | 53                 | 1          | 0    | 0     | 1      | 0         | •                  | 0     | 1         | 0   |
| Xpu_top<br>Xpu_ins<br>Xpu_mu                                           | sti21) fpu 1                                                                                                             | po_mul      | Ves                                                              | Wed 12 Oct<br>2016<br>10:05:52 PM               | Locked | 4352     | 3485    | 2641  | 774   | 0      | 0      | 64    | 0      | 0     | 6     | •      | 0      | 0          | 0          | 113       | 53                 | 1          | 0    | 0     | 1      | 0         | 0                  | 0     | 1         | 0   |
| //pu_m                                                                 | st(3)tpu 1<br>ul                                                                                                         | pu_mul      | Ves                                                              | Wed 12 Oct<br>2016<br>10:06:52 PM               | Locked | 4352     | 3485    | 2641  | 774   | 0      | 0      | 64    | 0      | 0     | 6     | •      | 0      | 0          | °.         | 113       | 53                 | 1          | 0    | 0     | 1      | 0         | •                  | 0     | 1         | 0   |
| Xpu_top<br>Xpu_ins<br>Xpu_dis                                          | stitl i tou I t                                                                                                          | pu_div      | Ves                                                              | Wed 12 Oct<br>2016<br>10:05:52 PM               | Locked | 2119     | 1827    | 1314  | 491   | 0      | 0      | 22    | 0      | 0     | 0     | •      | 0      | 0          | 0          | 129       | 65                 | 1          | 0    | 0     | 1      | 0         | •                  | 0     | 1         | 0   |
| //pu_dh                                                                | st(0)tpu 1<br>v                                                                                                          | pu_div      | Yes                                                              | Wed 12 Oct<br>2016<br>10:05:52 PM               | Locked | 2119     | 1827    | 1314  | 491   | 0      | 0      | 22    | 0      | 0     | 0     | •      | 0      | 0          | •          | 129       | 65                 | 1          | 0    | 0     | 1      | 0         | •                  | 0     | 1         | 0   |
| /fpu_dh                                                                | A<br>adS)/thn_t                                                                                                          | pu_div      | Ves                                                              | Wed 12 Oct<br>2016<br>10:05:52 PM               | Locked | 2119     | 1827    | 1314  | 491   | •      | 0      | 22    | 0      | 0     | 0     | ۰      | 0      | 0          | •          | 129       | æ                  | 1          | 0    | 0     | 1      | 0         | ۰                  | 0     | 1         | 0   |
| /fpu_dh                                                                | st\$8tpu 1<br>v                                                                                                          | pu_div      | Ves                                                              | Wed 12 Oct<br>2016<br>10:05:52 PM               | Locked | 2119     | 1827    | 1314  | 491   | 0      | 0      | 22    | 0      | 0     | 0     | •      | 0      | 0          | 0          | 129       | 65                 | 1          | 0    | 0     | 1      | 0         | •                  | 0     | 1         | 0   |
| /fpu_in                                                                | st(0)tpu 1                                                                                                               | pu_in       | Ves                                                              | Wed 12 Oct<br>2016<br>10:06:52 PM               | Locked | 877      | 789     | 484   | 305   | 0      | 0      | 0     | 0      | 0     | 0     | •      | 0      | 0          | 0          | 83        | 311                | 82         | 0    | 1     | 1      | 0         | 0                  | 0     | 1         | 0   |
| Apu_top<br>Apu_ins<br>Apu_in<br>Apu_top                                | st[2] i_fpu   t                                                                                                          | pu_in       | Ves                                                              | Wed 12 Oct<br>2016<br>10.05.52 PM<br>Wed 12 Oct | Locked | 877      | 789     | 484   | 305   | 0      | 0      | 0     | 0      | 0     | 0     | •      | 0      | 0          | 0          | 83        | 311                | 82         | 0    | 1     | 1      | 0         | •                  | 0     | 1         | 0   |
| Apu_top<br>Apu_int<br>Apu_in<br>Apu_top                                | st[1] (_tpu _t                                                                                                           | pu_in       | Yes                                                              | Wed 12 Dct<br>2016<br>10:05:52 PM<br>Wed 12 Dct | Locked | 877      | 789     | 484   | 305   | °      | 0      | 0     | 0      | 0     | 0     | ۰      | 0      | 0          | •          | 83        | 311                | 82         | 0    | 1     | 1      | 0         | •                  | 0     | 1         | 0   |
|                                                                        | st[3]. tou t                                                                                                             | pu in       | Mag.                                                             | Wed 12 Oct<br>2016<br>10:05:52 PM               | Locked | 877      | 789     | 484   | 305   | 0      | 0      | 0     | 0      | 0     | 0     | •      | 0      | 0          | 0          | 83        | 311                | 82         | 0    | 1     | 1      | 0         | 0                  | 0     | 1         | 0   |

Figure 216 • Partition Report from First Completed Multiprocess Implementation

## Step 3: Select the Implementation with Best Performance

After all of the parallel runs have completed, select the implementation with the best performance on the most timing-critical clock domain. A summary of the frequency, setup slack, and hold slack for each implementation is provided in the Multiprocess Summary Report (see the following screenshot).

| File Edit Actions Example Tools Window Help         File Edit Actions Example Tools Window Help         Image: Colspan="2">Image: Colspan="2">Image: Colspan="2" (Colspan="2")         Timing Results Summary         This section shows the high-level timing results obtained from the timing reports that were generated during this multi-process run. For turber timing details, see the linked individual timing reports (In each implementation's on report directory).         Timing Analysis Summary         Impl Name       Clock Domain       Target Frequency       Post-Route         Upper-Limit Frequency       Post-Route       1000mm         Impl I acc all act       ocik       125 0 MHz       150 8 MHz (v157%)       +1146m       +0 00mm         Impl I acc all act       ocik       125 0 MHz       150 8 MHz (v127%)       +1426 MHz (v127%)       +0 027m         Impl I acc all act       ocik       125 0 MHz       150 8 MHz (v127%)       +1426 MHz (v127%)       +0 027m         Impl I acc all act       ocik       125 0 MHz       153 1 MHz (v217%)       +1426 MHz (v127%)       +0 027m         Impl I acc fam.meed       ocik       125 0 MHz       153 1 MHz (v217%)       +1 027m       +0 027m         Impl I acc fam.meed       ocik       125 0 MHz       151 1 MHz (v20 M)       +1 027m       +0 027m         III acc fam.meed<                                                                                                                                                                                     |                                       | ACE - Achronix CAD E                                                                                                                     | invironment - \         | /ersion HS1.1 - pro | oj 1->impl 1 (AC16tSCO | 1 HI01 C)   |            |     |  |  |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|---------------------|------------------------|-------------|------------|-----|--|--|--|--|--|--|
| Multi-process Summary Report proj_1 23       Image: Comparison of the high-level limit product shared from the limit proofs that were generated during this multi-process run. For timing Analysis Summary         Timing Results Summary       This section shows the high-level limit prevails obtained from the limit greports that were generated during this multi-process run. For timing Analysis Summary         Impl Analysis Summary       Impl Anale       Clock Domain       Target Frequency       Post-Route         Impl Analysis Summary       Impl Anale       Clock Domain       Target Frequency       Post-Route         Impl Anale       Clock Domain       Target Frequency       Post-Route       Hold Slack         Impl Anale       Clock Domain       Target Frequency       Post-Route       Hold Slack         Impl Ance off port est       getk       1250 MHz       146.9 MHz (+16.7%)       +1.146ms       +0.038ms         Impl Ance off port est       getk       1250 MHz       190.8 MHz (+18.6%)       +1.257ms       +0.032ms         Impl Ance off port est       getk       1250 MHz       195.1 MHz (+21.7%)       +1.426ms       +0.032ms         Impl Ance off port est       getk       1250 MHz       195.1 MHz (+21.7%)       +1.426ms       +0.032ms         Impl Ance off port est       getk       1250 MHz       195.1 MHz (+22.6%)       +1.527ms       +0.032ms <td><u>F</u>ile</td> <td>Edit Actions Example Tools</td> <td><u>W</u>indow <u>H</u></td> <td>elp</td> <td></td> <td></td> <td></td> <td></td> | <u>F</u> ile                          | Edit Actions Example Tools                                                                                                               | <u>W</u> indow <u>H</u> | elp                 |                        |             |            |     |  |  |  |  |  |  |
| Index process summary network project of project of the section shows the high-level timing results obtained from the timing reports that were generated during this multi-process run. For further timing details, see the linked individual timing reports (in each implementation's own reports directory).         Timing Analysis Summary         Impl Aname       Clock Domain       Target Frequency       Post-Route         Upper-Limit Frequency       Post-Route       1485 9 MHz (18.7%)       1146ns       10036ns         Impl Lacc all opt end       ocik       125.0 MHz       1365 9 MHz (18.7%)       1146ns       10036ns         Impl Lacc all opt end       ocik       125.0 MHz       1361 MHz (24.1%)       11267ns       +0.032ns         Impl Lacc all opt end       ocik       125.0 MHz       1361 MHz (24.1%)       +1.267ns       +0.032ns         Impl Lacc all opt end       ocik       125.0 MHz       1361 MHz (24.1%)       +1.026ns       +0.032ns         Impl Lacc all opt end       ocik       125.0 MHz       1351 MHz (24.1%)       +1.262ns       +0.032ns         Impl Lacc all opt end       ocik       125.0 MHz       1351 MHz (24.2%)       +1.026ns       +0.032ns         Impl Lacc all opt end       ocik       125.0 MHz       154.5 MHz (24.2%)       +1.026ns       +0.032ns         Impl Lacc all opt end       ocik       125.0                                                                                                                                                                            | ] 🥝                                   |                                                                                                                                          |                         |                     |                        |             |            |     |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                       | ■ Multi-process Summary Report — proj_1 🕱                                                                                                |                         |                     |                        |             |            |     |  |  |  |  |  |  |
| Ins section shows the high-level timing results obtained from the timing teports that were generated during this multi-process run. For         Turning Analysis Summary         Impl Name       Clock Domain       Target Frequency       Post-Route         Impl. Lacx. nll ost       qcik       125 0 MHz       1485 9 MHz (+16.7%)       +1.146ms       +0.036ms         Impl. Lacx. nll ost       qcik       125 0 MHz       1485 9 MHz (+16.7%)       +1.146ms       +0.036ms         Impl. Lacx. nll ost       qcik       125 0 MHz       1485 9 MHz (+16.7%)       +1.146ms       +0.036ms         Impl. Lacx. nll ost       qcik       125 0 MHz       1485 9 MHz (+16.7%)       +1.146ms       +0.037ms         Impl. Lacx. nll ost       qcik       125 0 MHz       1482 9 MHz (+16.7%)       +1.146ms       +0.037ms         Impl. Lacx. nll ost       qcik       125 0 MHz       1482 9 MHz (+18.8%)       +1.267ms       +0.032ms         Impl. Lacx. nng. no. ased       qcik       125 0 MHz       155 1 MHz (+21.7%)       +1.424ms       +0.032ms         Impl. Lacx. nng. no. ased       qcik       125 0 MHz       155 1 MHz (+22.8%)       +1.524ms       +0.032ms         Impl. Lacx. nng. no. ased       qcik       125 0 MHz       151 1 MHz (+20.9%)       +1.383ms       +0.031ms         Imp                                                                                                                                                                                                                                          | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 1                                                                                                                                        |                         |                     |                        |             |            |     |  |  |  |  |  |  |
| Image and weak age the linked induced mining regular and weak get effected unity this multiploces with red time density.         Image age the linked induced mining regular and weak get effected unity this multiploces with red time density.         Image age the linked induced mining regular and weak get effected unity this multiploces with red time density.         Image age the linked induced mining regular and weak get effected unity this multiploces with red time density.         Image age the linked induced mining regular and weak get effected unity this multiploces with red time density.         Image age the linked induced mining regular and weak get effected unity.         Image age the linked induced mining regular and weak get effected unity.         Image age the linked induced mining regular and weak get effected unity.         Image age the linked induced mining regular and weak get effected unity.         Image age to the density.       Image age to the density.         Image age to the density.       Image age to the density.         Image age to the density.       Image age to the density.       Image age age age age age age age age age                                                                                                                                                                                                                                                                                                                                               | Ĕ                                     |                                                                                                                                          |                         |                     |                        |             |            |     |  |  |  |  |  |  |
| Timing Analysis Summary         Post-Route           Impl Name         Clock Doman         Target Frequency         Setup Slack         Hold Slack           Impl Lack         QCIk         1250 MHz         1460 MHz (+157%)         +1145m         +0036ms           Impl Lack         QCIk         1250 MHz         1460 MHz (+157%)         +1145m         +0036ms           Impl Lack         QCIk         1250 MHz         1465 MHz (+167%)         +1145m         +0037ms           Impl Lack         GCIk         1250 MHz         1485 MHz (+218%)         +1257m         +0032ms           Impl Lack         GCIk         1250 MHz         1482 MHz (+186%)         +1252m         +0032ms           Impl Lack         GCIk         1250 MHz         151 MHz (+217%)         +142ms         +0032ms           Impl Lack         GCIk         1250 MHz         153 MHz (+218%)         +125ms         +0037ms           Impl Lack         GCIk         1250 MHz         154 MHz (+235%)         +164ms         +0037ms           Impl Lack         GCIk         1250 MHz         154 MHz (+236%)         +126ms         +0037ms           Impl Lack         GCIk         1250 MHz         154 MHz (+236%)         +1387m         +0037ms           Impl                                                                                                                                                                                                                                                                                                 |                                       | This section shows the high-level timing results obtained from the timing reports that were generated during this multi-process run. For |                         |                     |                        |             |            |     |  |  |  |  |  |  |
| Impl Name         Clock Domain         Target Frequenty         Post-wate<br>Upper-Limit Frequency         Setup Stack         Hold Stack           Imd 1         0:0k         1250 MHz         459 MHz (+16.7%)         +1.145n         +0.03fns           Imd 1         0:0k         1250 MHz         1508 MHz (+18.8%)         +1.267ns         +0.03fns           Imd 1         0:0k         1250 MHz         1485 MHz (+18.8%)         +1.257ns         +0.03fns           Imd 1         0:0k         1250 MHz         1482 MHz (+18.8%)         +1.257ns         +0.03fns           Imd 1         0:0k         1250 MHz         1482 MHz (+18.8%)         +1.257ns         +0.03fns           Imd 1         0:0k         1250 MHz         1521 MHz (+21.8%)         +1.257ns         +0.03fns           Imd 1         0:0k         1250 MHz         1521 MHz (+21.8%)         +1.057ns         +0.03fns           Imd 1         0:0k         1250 MHz         1521 MHz (+21.8%)         +1.063ns         +0.03fns           Imd 1         0:0k         1250 MHz         1531 MHz (+22.8%)         +1.03fns         +0.03fns           Imd 1         0:0k         1250 MHz         1511 MHz (+20.9%)         +1.57ns         +0.03fns           Imd 1         0:0k                                                                                                                                                                                                                                                                                          | F                                     | Timing Analysis Summary                                                                                                                  |                         |                     |                        |             |            |     |  |  |  |  |  |  |
| Incl         Upper-Limit Frequency         Setup Stack         Hold Stack           Impel         acx         125 0 MHz         145 9 MHz (+16 7%)         +1145ns         +0 036ns           Impel         acx         eik         125 0 MHz         145 9 MHz (+18 7%)         +1145ns         +0 037ns           Impel         acx         eik         125 0 MHz         148 5 MHz (+18 7%)         +1267ns         +0 032ns           Impel         acx         eix         125 0 MHz         148 5 MHz (+18 7%)         +1257ns         +0 032ns           Impel         acx         eix         125 0 MHz         148 2 MHz (+18 7%)         +1257ns         +0 032ns           Impel         acx         fan 500 seed         upik         125 0 MHz         152 1 MHz (+21 7%)         +1424ns         +0 032ns           Impel         acx         fan 500 seed         upik         upik         125 0 MHz         153 5 MHz (+22 7%)         +1424ns         +0 032ns           Impel         acx         fan seed         upik         125 0 MHz         154 5 MHz (+22 7%)         +1424ns         +0 032ns           Impel         acx         fan seed         upik         125 0 MHz         151 1 MHz (+22 7%)         +152ns         +0 032ns                                                                                                                                                                                                                                                                                                  |                                       | Impl Name                                                                                                                                | Clock Domain            | Target Frequency    | Post                   | -Route      |            |     |  |  |  |  |  |  |
| Impl         Lacx         old         125.0 MHz         150.8 MHz (+20.6%)         +1.368ns         +0.031ns           Impl         Lacx         cis         pcik         125.0 MHz         148.5 MHz (+18.8%)         +1.267ns         +0.032ns           Impl         Lacx         cis         pcik         125.0 MHz         148.5 MHz (+18.8%)         +1.252ns         +0.032ns           Impl         Lacx         cis         pcik         125.0 MHz         148.2 MHz (+18.6%)         +1.252ns         +0.032ns           Impl         Lacx         cis         pcik         125.0 MHz         155.1 MHz (+22.1%)         +1.424ns         +0.032ns           Impl         Lacx         fan.8700         seed         util         pcik         125.0 MHz         155.1 MHz (+22.8%)         +1.424ns         +0.032ns           Impl         Lacx         fan.8700         pcik         125.0 MHz         155.1 MHz (+22.8%)         +1.426ns         +0.032ns           Impl         Lacx         pcik         125.0 MHz         154.4 MHz (+22.8%)         +1.426ns         +0.032ns           Impl         Lacx         pcik         125.0 MHz         151.1 MHz (+22.9%)         +1.383ns         +0.032ns           Impl         Lacx                                                                                                                                                                                                                                                                                                             |                                       |                                                                                                                                          | CIOCK DOMAIN            | ranget Frequency    | Upper-Limit Frequency  | Setup Slack | Hold Slack |     |  |  |  |  |  |  |
| impl 1 acx all opt       gclk       125 0 MHz       150 8 MHz (+20 6%)       +1.366ns       +0.031ns         impl 1 acx cls pro ext       gclk       125.0 MHz       148.5 MHz (+18.8%)       +1.257ns       +0.032ns         impl 1 acx cls pro ext       gclk       125.0 MHz       155.1 MHz (+24.1%)       +1.553ns       +0.032ns         impl 1 acx cls ubil       gclk       125.0 MHz       148.5 MHz (+18.6%)       +1.252ns       +0.032ns         impl 1 acx fan 500 seed ubil       gclk       125.0 MHz       148.2 MHz (+18.6%)       +1.424ns       +0.032ns         impl 1 acx fan 500 seed ubil       gclk       125.0 MHz       153.5 MHz (+22.8%)       +1.424ns       +0.032ns         impl 1 acx fan seed ubil bigblock       gclk       125.0 MHz       153.5 MHz (+22.8%)       +1.524ns       +0.032ns         impl 1 acx fan seed ubil bigblock       gclk       125.0 MHz       154.4 MHz (+23.6%)       +1.527ns       +0.032ns         impl 1 acx fan seed       gclk       125.0 MHz       154.5 MHz (+23.6%)       +1.527ns       +0.032ns         impl 1 acx fan seed       gclk       125.0 MHz       151.1 MHz (+20.9%)       +1.382ns       +0.032ns         impl 1 acx con ubil       gclk       125.0 MHz       151.1 MHz (+20.9%)       +1.031ns       +0.033ns                                                                                                                                                                                                                                                             | 1000001                               | impl_1                                                                                                                                   | gclk                    | 125.0 MHz           | 145.9 MHz (+16.7%)     | +1.145ns    | +0.036ns   |     |  |  |  |  |  |  |
| Impl 1 acx cis pro seed         gcik         125.0 MHz         155.1 MHz (+24.1%)         +1.553ns         +0.034ns           Impl 1 acx cis pro seed         gcik         125.0 MHz         148.2 MHz (+18.6%)         +1.252ns         +0.032ns           Impl 1 acx fan 500 seed util         gcik         125.0 MHz         153.1 MHz (+21.7%)         +1.424ns         +0.032ns           Impl 1 acx fan pro seed         gcik         125.0 MHz         153.5 MHz (+22.8%)         +1.486ns         +0.034ns           Impl 1 acx fan pro seed         gcik         125.0 MHz         154.4 MHz (+23.5%)         +1.524ns         +0.032ns           Impl 1 acx fan pro seed         gcik         125.0 MHz         154.5 MHz (+22.8%)         +1.524ns         +0.032ns           Impl 1 acx fan pro seed         gcik         125.0 MHz         154.5 MHz (+23.6%)         +1.524ns         +0.032ns           Impl 1 acx fan pro seed         gcik         125.0 MHz         154.5 MHz (+23.6%)         +1.032ns         +0.032ns           Impl 1 acx fan pro seed         gcik         125.0 MHz         148.5 MHz (+18.8%)         +1.06ns         +0.02ns           Impl 1 acx fan pro seed         gcik         125.0 MHz         143.5 MHz (+14.8%)         +1.031ns         +0.031ns           Impl 1 acx mix utl seed         gcik                                                                                                                                                                                                              | <b>S</b>                              | impl 1 acx all opt                                                                                                                       | gclk                    | 125.0 MHz           | 150.8 MHz (+20.6%)     | +1.368ns    | +0.031ns   |     |  |  |  |  |  |  |
| Impl 1 acx cis util         Qcik         125.0 MHz         148.2 MHz (+18.6%)         +1.252ns         +0.032ns           Impl 1 acx fan 500 seed util         gcik         125.0 MHz         152.1 MHz (+21.7%)         +1.424ns         +0.032ns           Impl 1 acx fan fxo seed         gcik         125.0 MHz         153.5 MHz (+22.8%)         +1.486ns         +0.032ns           Impl 1 acx fan fxo seed         gcik         125.0 MHz         153.5 MHz (+22.8%)         +1.486ns         +0.032ns           Impl 1 acx fan seed util biobiok         gcik         125.0 MHz         154.4 MHz (+23.5%)         +1.524ns         +0.032ns           Impl 1 acx fan seed util biobiok         gcik         125.0 MHz         154.5 MHz (+23.6%)         +1.527ns         +0.032ns           Impl 1 acx fan seed         gcik         125.0 MHz         151.1 MHz (+20.9%)         +1.382ns         +0.032ns           Impl 1 acx invs seed         gcik         125.0 MHz         143.5 MHz (+18.8%)         +1.031ns         +0.031ns           Impl 1 acx invs seed1         gcik         125.0 MHz         143.5 MHz (+14.8%)         +1.031ns         +0.033ns           Impl 1 acx invs seed21         gcik         125.0 MHz         144.9 MHz (+15.9%)         +1.32ns         +0.033ns           Impl 1 acx seed33         gcik                                                                                                                                                                                                               | 8                                     | impl 1 acx cls pro ext                                                                                                                   | gclk                    | 125.0 MHz           | 148.5 MHz (+18.8%)     | +1.267ns    | +0.032ns   |     |  |  |  |  |  |  |
| Impl       1 acx       fan       1 acx       i                                                                                                                                                                                                                                                                                                                                                                   |                                       | impl 1 acx cls pro seed                                                                                                                  | gclk                    | 125.0 MHz           | 155.1 MHz (+24.1%)     | +1.553ns    | +0.034ns   |     |  |  |  |  |  |  |
| Impl 1 acx fan pro seed       gclk       125.0 MHz       1535 MHz (+22.8%)       +1.486ns       +0.034ns         Impl 1 acx fan seed util bigblock       gclk       125.0 MHz       154.4 MHz (+23.5%)       +1.524ns       +0.032ns         Impl 1 acx fan seed util bigblock       gclk       125.0 MHz       154.5 MHz (+23.6%)       +1.527ns       +0.033ns         Impl 1 acx gpm       gclk       125.0 MHz       151.1 MHz (+20.9%)       +1.382ns       +0.032ns         Impl 1 acx gpm       gclk       125.0 MHz       151.1 MHz (+20.9%)       +1.383ns       +0.032ns         Impl 1 acx gpm       gclk       125.0 MHz       148.5 MHz (+18.8%)       +1.031ns       +0.032ns         Impl 1 acx mux util seed       gclk       125.0 MHz       148.5 MHz (+14.8%)       +1.031ns       +0.031ns         Impl 1 acx seed31       gclk       125.0 MHz       144.5 MHz (+14.8%)       +1.031ns       +0.033ns         Impl 1 acx seed32       gclk       125.0 MHz       144.9 MHz (+15.9%)       +1.138ns       +0.033ns         Impl 1 acx seed33       gclk       125.0 MHz       144.9 MHz (+19.8%)       +1.031ns       +0.033ns         Impl 1 acx seed32       gclk       125.0 MHz       145.7 MHz (+16.6%)       +1.138ns       +0.033ns       ingl 1 acx seed32       <                                                                                                                                                                                                                                                                   |                                       | impl 1 acx cls util                                                                                                                      | gclk                    | 125.0 MHz           | 148.2 MHz (+18.6%)     | +1.252ns    | +0.032ns   |     |  |  |  |  |  |  |
| Impl 1 acx fan seed util bigblock       gclk       125.0 MHz       154.4 MHz (+23.5%)       +1.524ns       +0.032ns         Impl 1 acx gpm       gclk       125.0 MHz       154.5 MHz (+23.6%)       +1.527ns       +0.033ns         Impl 1 acx gpm       gclk       125.0 MHz       154.5 MHz (+23.6%)       +1.527ns       +0.032ns         Impl 1 acx gpm       gclk       125.0 MHz       151.1 MHz (+20.9%)       +1.382ns       +0.032ns         Impl 1 acx gpm       gclk       125.0 MHz       148.5 MHz (+18.8%)       +1.266ns       +0.002ns         Impl 1 acx ws seed       gclk       125.0 MHz       143.5 MHz (+18.8%)       +1.031ns       +0.031ns         Impl 1 acx iws seed       gclk       125.0 MHz       143.5 MHz (+14.8%)       +1.021ns       +0.031ns         Impl 1 acx mux utl seed       gclk       125.0 MHz       143.5 MHz (+14.8%)       +1.031ns       +0.031ns         Impl 1 acx seed21       gclk       125.0 MHz       144.9 MHz (+15.9%)       +1.031ns       +0.033ns         Impl 1 acx seed33       gclk       125.0 MHz       144.9 MHz (+19.8%)       +1.032ns       +0.033ns         Impl 1 acx seed82 util       gclk       125.0 MHz       145.7 MHz (+18.6%)       +1.138ns       +0.033ns         Impl 1 acx wil cls seed                                                                                                                                                                                                                                                                                    |                                       | impl 1 acx fan500 seed util                                                                                                              | gclk                    | 125.0 MHz           | 152.1 MHz (+21.7%)     | +1.424ns    | +0.032ns   |     |  |  |  |  |  |  |
| Impl 1 acx app       gclk       125.0 MHz       154.5 MHz (+23.6%)       +1.527ns       +0.033ns         Impl 1 acx app       gclk       125.0 MHz       151.1 MHz (+20.9%)       +1.382ns       +0.032ns         Impl 1 acx app       gclk       125.0 MHz       151.1 MHz (+20.9%)       +1.266ns       +0.002ns         Impl 1 acx app       gclk       125.0 MHz       148.5 MHz (+18.8%)       +1.266ns       +0.002ns         Impl 1 acx mux utl seed       gclk       125.0 MHz       151.1 MHz (+20.9%)       +1.383ns       +0.031ns         Impl 1 acx mux utl seed       gclk       125.0 MHz       143.5 MHz (+14.8%)       +1.031ns       +0.033ns         Impl 1 acx ntd       gclk       125.0 MHz       143.5 MHz (+14.8%)       +1.02ns       +0.033ns         Impl 1 acx seed21       gclk       125.0 MHz       144.9 MHz (+15.9%)       +1.098ns       +0.031ns         Impl 1 acx seed33       gclk       125.0 MHz       149.7 MHz (+19.8%)       +1.031ns       +0.033ns         Impl 1 acx seed32 util       gclk       125.0 MHz       143.5 MHz (+18.8%)       +1.031ns       +0.033ns         Impl 1 acx seed match       gclk       125.0 MHz       153.1 MHz (+22.5%)       +1.468ns       +0.033ns         Impl 1 acx utl cls seed       gc                                                                                                                                                                                                                                                                                        |                                       | impl 1 acx fan pro seed                                                                                                                  | gclk                    | 125.0 MHz           | 153.5 MHz (+22.8%)     | +1.486ns    | +0.034ns   |     |  |  |  |  |  |  |
| Impl 1 acx app       gclk       125.0 MHz       151.1 MHz (+20.9%)       +1.382ns       +0.032ns         Impl 1 acx app       gclk       125.0 MHz       148.5 MHz (+18.8%)       +1.266ns       +0.002ns         Impl 1 acx iws seed       gclk       125.0 MHz       148.5 MHz (+18.8%)       +1.266ns       +0.002ns         Impl 1 acx iws seed       gclk       125.0 MHz       151.1 MHz (+20.9%)       +1.383ns       +0.031ns         Impl 1 acx iws seed       gclk       125.0 MHz       143.5 MHz (+14.8%)       +1.031ns       +0.031ns         Impl 1 acx ntd       gclk       125.0 MHz       143.5 MHz (-34.0%)       -4.122ns       +0.033ns         Impl 1 acx seed21       gclk       125.0 MHz       144.9 MHz (-15.9%)       +1.098ns       +0.033ns         Impl 1 acx seed33       gclk       125.0 MHz       144.7 MHz (+18.8%)       +1.138ns       +0.035ns         Impl 1 acx seed32 util       gclk       125.0 MHz       145.7 MHz (+16.6%)       +1.138ns       +0.035ns         Impl 1 acx seed       gclk       125.0 MHz       153.1 MHz (+22.5%)       +1.468ns       +0.035ns         Impl 1 acx util cls seed       gclk       125.0 MHz       143.5 MHz (+14.8%)       +1.031ns       +0.031ns         Impl 1 acx util cls seed <td< td=""><td></td><td>impl 1 acx fan seed util bigblock</td><td>gclk</td><td>125.0 MHz</td><td>154.4 MHz (+23.5%)</td><td>+1.524ns</td><td>+0.032ns</td><td></td></td<>                                                                                                                    |                                       | impl 1 acx fan seed util bigblock                                                                                                        | gclk                    | 125.0 MHz           | 154.4 MHz (+23.5%)     | +1.524ns    | +0.032ns   |     |  |  |  |  |  |  |
| Impl 1 acx opp util       gclk       125.0 MHz       148.5 MHz (+18.8%)       +1.266ns       +0.002ns         Impl 1 acx ives seed       gclk       125.0 MHz       151.1 MHz (+20.9%)       +1.383ns       +0.031ns         Impl 1 acx mux util seed       gclk       125.0 MHz       143.5 MHz (+14.8%)       +1.031ns       +0.031ns         Impl 1 acx mux util seed       gclk       125.0 MHz       143.5 MHz (+14.8%)       +1.031ns       +0.031ns         Impl 1 acx seed21       gclk       125.0 MHz       82.5 MHz (-34.0%)       -4.122ns       +0.031ns         Impl 1 acx seed33       gclk       125.0 MHz       144.9 MHz (+15.9%)       +1.098ns       +0.031ns         Impl 1 acx seed33       gclk       125.0 MHz       149.7 MHz (+19.8%)       +1.320ns       +0.033ns         Impl 1 acx seed32 util       gclk       125.0 MHz       145.7 MHz (+16.6%)       +1.138ns       +0.035ns         Impl 1 acx seed match       gclk       125.0 MHz       153.1 MHz (+22.5%)       +1.468ns       +0.031ns         Impl 1 acx util cls seed       gclk       125.0 MHz       143.5 MHz (+14.8%)       +1.031ns       +0.031ns         Impl 1 acx util cls seed       gclk       125.0 MHz       143.5 MHz (+14.8%)       +1.031ns       +0.032ns         Impl                                                                                                                                                                                                                                                                                |                                       | impl 1 acx gpm                                                                                                                           | gclk                    | 125.0 MHz           | 154.5 MHz (+23.6%)     | +1.527ns    | +0.033ns   |     |  |  |  |  |  |  |
| Impl 1 acx mux util seed       gclk       125.0 MHz       151.1 MHz (+20.9%)       +1.383ns       +0.031ns         Impl 1 acx mux util seed       gclk       125.0 MHz       143.5 MHz (+14.8%)       +1.031ns       +0.031ns         Impl 1 acx ntd       gclk       125.0 MHz       143.5 MHz (-34.0%)       -4.122ns       +0.033ns         Impl 1 acx seed21       gclk       125.0 MHz       144.9 MHz (+15.9%)       +1.098ns       +0.031ns         Impl 1 acx seed33       gclk       125.0 MHz       144.9 MHz (+19.9%)       +1.320ns       +0.033ns         Impl 1 acx seed32       util       gclk       125.0 MHz       145.7 MHz (+16.6%)       +1.138ns       +0.035ns         Impl 1 acx seed32 util       gclk       125.0 MHz       153.1 MHz (+22.5%)       +1.468ns       +0.035ns         Impl 1 acx util cls seed       gclk       125.0 MHz       153.1 MHz (+18.8%)       +1.031ns       +0.035ns         Impl 1 acx util cls seed       gclk       125.0 MHz       143.5 MHz (+14.8%)       +1.031ns       +0.031ns         Impl 1 acx util cls seed       gclk       125.0 MHz       143.5 MHz (+18.8%)       +1.031ns       +0.032ns                                                                                                                                                                                                                                                                                                                                                                                                  |                                       | impl 1 acx gpn                                                                                                                           | gclk                    | 125.0 MHz           | 151.1 MHz (+20.9%)     | +1.382ns    | +0.032ns   |     |  |  |  |  |  |  |
| Impl 1 acx mux util seed       gclk       125.0 MHz       143.5 MHz (+14.8%)       +1.031ns       +0.031ns         Impl 1 acx ntd       gclk       125.0 MHz       82.5 MHz (-34.0%)       -4.122ns       +0.033ns         Impl 1 acx seed21       gclk       125.0 MHz       144.9 MHz (+15.9%)       +1.098ns       +0.031ns         Impl 1 acx seed33       gclk       125.0 MHz       144.9 MHz (+15.9%)       +1.320ns       +0.033ns         Impl 1 acx seed32       gclk       125.0 MHz       149.7 MHz (+19.8%)       +1.320ns       +0.035ns         Impl 1 acx seed82 utili       gclk       125.0 MHz       145.7 MHz (+16.6%)       +1.138ns       +0.035ns         Impl 1 acx seed match       gclk       125.0 MHz       153.1 MHz (+22.5%)       +1.468ns       +0.033ns         Impl 1 acx util cls seed       gclk       125.0 MHz       143.5 MHz (+14.8%)       +1.031ns       +0.031ns         Impl 1 acx util cls seed       gclk       125.0 MHz       143.5 MHz (+14.8%)       +1.031ns       +0.031ns         Impl 1 acx util cls seed       gclk       125.0 MHz       143.5 MHz (+14.8%)       +1.031ns       +0.02ns                                                                                                                                                                                                                                                                                                                                                                                                                 |                                       | impl 1 acx gpn util                                                                                                                      | gclk                    | 125.0 MHz           | 148.5 MHz (+18.8%)     | +1.266ns    | +0.002ns   |     |  |  |  |  |  |  |
| Impl 1 acx ntd       gclk       125.0 MHz       82.5 MHz (-34.0%)       -4.122 ns       +0.033 ns         Impl 1 acx seed21       gclk       125.0 MHz       144.9 MHz (+15.9%)       +1.098 ns       +0.031 ns         Impl 1 acx seed33       gclk       125.0 MHz       144.9 MHz (+19.8%)       +1.320 ns       +0.033 ns         Impl 1 acx seed33       gclk       125.0 MHz       149.7 MHz (+19.8%)       +1.320 ns       +0.033 ns         Impl 1 acx seed82 util       gclk       125.0 MHz       145.7 MHz (+16.6%)       +1.138 ns       +0.035 ns         Impl 1 acx seed match       gclk       125.0 MHz       153.1 MHz (+22.5%)       +1.468 ns       +0.033 ns         Impl 1 acx util cls seed       gclk       125.0 MHz       143.5 MHz (+14.8%)       +1.031 ns       +0.031 ns         Impl 1 acx util pro       gclk       125.0 MHz       148.5 MHz (+18.8%)       +1.031 ns       +0.032 ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                       | impl 1 acx lws seed                                                                                                                      | gclk                    | 125.0 MHz           | 151.1 MHz (+20.9%)     | +1.383ns    | +0.031ns   |     |  |  |  |  |  |  |
| Impl 1 acx seed31       gclk       125.0 MHz       144.9 MHz (+15.9%)       +1.098ns       +0.031ns         Impl 1 acx seed33       gclk       125.0 MHz       149.7 MHz (+19.8%)       +1.320ns       +0.033ns         Impl 1 acx seed32 util       gclk       125.0 MHz       145.7 MHz (+16.6%)       +1.138ns       +0.035ns         Impl 1 acx seed match       gclk       125.0 MHz       153.1 MHz (+22.5%)       +1.468ns       +0.035ns         Impl 1 acx util cls seed       gclk       125.0 MHz       143.5 MHz (+14.8%)       +1.031ns       +0.031ns         Impl 1 acx util cls seed       gclk       125.0 MHz       148.5 MHz (+18.8%)       +1.031ns       +0.032ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                       | impl 1 acx mux utl seed                                                                                                                  | gclk                    | 125.0 MHz           | 143.5 MHz (+14.8%)     | +1.031ns    | +0.031ns   |     |  |  |  |  |  |  |
| Impl 1 acx seed33         gclk         125.0 MHz         149.7 MHz (+19.8%)         +1.320ns         +0.033ns           Impl 1 acx seed82 util         gclk         125.0 MHz         145.7 MHz (+16.6%)         +1.138ns         +0.035ns           Impl 1 acx seed82 util         gclk         125.0 MHz         153.1 MHz (+12.5%)         +1.468ns         +0.033ns           Impl 1 acx seed         gclk         125.0 MHz         153.1 MHz (+22.5%)         +1.468ns         +0.033ns           Impl 1 acx util cls seed         gclk         125.0 MHz         143.5 MHz (+14.8%)         +1.031ns         +0.031ns           Impl 1 acx util pro         gclk         125.0 MHz         148.5 MHz (+18.8%)         +1.266ns         +0.002ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                       | impl 1 acx ntd                                                                                                                           | gclk                    | 125.0 MHz           | 82.5 MHz (-34.0%)      | -4.122ns    | +0.033ns   |     |  |  |  |  |  |  |
| Impl 1 acx seed 82 uili         gclk         125.0 MHz         145.7 MHz (+16.6%)         +1.138ns         +0.035ns           Impl 1 acx seed match         gclk         125.0 MHz         153.1 MHz (+22.5%)         +1.468ns         +0.033ns           Impl 1 acx utl cis seed         gclk         125.0 MHz         143.5 MHz (+14.8%)         +1.031ns         +0.031ns           Impl 1 acx utl pro         gclk         125.0 MHz         148.5 MHz (+18.8%)         +1.266ns         +0.002ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                       | impl 1 acx seed21                                                                                                                        | gclk                    | 125.0 MHz           | 144.9 MHz (+15.9%)     | +1.098ns    | +0.031ns   |     |  |  |  |  |  |  |
| Impl 1 acx seed match         gclk         125.0 MHz         153.1 MHz (+22.5%)         +1.468ns         +0.033ns           Impl 1 acx utl cls seed         gclk         125.0 MHz         143.5 MHz (+14.8%)         +1.031ns         +0.031ns           Impl 1 acx utl cls seed         gclk         125.0 MHz         143.5 MHz (+18.8%)         +1.266ns         +0.002ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                       | impl 1 acx seed33                                                                                                                        | gclk                    | 125.0 MHz           | 149.7 MHz (+19.8%)     | +1.320ns    | +0.033ns   |     |  |  |  |  |  |  |
| impl 1 acx util cls seed         gclk         125.0 MHz         143.5 MHz (+14.8%)         +1.031ns         +0.031ns           impl 1 acx util pro         gclk         125.0 MHz         148.5 MHz (+18.8%)         +1.266ns         +0.002ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                       | impl 1 acx seed82 util                                                                                                                   | gclk                    | 125.0 MHz           | 145.7 MHz (+16.6%)     | +1.138ns    | +0.035ns   |     |  |  |  |  |  |  |
| impl 1 acx utl pro         gclk         125.0 MHz         148.5 MHz (+18.8%)         +1.266ns         +0.002ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                       | impl 1 acx seed match                                                                                                                    | gclk                    | 125.0 MHz           | 153.1 MHz (+22.5%)     | +1.468ns    | +0.033ns   |     |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                       | impl 1 acx utl cls seed                                                                                                                  | gclk                    | 125.0 MHz           | 143.5 MHz (+14.8%)     | +1.031ns    | +0.031ns   |     |  |  |  |  |  |  |
| ∫ t <sup>¢</sup> ∫ 23M of 35M û                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                       | impl 1 acx utl pro                                                                                                                       | gcik                    | 125.0 MHz           | 148.5 MHz (+18.8%)     | +1.266ns    | +0.002ns   | -   |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ] ∎≎                                  |                                                                                                                                          |                         |                     |                        |             | 23M of 35  | M 🗊 |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                       |                                                                                                                                          |                         |                     |                        |             |            |     |  |  |  |  |  |  |

Figure 217 • Multiprocess Summary Report from the First Incremental Run



The following screenshot shows the critical path in the best implementation of the run, impl\_1\_acx\_cls\_pro\_seed (actual results may differ).

Figure 218 • Critical Path (green) in the Best Multiprocess Implementation

Return to the Multiprocess View and check the **Copy Incremental Flow DB from Template Impl** checkbox. Optionally, change the radio button to **Existing Implementations** if desired (though this is not necessary). See the following screenshot.

| Edit Actions Example Tools Window Help                                               | ACE - Achronix CAD Environment - Version HS1.1 - proj_1->impl_1_acx_fan_seed_util_bigblock (AC16tSC01Hl01C)                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 🖑 🌣 🛠 🗎 🏦   🧿 💖   🔚 🕮 🗄                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Multiprocess 🕅                                                                       | se s                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| system.                                                                              | ementations executed simultaneously, and whether they are executed locally in the background, or submitted to an external cloud/grid/batch job                                                                                                                                                                                                                                                                                                                                                                                                             |
| Parallel Job Count: 25                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Enable Job Submission System (configur                                               | (ed in Preferences)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Multiprocess Flow Management                                                         | esired flow steps that all multiprocess implementations should follow. Then in the combo-box below, select how far through the flow the                                                                                                                                                                                                                                                                                                                                                                                                                    |
| implementations should run. (This provides                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Stop Flow After: Run Post-Route Timing A                                             | nalysis 🗸                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Force Selected Flow St                                                               | tep to be Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| - Select Implementations                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| implementations with the same name.) W<br>enabled, the user can optionally choose to | Active Project should be queued for execution. (Option Set Implementations will be created if they don't already exist, or will overwrite existing<br>when the "Start Selected" button is pressed, the selected implementations will run using the current Flow configuration. When Incremental Compile is<br>copy the Incremental Compile DB file from the template (active) implementation to all the other implementations before running the flow. This allow<br>revious run and copy the unchanged partition place and route data to the other impls. |
| Existing Implementations                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| O Generate Implementations from Option                                               | un Sets                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Copy Incremental Flow DB From Templ                                                  | ate Impl                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Implementation Ex                                                                    | xecution State Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 🗹 💭 impl 1                                                                           | Selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| ☑                                                                                    | Selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 🗹 💭 impl_1_acx_cls_pro_ext                                                           | Selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 🗹 💭 impl_1_acx_cls_pro_seed                                                          | Selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 🗹 💭 impl_1_acx_cls_util                                                              | Selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 🗹 💭 impl_1_acx_fan_pro_seed                                                          | Selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 🗹 💭 impl_1_acx_fan_seed_util_bigblock                                                | Selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 🗹 💭 impl_1_acx_fan500_seed_util                                                      | Selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 🗹 💭 impl_1_acx_gpm                                                                   | Selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 🗹 💭 impl_1_acx_gpn                                                                   | Selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 🗹 💭 impl_1_acx_gpn_util                                                              | Selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 🗹 💭 impl_1_acx_lws_seed                                                              | Selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                                      | Selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 🗹 🕮 impl_1_acx_mux_utl_seed                                                          | Selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| ☑                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                                                      | Selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <pre>✓</pre>                                                                         | Selected<br>Selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| ☑                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

#### Figure 219 • Multiprocess View with the

The Template implementation referred to in the checkbox is the implementation to be used as the source for all unchanged partitions in the next incremental compile. The Template implementation is the same as the Active implementation. From the Projects View of the Projects Perspective, click the triangle to the left of the Project name to expand the list of implementations. Then left-click on the desired implementation (the one with the best performance) to make it the Active implementation. The implementation name of the active implementation turns bold and is highlighted as in the following screenshot.



Figure 220 • Selection of the Template (Active) Implementation

## Step 4: Change the RTL and Recompile the Design in Synplify Pro

Repeat Steps 8-10 of the Single-Process Incremental Compile Tutorial (page 408) to modify the RTL and force Syplify Pro to recompile the partitions in at least one of the defined compile points.

### Step 5: Recompile the Multiprocess Implementations in ACE

Click the three stacked green triangle icon in the Multiprocess view to start a new incremental compile iteration on all implementations in parallel. ACE automatically copies the output/<design>.icdb file from the Template implementation into all other implementations and uses that as the source for the tear-and-stitch operation on all unchanged partitions during the run\_prepare flow step.

As seen in the following screenshot from the  $impl_1_acx_mux_utl_seed$  implementation, only 8 of the 37 partitions have been recompiled in this iteration.

| Edit Actions E                                                                                        |                                                |                   | - · ·                             |        |          |          |       |       |        |        |       |        |       |       |        |        |             |            |                   |            |                          |           |           |        |           |           |                   |        |        |
|-------------------------------------------------------------------------------------------------------|------------------------------------------------|-------------------|-----------------------------------|--------|----------|----------|-------|-------|--------|--------|-------|--------|-------|-------|--------|--------|-------------|------------|-------------------|------------|--------------------------|-----------|-----------|--------|-----------|-----------|-------------------|--------|--------|
| ∃⊜ &%⊀                                                                                                |                                                |                   |                                   |        |          |          |       | 01    |        |        |       |        |       |       |        | -      |             |            |                   |            |                          |           |           |        |           |           |                   |        |        |
| Partition Repo                                                                                        | rt — rpu_top                                   | a imir            | ig Report -                       | Route  | ea — 1   | pu_to    | p 23  |       | CK/Res | ес кер | ort – | rpu_co | pb E  | Utili | zatior | п керс | ort - Route | ed — fpu_t | ор                |            |                          |           |           |        |           | _         |                   | _      | _      |
| Partition R                                                                                           | eport                                          |                   |                                   |        |          |          |       |       |        |        |       |        |       |       |        |        |             |            |                   |            |                          |           |           |        |           |           |                   |        |        |
| ACE Achronix CA<br>Design: proj_1 - im<br>Device: AC16tSC01<br>Generated on Wed<br>Host: cad40.achror | pl_1_acx_cls_pro<br>HI01C<br>Oct 12 23:04:38 P | _seed - fpu_top   | Build 95908*-                     | Date 2 | 2016-10- | 12 14:50 | D     |       |        |        |       |        |       |       |        |        |             |            |                   |            |                          |           |           |        |           |           |                   |        |        |
| Summary                                                                                               |                                                |                   |                                   |        |          |          |       |       |        |        |       |        |       |       |        |        |             |            |                   |            |                          |           |           |        |           |           |                   |        |        |
| Number of parti     Number of insta     Number of nets                                                | ances: 51123 (155                              | 72 re-compiled, 3 |                                   |        |          |          |       |       |        |        |       |        |       |       |        |        |             |            |                   |            |                          |           |           |        |           |           |                   |        |        |
| Details<br>Partition Name                                                                             | Module Name                                    | Re-Compiled?      | Timestamp                         | Туре   | Nets     | Insts    | LUTs  | Flops | MUX4s  | MUX8s  | ALUs  | LRAMs  | BRAMs | DSPs  | IPINs  | OPINs  | CLK_IPINs   | CLK_OPINs  | Boundary<br>Input | Output     | Registered<br>Input Nets |           | Input     | Output | Input     | Output    | Dangling<br>Input | Output | Feedtl |
| /fpu_top<br>/fpu_inst[1].i_fpu<br>/fpu_mul                                                            | fpu_mul                                        | Yes               | Wed 12 Oct<br>2016<br>10:46:51 PM | Locked | 4352     | 3485     | 2641  | 774   | 0      | 0      | 64    | 0      | 0     | 6     | 0      | 0      | 0           | 0          | Nets              | Nets<br>53 | 1                        | Nets<br>0 | Nets<br>0 | Nets   | Nets<br>0 | Nets<br>0 | Nets<br>0         | Nets   | 0      |
| /fpu_top                                                                                              | fpu_mul                                        | Yes               | Wed 12 Oct<br>2016<br>10:46:51 PM | Locked | 4352     | 3485     | 2641  | 774   | 0      | 0      | 64    | 0      | 0     | 6     | 0      | 0      | 0           | 0          | 113               | 53         | 1                        | 0         | 0         | 1      | 0         | 0         | 0                 | 1      | 0      |
| /fpu_top<br>/fpu_inst[2].i_fpu<br>/fpu_mul                                                            | fpu_mul                                        | Yes               | Wed 12 Oct<br>2016<br>10:46:51 PM | Locked | 4352     | 3485     | 2641  | 774   | 0      | 0      | 64    | 0      | 0     | 6     | 0      | 0      | 0           | 0          | 113               | 53         | 1                        | 0         | 0         | 1      | 0         | 0         | 0                 | 1      | 0      |
| /fpu_top<br>/fpu_inst[3].i_fpu<br>/fpu_mul                                                            | fpu_mul                                        | Yes               | Wed 12 Oct<br>2016<br>10:46:51 PM | Locked | 4352     | 3485     | 2641  | 774   | 0      | 0      | 64    | 0      | 0     | 6     | 0      | 0      | 0           | 0          | 113               | 53         | 1                        | 0         | 0         | 1      | 0         | 0         | 0                 | 1      | 0      |
| /fpu_top<br>/fpu_inst[0].i_fpu<br>/fpu_mul<br>/fpu_mul_ctl                                            | fpu_mul_ctl                                    | Yes               | Wed 12 Oct<br>2016<br>10:46:51 PM | Locked | 552      | 408      | 218   | 188   | 0      | 0      | 2     | 0      | 0     | 0     | 0      | 0      | 0           | 0          | 133               | 78         | 3                        | 7         | 1         | 1      | 0         | 0         | o                 | 0      | 3      |
| /fpu_top<br>/fpu_inst[1].i_fpu<br>/fpu_mul<br>/fpu_mul_ctl                                            | fpu_mul_ctl                                    | Yes               | Wed 12 Oct<br>2016<br>10:46:51 PM | Locked | 552      | 408      | 218   | 188   | 0      | 0      | 2     | 0      | 0     | 0     | 0      | 0      | 0           | 0          | 133               | 78         | 3                        | 7         | 1         | 1      | 0         | 0         | 0                 | 0      | 3      |
| /fpu_top<br>/fpu_inst[2].i_fpu<br>/fpu_mul<br>/fpu_mul_ctl                                            | fpu_mul_ctl                                    | Yes               | Wed 12 Oct<br>2016<br>10:46:51 PM | Locked | 552      | 408      | 218   | 188   | 0      | 0      | 2     | 0      | 0     | 0     | 0      | 0      | 0           | 0          | 133               | 78         | 3                        | 7         | 1         | 1      | 0         | 0         | 0                 | 0      | з      |
| /fpu_top<br>/fpu_inst[3].i_fpu<br>/fpu_mul<br>/fpu_mul_ctl                                            | fpu_mul_ctl                                    | Yes               | Wed 12 Oct<br>2016<br>10:46:51 PM | Locked | 552      | 408      | 218   | 188   | o      | 0      | 2     | 0      | 0     | 0     | 0      | 0      | 0           | 0          | 133               | 78         | 3                        | 7         | 1         | 1      | o         | 0         | 0                 | 0      | з      |
| /fpu_top                                                                                              | fpu_top                                        | No                | Wed 12 Oct<br>2016<br>10:06:52 PM | Hard   | 23134    | 19707    | 13406 | 5320  | 154    | 0      | 308   | 0      | 0     | 0     | 364    | 154    | 1           | 0          | 0                 | 0          | 0                        | 0         | 0         | 0      | o         | 0         | 0                 | 0      | 0      |
| /fpu_div                                                                                              | fpu_div                                        | No                | Wed 12 Oct<br>2016<br>10:06:52 PM | Locked | 2119     | 1827     | 1314  | 491   | 0      | 0      | 22    | 0      | 0     | 0     | 0      | 0      | 0           | 0          | 129               | 65         | 1                        | 0         | 0         | 1      | 0         | 0         | 0                 | 1      | 0      |
| /fpu_div                                                                                              | fpu_div                                        | No                | Wed 12 Oct<br>2016<br>10:06:52 PM | Locked | 2119     | 1827     | 1314  | 491   | 0      | 0      | 22    | 0      | 0     | 0     | 0      | 0      | 0           | 0          | 129               | 65         | 1                        | 0         | 0         | 1      | 0         | 0         | 0                 | 1      | 0      |
| /fpu_top<br>/fpu_inst[2].i_fpu<br>/fou_div                                                            | fpu_div                                        | No                | Wed 12 Oct<br>2016<br>10:06:52 PM | Locked | 2119     | 1827     | 1314  | 491   | 0      | 0      | 22    | 0      | 0     | 0     | 0      | 0      | 0           | 0          | 129               | 65         | 1                        | o         | 0         | 1      | 0         | 0         | 0                 | 1      | 0      |

### Figure 221 • Partition Report from Second Incremental Multiprocess Compile

After all of the parallel runs complete, return to the updated Multiprocess Summary Report in the Multiprocess View to examine the critical path reports for each implementation.

As seen in the example below, the impl\_1\_acx\_clk\_pro\_seed implementation achieved 155.1 MHz in the first iteration and 148.2 MHz in the second iteration. One of the incremental compiles, for impl\_acx\_fan\_pro\_seed, failed to route and returned a Flow Error.

| 👜   ؇ 🌭 🐇 🗎 📗 🖉 🎗                                                                                                          | ?   📔 🖷 😰                                | 🗗 🗗   🗇 🔷 🍕                                      | •                                                          |                             |                |
|----------------------------------------------------------------------------------------------------------------------------|------------------------------------------|--------------------------------------------------|------------------------------------------------------------|-----------------------------|----------------|
| Partition Report                                                                                                           | tilization Rep                           | o 🗎 Mult                                         | ti-process Sum 🕱                                           | »2                          |                |
| ACE Achronix CAD Environment<br>Project: proj_1<br>Generated by: mikeriepe on cad37.a<br>Generated on: 2016-10-12 11:18:21 | Version HS1.1                            | ort                                              |                                                            |                             |                |
| iming Results Summary                                                                                                      | ,                                        |                                                  |                                                            |                             |                |
| This section shows the high-level tir<br>further timing details, see the linked<br>iming Analysis Summary                  | ning results obtair<br>individual timing | ned from the timing re<br>reports (in each imple | ports that were generated d<br>ementation's own reports di | uring this mul<br>rectory). | ti-process rur |
|                                                                                                                            |                                          |                                                  | Post                                                       | -Route                      |                |
| Impl Name                                                                                                                  | Clock Domain                             | Target Frequency                                 | Upper-Limit Frequency                                      | Setup Slack                 | Hold Slack     |
| <u>impl_1</u>                                                                                                              | gclk                                     | 125.0 MHz                                        | 150.1 MHz (+20.1%)                                         | +1.338ns                    | +0.033ns       |
| impl 1 acx all opt                                                                                                         | gclk                                     | 125.0 MHz                                        | 149.7 MHz (+19.8%)                                         | +1.319ns                    | +0.032ns       |
| impl 1 acx cls pro ext                                                                                                     | gclk                                     | 125.0 MHz                                        | 145.6 MHz (+16.5%)                                         | +1.132ns                    | +0.034ns       |
| impl 1 acx cls pro seed                                                                                                    | gclk                                     | 125.0 MHz                                        | 148.2 MHz (+18.5%)                                         | +1.252ns                    | +0.032ns       |
| impl 1 acx cls util                                                                                                        | gclk                                     | 125.0 MHz                                        | 143.1 MHz (+14.5%)                                         | +1.014ns                    | +0.033ns       |
| impl 1 acx fan500 seed util                                                                                                | gclk                                     | 125.0 MHz                                        | 148.2 MHz (+18.6%)                                         | +1.253ns                    | +0.033ns       |
| impl_1_acx_fan_pro_seed<br>(Flow Error)                                                                                    |                                          |                                                  |                                                            |                             |                |
| impl 1 acx fan seed util bigblock                                                                                          | gclk                                     | 125.0 MHz                                        | 147.4 MHz (+17.9%)                                         | +1.217ns                    | +0.033ns       |
| impl 1 acx gpm                                                                                                             | gclk                                     | 125.0 MHz                                        | 139.5 MHz (+11.6%)                                         | +0.832ns                    | +0.033ns       |
| impl 1 acx gpn                                                                                                             | gclk                                     | 125.0 MHz                                        | 148.4 MHz (+18.8%)                                         | +1.263ns                    | +0.033ns       |
| impl 1 acx gpn util                                                                                                        | gclk                                     | 125.0 MHz                                        | 150.5 MHz (+20.4%)                                         | +1.357ns                    | +0.033ns       |
| impl 1 acx lws seed                                                                                                        | gclk                                     | 125.0 MHz                                        | 152.1 MHz (+21.6%)                                         | +1.424ns                    | +0.034ns       |
| impl 1 acx mux utl seed                                                                                                    | gclk                                     | 125.0 MHz                                        | 151.0 MHz (+20.8%)                                         | +1.376ns                    | +0.033ns       |
| impl 1 acx ntd                                                                                                             | gclk                                     | 125.0 MHz                                        | 83.6 MHz (-33.2%)                                          | -3.967ns                    | +0.033ns       |
| impl 1 acx seed21                                                                                                          | gclk                                     | 125.0 MHz                                        | 149.5 MHz (+19.6%)                                         | +1.311ns                    | +0.033ns       |
| impl 1 acx seed33                                                                                                          | gclk                                     | 125.0 MHz                                        | 143.4 MHz (+14.7%)                                         | +1.025ns                    | +0.033ns       |
| impl 1 acx seed82 util                                                                                                     | gclk                                     | 125.0 MHz                                        | 147.8 MHz (+18.2%)                                         | +1.234ns                    | +0.033ns       |
| impl 1 acx seed match                                                                                                      | gclk                                     | 125.0 MHz                                        | 134.6 MHz (+7.7%)                                          | +0.573ns                    | +0.033ns       |
| impl 1 acx utl cls seed                                                                                                    | gclk                                     | 125.0 MHz                                        | 151.0 MHz (+20.8%)                                         | +1.376ns                    | +0.033ns       |
|                                                                                                                            |                                          | 1                                                | I                                                          |                             | I              |

### Figure 222 • Multiprocess Summary Report from the Second Incremental Run

Finally, select **File**  $\rightarrow$  **Restore Implementation** to restore the routed.acxdb database for the Template implementation, and select **Actions**  $\rightarrow$  **Timing**  $\rightarrow$  **Run Post-Route Timing Analysis** to observe the new critical path. The following screenshot shows the critical path in the Template implementation after recompiling all of the changed partitions.

As usual, the instances of all unchanged partitions are highlighted in a dark yellow color to indicate that they are locked.



### Figure 223 • Critical Path (Green) from the Best Multiprocess Implementation of the Second Incremental Run

All timing paths inside the unchanged partitions can be observed to remain the same. Once timing closure of a critical block in at least one of the multiprocess implementations is achieved, this flow allows timing closure to be maintained until that block must be recompiled.

451

# Automatic Flop Pushing into I/O Pins

The term "flop pushing" refers to the process of converting an unregistered I/O pin, plus one or more attached DFFs, into a registered I/O pin. The purpose of flop pushing is to help with chip I/O timing closure. By avoiding the pin-to-flop, or flop-to-pin, delays, extra margin is achieved for off-chip timing paths.

# Background

The flop-pushing feature is necessary in ACE because Synplify-Pro does not support inferencing of registered I/O pins. The following Verilog source code describes a simple design consisting of two flip-flops, plus a set of IPIN and OPIN instances that have been behaviorally instantiated in a top-level wrapper module.

### Verilog Design File

```
1
     module TEST_TOP (in, rst, ce, clk, out)
 2
          input in, rst, ce, clk;
 3
          output out;
 4
 5
          IPIN
                   ipin_in (.din(in), .dout(in_p));
 6
          IPIN
                   ipin_rst (.din(rst), .dout(rst_p));
 7
          IPIN
                   ipin_ce (.din(ce), .dout(ce_p));
 8
          CLK_IPIN ipin_clk (.din(clk), .dout(clk_p));
 9
          OPIN
                   opin_out (.din(out), .dout(out_p));
10
11
          TEST test (.in(in_p), .rst(rst_p), .ce(ce_p), .clk(clk_p), .out(out_p));
12
13
     endmodule
14
15
     module TEST (in, rst, ce, clk, out)
16
          input in, rst, ce, clk;
17
          output out;
18
          reg out;
19
20
          wire dff_q;
21
22
          ACX_DFFER dff (.d(in), .clk(clk), .ce(ce), .rn(rst), .q(dff_q));
23
24
          always @(posedge clk or negedge rst)
25
          begin
26
              if (!rst)
27
                 out <= 0;
28
             else
29
                if (ce) out <= dff_q;</pre>
30
          end
31
     endmodule
```

Alternatively, the IPINs and OPINs could be instantiated in the netlist with a set of create\_boundary\_pins Tcl commands in a separate .pdc constraints file, as follows.

#### **PDC Constraints File**

| 1 | <pre>create_boundary_pins {p:in} {ipin_in}</pre>   |
|---|----------------------------------------------------|
| - |                                                    |
| 2 | <pre>create_boundary_pins {p:rst} {ipin_rst}</pre> |
| 3 | create_boundary_pins {p:ce} {ipin_ce}              |
| 4 | <pre>create_boundary_pins {p:clk} {ipin_clk}</pre> |
| 5 | <pre>create_boundary_pins {p:out} {opin_out}</pre> |

When structurally instantiating the IPINs and OPINs, one could register the I/Os by connecting the clk, ce, and rstn inputs. But the create\_boundary\_pins constraints will not register the I/Os.

By placing the flops in the device core as separate instances, extra delay from the pin to the flop is incurred on the I/ O-ring-to-core routing path. If the device's I/O timing is tight, that could result in an external setup timing failure. On the other hand, the presence of separate DFFER instances allows the flops to be placed in the core near their fan-in/ fan-out logic, possibly reducing the routing delay from the flop to intermediate logic in the design. Flop pushing can therefore be viewed as a form of optional retiming, allowing the designer the ability to trade off-chip for on-chip delays between the I/O pins and the boundary flops.

In ACE, flop pushing is performed by a command called the *reconditioner* during the run\_prepare flow step. Flop pushing happens very early in the prepare flow, after flattening and elaboration. You will see messages like the following in the ACE logfile.

```
INF0: Running netlist reconditioner...
INF0: Reconditioning post_elaborate TEST_TOP
INF0: For detailed information see the file: ace/impl_1/pnr/log/
test_recondition_post_elaborate.log
INF0: Pushed DFFs into 1 of 1 candidate IPIN output pins
INF0: Pushed DFFs into 1 of 1 candidate OPIN input pins
INF0: Reconditioning complete (runtime = 00:00:00)
```

# Capabilities

In the simplest case, ACE performs flop pushing by executing the following algorithm:

- 1. Finding an IPIN that drives a DFF, or a DFF that drives an OPIN
- 2. Deleting the DFF
- 3. Converting the IPIN/OPIN into a flopped IPIN/OPIN by making the following changes:
  - a. Connecting the DFF clock input to the IPIN/OPIN clock input
  - b. Optionally connecting the DFF reset and enable inputs to the IPIN/OPIN reset and enable inputs
  - c. Changing the IPIN/OPIN's mode parameter from "0" to "1"
  - d. Moving the value of the init and sr\_assertion attributes from the DFF to the IPIN/OPIN

Flop pushing is supported for flops connected to IPIN data output pins, and OPIN data input pins. For obvious reasons it is not supported for CLK\_IPINs or CLK\_OPINs. ACE also supports more complex cases:

- IPINs that drive more than one DFF
- · Chains of buffer LUTs and inverter LUTs between the pad and the DFF

• OPINs in which the data input and the clock-enable input are both driven by DFFs

The reconditioner checks for many possible scenarios that prevent flops pushing, especially in the above complex cases. A partial list of such exceptions includes:

- The IPIN or OPIN is already registered
- DFFs in the IPIN fanout do not all share the same clock input nets
- · DFFs in the IPIN fanout do not all share the same set, reset, or enable input nets
- DFFs in the IPIN fanout are a mixture of DFF, DFFC, DFFP, DFFR, and/or DFFS instances
- · DFFs in the IPIN fanout have a mixture of synchronous and asynchronous resets
- · DFFs in the IPIN fanout are a mixture of positive and negative edge triggered
- DFFs in the IPIN fanout have different init parameter values
- A DFF in the IPIN fanout is driven by more than one input pin, or drives more than one output pin
- · A DFF clock is driven by a generated clock or reset that can only be routed in the core (not the I/O ring)
- LUTs between the IPIN/OPIN and DFF are configured as anything but a buffer or inverter
- Nets on the path between the IPIN/OPIN and DFF (including intermediate buffers or inverters) have a fanout greater than one
- DFFs driven by a IPIN/OPIN through a chain of buffers and/or inverters that have different inversion (odd vs. even number of inverters)

# ACE Implementation Options

The behavior of ACE with respect to flop pushing is controlled globally by the implementation options push\_flops\_into\_pads and pad\_flop\_pushing\_clock\_type, described below. See the **Options View** (page 100) section for more information about implementation options. Flop pushing can also be controlled on a per-instance basis using the ace\_useioff attribute, as described in the next section **ACE Attributes** (page 455).

## push\_flops\_into\_pads

The implementation option push\_flops\_into\_pads controls whether flop pushing is performed automatically or manually. This implementation option has the following legal settings:

- "0" flop pushing is completely disabled
- "1" (manual mode) push flops into pads that have the ace\_useioff attribute set to "1"
- "15" (automatic mode) push flops into all pads *except* those that have the ace\_useioff attribute set to "0"

### **Example Setting**

set\_impl\_option push\_flops\_into\_pads 15

## pad\_flop\_pushing\_clock\_type

The implementation option  $pad_flop_pushing_clock_type$  enables automatic flop pushing to be controlled by the routing type of the pushed clock. The option only applies when the implementation option

UG070

push\_flops\_into\_pads has the value "15" (automatic mode). This implementation option has the following legal settings:

- "boundary" automatically push flops into pads only when the flops are clocked by a boundary clock
- "trunk" automatically push flops into pads only when the flops are clocked by a trunk clock
- · "all" automatically push flops into all pads regardless of the clock routing type

The routing type of a clock net is controlled by the set\_clock\_type command.

#### set\_clk\_type Examples

```
set_clock_type clk1 -boundary
set_clock_type clk2 -trunk
set_impl_option pad_flop_pushing_clock_type "boundary"
```

In the above example, only flops clocked by the boundary clock clk1 are automatically pushed in the pads.

# ACE Attributes

The behavior of ACE with respect to flop pushing can be controlled for individual input/output pads with the ace\_useioff synthesis attribute. The attribute has the following semantics:

- If the ace\_useioff attribute associated with an I/O pin has a non-zero value, ACE pushes flip-flops into that pin when possible. This behavior is useful when the push\_flops\_into\_pads implementation option has the value 1 (manual mode).
- If the ace\_useioff attribute associated with an I/O pin has the value 0, ACE prevents flip-flops from being
  automatically pushed into that pin. This behavior is useful when the push\_flops\_into\_pads implementatio
  n option has a value of 15 (automatic mode).



#### Figure 224 • Valid Locations to Place the ace\_useioff Attribute in an eFPGA Design Hierarchy

The ace\_useioff attribute can be placed in several different locations in your RTL code, as shown in the figure above, and as described below.

- On a top-level module port (A) connected to an IPIN/OPIN
- On a net (B) connecting an IPIN/OPIN to a top-level module port
- On an IPIN/OPIN instance (C)
- On a net (D) connecting an IPIN/OPIN to a hierarchical module pin
- · On a net (E) connecting a hierarchical module port to one or more flip-flop instances
- On one or more flip-flop instances (F) driven by an IPIN instances or driving an OPIN instance

If there is more than one flip-flop driven by the same IPIN, all DFF instances must have a ace\_useioff attribute with the same value.

The ace\_useioff cannot be placed in the following location:

• On the an intermediate port (1) separating two levels of hierarchy. Synplify-Pro does forward annotate attributes on intermediate *output* ports, but when placed on intermediate *input* ports the attributes are lost during flattening, so this method is not recommended

Be careful not to add the ace\_useioff attributes in more than one location relative to a given I/O pin. A conflict occurs when some attributes associated with particular I/O pin have the value "1", and some have the value "0". When a conflict is detected, ACE issues a warning message, the value "0" is assumed, and flop pushing is disabled for that I/O. Be especially careful to avoid conflicts when the attributes are placed on DFF instances, and an IPIN drives more than one DFF.

The ace\_useioff attributes can be specified by the user in the Verilog/VHDL source code, or in the physical design constraints (.pdc) file, as shown in the following examples. An advantage of specifying the attribute in the .pdc file is that it is not necessary to re-compile the design in order to experiment with different flop-pushing strategies. An advantage of specifying the attribute in the HDL source code is that the intent of the designer is more self-documenting, as readers do not have to refer to a separate .pdc file and cross-reference the port/net/instance names between the files.

## Examples

Several examples follow demonstrating how to set the ace\_useioff attribute on:

- Top-level ports
- I/O pin instances
- Boundary wires
- DFF instances

Also demonstrated is whether to use either Verilog, VHDL, or a PDC constraint. For more information about the use of attributes in Synplify, see the section "Forward Annotation of RTL Attributes to Netlist" in the Synthesis Optimization Recommendations chapter of the *Synthesis User Guide* (UG018).

#### Verilog Example of a Port attribute

```
module flop_push_test1 (ina, inb, sel, clk, z0);
input [3:0] ina /* synthesis ace_useioff=1 */;
```

```
input [3:0] inb /* synthesis ace_useioff=0 */;
input sel /* synthesis ace_useioff=1 */;
input clk;
output z0 /* synthesis ace_useioff=1 */;
endmodule
```

### VHDL Example of a Port Attribute

```
entity flop_push_test1 is
port(
        ina
               : in signed( 3 downto 0 );
        inb
               : in signed( 3 downto 0);
              : in std_logic;
        sel
              : in std_logic;
        clk
        z0
               : out std_logic
);
attribute ace_useioff : boolean;
attribute ace_useioff of ina : signal is TRUE;
attribute ace_useioff of inb : signal is FALSE;
attribute ace_useioff of sel : signal is TRUE;
attribute ace_useioff of z0 : signal is TRUE;
```

end entity;

Physical Design Constraints (.pdc) File of Port Attributes

set\_property ace\_useioff "1" [find -ports {ina\[\*\]}]
set\_property ace\_useioff "0" [find -ports {inb\[\*\]}]
set\_property ace\_useioff "1" {p:sel p:z0}

### (i) Note

In the above three examples, the input port bus ina, the input port sel, and the output port z0 are selected for flop pushing. The input port bus inb, the input port clk, are not.

If the ace\_useioff attribute has the value "1", ACE tries to push a flip-flop into the pad connected to the given port even when flop pushing is disabled by default. If the attribute has the value "0", ACE prevents flop pushing on that pad, even if flop pushing is enabled by default. Of course flop pushing may be prevented by any of the exceptions listed **above** (page 454).

It is not possible, using RTL attributes, to apply different values of the ace\_useioff attribute to different ports in a port bus (e.g, giving in\_a[2] a ace\_useioff value of "0"). It also cannot be done by applying an attribute to a wire that is assigned the value of the bus (see the following example, flop\_push\_test5). The solution requires bit-blasting the bus into separate ports or assigning different values of ace\_useioff to different bus ports using PDC constraints.

#### Verilog Example of an IPIN Instance Attribute

```
module flop_push_test2 (in, clk);
input [38:0] in;
input clk;
wire ipin_dout_37;
IPIN ipin_37( .din(in[37]) , .dout(ipin_dout_37) ) /* synthesis ace_useioff = 0 */;
reg data_37 = 1'b0;
always @(posedge clk)
begin
data_37 <= ipin_dout_37;
end
endmodule
```

#### Physical Design Constraints (.pdc) File of IPIN Instance Attributes

```
set_property ace_useioff "1" [find -insts {ipin_*}]
set_property ace_useioff "0" {i:ipin_37}
```

#### Verilog Example of a Boundary Wire Attribute

```
module flop_push_test3 (in, clk);
input [38:0] in;
input clk;
(* syn_keep *) wire ipin_dout_37 /* synthesis ace_useioff=0 */;
IPIN ipin_37 (.pad(in[37]), .dout(ipin_dout_37));
reg level1_37 = 1'b0;
always @(posedge clk[0])
begin
level1_37 <= ipad_dout_37;
end
endmodule
```

Physical Design Constraints (.pdc) File of Wire Attributes

```
set_property ace_useioff "1" [find -nets {ipin_dout_*}]
set_property ace_useioff "0" {n:ipin_dout_37}
```

#### Verilog Example of a DFF Instance Attribute

```
module flop_push_test4 (in, clk);
    input [38:0] in;
    input clk;
    wire ipin_dout_37;
    IPIN ipin_37(.din(in[37]), .dout(ipin_dout_37));
    wire dff1_q, dff2_q;
    ACX_DFF dff1 (.d(ipin_dout_37), .clk(clk), q(dff1_q)) /* synthesis ace_useioff = 0
*/;
    ACX_DFF dff2 (.d(ipin_dout_37), .clk(clk), q(dff2_q)) /* synthesis ace_useioff = 0
*/;
endmodule
```

Physical Design Constraints (.pdc) File of DFF Instance Attributes

```
set_property ace_useioff "1" [find -insts {dff*}]
set_property ace_useioff "0" {i:dff1 i:dff2}
```

The following is an example of a boundary wire attribute that *does not* work as expected.

### Caution!

As noted above, it is not possible using RTL attributes to apply different values of the ace\_useioff attribute to different ports in a port bus. The above example, flop\_push\_test5, appears to be a clever way to apply the ace\_useioff attribute to the net connecting the UCM port to a single IPIN in the 39-bit port bus in. Unfortunately, this technique does not work. Synplify Pro optimizes away the wire ipin\_din\_37, despite the presence of the syn\_keep attribute, and the ace\_useioff attribute is not forward-annotated into the ACE input netlist. One can use PDC, however, to apply the ace\_useioff attribute to the following example.

### Physical Design Constraints (.pdc) For Example flop\_push\_test5 That DOES Work

```
set_property ace_useioff "1" [find -nets {in\[*\]}]
set_property ace_useioff "0" {n:in\[37\]}
```

# **Timing Analysis Implications**

As discussed above, flop pushing can be viewed as a form of retiming. Pushing a flop into a boundary pin reduces the off-chip timing path at the flop input by reducing the wiring delay. But it increases the on-chip timing path at the flop output, possibly by a large amount depending on how closely the driven logic is placed to the boundary pin. On small designs, especially when the logic is placed near the center of the chip, the increased delay can be significant.

Enabling flop pushing by default across a suite of designs often causes QoR to appear to degrade significantly. This apparent degradation happens because the off-chip delays are often not modeled well in the design timing constraints. The off-chip delay must be modeled using a set\_input\_delay or set\_output\_delay timing constraint. If those delays are zero, the improvement in off-chip delay may not be evident, and the increase in on-chip delay may be dominant.

When set\_input\_delay and set\_output\_delay constraints are given at all, this causes the timer to completely ignore timing paths that start or end off-chip. Pushing a flop into a pad with unspecified input/output delay could cause new setup/hold violations to appear that were not previously modeled.

# Working with Virtual I/O

The role of I/O virtualization is to take a design with too many I/O pads (or boundary pins in the case of a Speedcore fabric) and reduce the number of I/O until the design fits in the given fabric. This option is only run in evaluation flow mode.

## Behavior

I/O virtualization is performed automatically as part of the run\_prepare flow step in evaluation flow mode. It is not permitted to export a bitstream for a design with virtualized I/Os. If there are a sufficient number of boundary pin sites to place the design, then the command is a no-op. If the design has more boundary pin instances than available sites, I/O virtualization modifies the netlist by reducing the number of boundary pins until the design fits. When virtualizing I/O, no attempt is made to maintain logical equivalency with the original netlist. Rather, the goal is to

perturb the behavior of the placement and routing tools as little as possible and, therefore, make an evaluation run correspond as closely as possible to a production run of a similar design.

I/O virtualization operates by collapsing multi-bit bused boundary pins as well as single non-bused boundary pins. By default, pins are selected automatically for virtualization, starting with the widest pin bus until enough boundary pin sites are available to fit the remaining number of boundary pin instances. If that number is insufficient, individual non-bused pins are also virtualized. Pin buses and individual pins can also be manually selected for virtualization through top-level port attributes in the RTL or PDC constraints (see **Port Attributes** (page 462), below). Depending on the virtualization mode, some serialization boundary pins may be inserted, so it is possible for the process to fail and leave too many boundary pins in the design.

The pins are collapsed using one of three user-specified styles:

- stubout each IPIN is replaced with a "stub" LUT that drives a constant zero onto the IPIN output net. Similarly, each OPIN is replaced with a "stub" LUT, driven by the OPIN input net, with a floating output pin. These stub LUTs are given must\_keep attributes so that ACE does not optimize them away.
- serialize\_dff bused IPINs are replaced with a single IPIN that drives a scan chain implemented with DFFs. The
  output of each DFF drives the output net from its original corresponding IPIN as well as the next stage in the
  scan chain. Bused OPINs are replaced with a single OPIN that is driven by a scan chain implemented with DFFs.
  The input of each DFF is driven by a 2-input MUX, one input of which is driven by the input net from its original
  corresponding OPIN. The other input of the MUX is driven by the output of the DFF in the previous stage of the
  scan chain. One additional IPIN per port bus is also added which drives the select line of the MUXes.
- **serialize\_lut** this style is the same as the serialize\_dff style, except that the scan chain is implemented with LUTs instead of DFFs.

The stubout style is the simplest and has the greatest rate of pad compression. However, it is the least realistic since there are no connections pulling the stub LUTs toward the edge of the chip. The placer pulls them into the chip core, placing them at the center of gravity of the loads that they drive. The two serialize styles keep one representative boundary pin and are, therefore, more realistic, though of course the strength of the placement forces pulling the scan chain toward to chip edge are significantly reduced. The main reason to use the serialize\_dff style over the serialize\_lut style is that, in the former style, the timer only sees a path that starts or ends at the last stage of the scan chain, while in the former the entire scan chain (possibly hundreds of LUT delays) contributes to the length of the timing path.

For the serialize\_dff style, a clock must be connected to the DFFs that make up the scan chain. By default, that clock is selected automatically to be the clock in the chip core with the largest number of load pins. The clock can be user-specified either through a global implementation option, or on a per-port basis through an attribute on the port. These options are discussed in **Implementation Options** (page 461) and **Port Attributes** (page 462).

# Implementation Options

The behavior of I/O virtualization can be controlled on a global basis by the following implementation options:

- **virtual\_io\_style** controls the style, or method, used to virtualize excess I/O pad or boundary pin buses in the top-level netlist. Legal enumeration values are:
  - stubout (the default)
  - serialize\_dff
  - serialize\_lut

See above for a definition of the behavior of each of these styles.

- virtual\_io\_utilization sets the I/O pad or boundary pin utilization percentage targeted by I/O virtualization.
   Legal values are integers between 0 and 100. An error is returned if the given utilization cannot be met. A target utilization of zero percent requests that all possible port buses and non-bused ports are to be virtualized to achieve the smallest possible number of pins. A target utilization of 100 percent requests that port buses and non-bused ports are to be virtualized until the number of remaining ports fit into the target fabric. This option is mutually exclusive with the virtual\_io\_num\_pads option (both cannot be specified).
- virtual\_io\_num\_pads sets the final number of I/O pad or boundary pin instances targeted by I/O virtualization. Legal values are 0 or larger. A target pad number of zero requests that all possible port buses and non-bused ports are to be virtualized to achieve the smallest possible number of pins. If the specified value is larger than the number of available I/O pad or boundary pin sites in the selected fabric, the number of available I/O pad or boundary pin sites with the virtual\_io\_utilization option (both cannot be specified).
- virtual\_io\_clock\_port specifies the name of the clock, by its top-level port name, to be used by I/O virtualization to clock serialization flops. Only applies for the serialize\_dff virtualization style. This option can also be specified individually for a given port with the RTL or PDC port attribute, ace\_virtualize\_clock\_port, which overrides this option if given. If not specified, the virtualization clock is derived automatically as the core clock net driving the largest number of loads. This option is mutually exclusive with the virtual\_io\_clock\_net option (both cannot be specified).
- virtual\_io\_clock\_net specifies the name of the clock, by its net name, to be used by I/O virtualization to clock serialization flops. Only applies for the serialize\_dff virtualization style. This option can also be specified individually for a given port with the RTL or PDC port attribute, ace\_virtualize\_clock\_net, which overrides this option if given. If not specified, the virtualization clock is derived automatically as the core clock net driving the largest number of loads. This option is mutually exclusive with the virtual\_io\_clock\_port option (both cannot be specified).

# Port Attributes

By default, I/O virtualization selects port buses for virtualization automatically. They are virtualized in order of decreasing size until the netlist meets the given target boundary pin utilization. However, port buses which are virtualized through the use of the RTL port attribute ace\_virtualize can be manually controlled. When the virtualization style is set to serialize\_dff, either a top-level port name or net name to be connected to the clock input of the new serialization flop instances can also be specified. Use the RTL port attribute ace\_virtualize\_clock\_net respectively.

The attribute can be set in the Verilog/VHDL source code, or in the physical design constraints (.pdc) file, as follows. An advantage of setting the property in the .pdc file is that the design does not have to be re-synthesized in order to experiment with different virtualization strategies.

Verilog Example

```
module pds (
    input clk_i,
    (* ace_virtualize="1", ace_virtualize_clock_port="clk_i" *)
    output [63:0] tx_data_o,
    (* ace_virtualize="1", ace_virtualize_clock_net="clk_i_c" *)
    output [ 7:0] tx_ifg_delay_o
endmodule
```

#### VHDL Example

If the target boundary pin utilization is not met after all user-specified ports are virtualized, additional ports are selected automatically until the target boundary pin utilization is met.

#### Physical Design Constraints (.pdc) File

```
set_property ace_virtualize "1" [find -ports {sample_src\[*\]}]
set_property ace_virtualize_clock_port "clk" [find -ports {sample_src\[*\]}]
```

# **Runtime Messages**

Below are the output messages from I/O virtualization using the example above with user-specified port buses and the serialize\_dff virtualization style.

#### **Runtime Messages**

```
INFO: Virtualize IO: Serializing user-specified 512-bit output PortBus tx_data_o using
clock clk_i_c
INFO: Virtualize IO: Serializing user-specified 64-bit output PortBus tx_data_valid_o
using clock clk_i_c
INFO: Virtualize IO: Serializing user-specified 64-bit output PortBus tx_ifg_delay_o
using clock clk_i_c
INFO: Virtualize IO: Serializing user-specified 512-bit input PortBus rx_data_i using
clock clk_i_c
```

463

INF0: Virtualize IO: Serializing user-specified 128-bit output PortBus pause\_val\_o using clock clk\_i\_c INF0: Virtualize IO: Serializing remaining 6 auto-selected input ports using clock clk\_c INF0: Virtualize IO: Serializing remaining 13 auto-selected output ports using clock clk\_c WARNING: Virtualize IO: Netlist pds had too many IOs to fit in the selected device.

Merged and deleted 1280 of 1498 IO ports. Final number of ports is 227. This is for

evaluation purposes only and will cause simulation mismatches.

Schematic View

The following images illustrate each of the available virtualization styles with schematic diagrams showing 4-bit busses of input pads and output pads. First shown is the input netlist before pad virtualization, followed by the output netlist for the stubout, serialize\_dff, and serialize\_lut styles.

## **Input Netlist**

The following figure illustrates the input netlist for a 4-bit bus of input pads, and a 4-bit bus of output pads. The output pads have an output-enable driver.



Figure 225 • Input and Output Pads

# **Output Netlist Styles**

### stubout

The following two schematics illustrate the output of I/O virtualization when using the stubout style. Notice that none of the IPIN or OPIN instances remain. The new LUTs replacing the IPIN instances are all driven by constant zeros, and the new LUTs replacing the OPIN instances have unconnected outputs.



Figure 226 • Stubout Style Input Pad



Figure 227 • Stubout Style Output Pad

## serialize\_dff

The following two schematics illustrate the output of I/O virtualization using the serialize\_dff style. Notice that the 4-bit IPIN and OPIN buses have been replaced by a single IPIN or OPIN instance. On the input side, the input pads were previously driving a bus of four DFFs. Those DFFs are now driven by the intermediate outputs of a 4-bit shift chain built from DFFs. On the output side, observe that the 4-bit output DFF shift chain is driven by four 2-to-1 MUXes. One input of the MUX comes from the flops originally driving the outputs, while the other input of each MUX is driven by the output of the previous stage of the shift chain. A new IPIN instance has been created to drive the select pin if these MUXes.



Figure 228 • serialize\_dff Style Input Pad





### serialize\_lut

The following two schematics illustrate the output of I/O virtualization using the serialize\_lut style. Notice that the 4-bit IPIN and OPIN buses have been replaced by a single IPIN or OPIN instance. On the input side, the input pads were previously driving a bus of four DFFs. Those DFFs are now driven by the intermediate outputs of a 4-bit shift chain built from LUTs. On the output side, observe that the 4-bit output LUT shift chain is driven by four 2-to-1 MUXes. One input of the MUX comes from the flops originally driving the outputs, while the other input of each MUX is driven by the output of the previous stage of the shift chain. A new IPIN instance has been created to drive the select pin if these MUXes.



Figure 230 • serialize\_lut Style Input Pad



Figure 231 • serialize\_lut Style Output Pad

# Accessing Help

ACE provides a number of ways to access help information, including context-sensitive help and a built-in copy of this user guide document.

# Accessing Context-Sensitive Help

ACE provides brief context-sensitive help for most parts of the application. This contextual help typically contains a brief description of the view, dialog, etc., followed by a list of hyperlinks to relevant sections within the ACE User Guide.

To cause the context-sensitive help to be shown, simply press the **F1** key in Windows, or **Shift+F1** in Linux, and the contextual help appears in a view on the right.

The following is an example of what appears when contextual help is opened while the **Projects view** (page 120) has focus:

|               | - C - X-                                         |
|---------------|--------------------------------------------------|
|               |                                                  |
|               | Quick Access                                     |
| 😰 Help 🛛      |                                                  |
| Contents      | 察 Search                                         |
| Related       | Topics                                           |
| 💷 Bookmark    | rs 🛗 Index                                       |
|               | r<br>ws you to browse and<br>ect configurations. |
| See also:     |                                                  |
| 🗎 Projects V  | iew                                              |
| Projects      |                                                  |
| Working v     | vith Projects                                    |
| More results: |                                                  |
| 💖 Search for  | Projects View                                    |

Figure 232 · Context-Sensitive Help Example

# Navigating Help Topics

Help topics (corresponding to sections within the ACE User Guide) can be browsed using the Help window or Help view. Choosing which to use is a matter of preference; the Help view is displayed within the workbench like any other view, and is good for quick help lookups. The Help window is (as the name implies) a separate window from the rest of ACE and can be individually maximized, thus allowing easier reading of larger quantities of content.

# Using the Help Window

The Help window is separate from the workbench, used exclusively for browsing and searching help content. To open the window, select **Help**  $\rightarrow$  **Help Contents** from the main menu. This action opens the help window with the (

🕘 ) **Contents** tab visible in the left frame, which shows the table of contents.

#### Caution!

There is a known bug on the Linux platform in the application frameworks underlying ACE that might cause view/editor tab movements to detach instead of docking when the Help window is open. See the **Troubleshooting** (page 762) section for more details, including several workarounds.

## Navigating the Help Window

## **Table of Contents**

- 1. In the left frame, select the ( 🗐 ) Contents tab.
- 2. To find the topic to be read in the table of contents:
  - a. Click to expand the subtopics.
  - b. Click in the desired topic to have it displayed in the frame on the right.
- 3. Some topics provide links to additional related topics within (of after) their content. Click these links to learn more.
- 4. Use the ( ) **Back** and ( ) **Forward** buttons (above the right frame) to navigate back and forth among the recently viewed topics. These buttons behave the same way as in Web browsers.
- 5. Use the ( 🏠 ) Home button (above the right frame) to return to the help home page in the ( 🗐 ) Contents.

## Searching

To quickly locate topics on a particular subject in the documentation, enter a query in the **Search** field at the top of the window. Search results are displayed in the left frame on the (**Search Results** tab. For more details, see **Searching Help** (page 470).

## Synchronizing

Clicking the (<sup>1</sup>/<sub>1</sub>) **Show in Table of Contents** button above the right frame selects that topic for that page in the **Contents** tree in the left frame (useful when navigating search results when the tree may be out of sync). The (<sup>1</sup>/<sub>2</sub>) **Link with Contents** button above the left frame in the **Contents** tab keeps the navigation tree synchronized to the current topic shown in the right frame.

## **Maximizing and Restoring Help Frames**

The two main frames of the Help window can each be maximized to take up the entire window. To maximize a frame, click the ( <sup>□</sup> ) **Maximize** button in the frame toolbar, or double-click any blank part of the toolbar for that frame. To return the frame to its original size, click the ( <sup>□</sup> ) **Restore** button or double-click the toolbar again.

# Using the Help View

The Help view provides the same features as the Help window, but does it in a single view panel within the **Workbench** (page 6) instead of in a separate window.

# Searching Help

The help system includes a search engine that can run simple or complex queries on the documentation to help locate the desired information. To search help:

- 1. From the main menu, select Help  $\rightarrow$  Search.
- 2. Type the word or phrase for the search subject.
- 3. Click GO or press Enter. The list of results are displayed below in the left frame (within the Search Results tab).
- 4. Click the topic in the list of results to view the content.

Alternately, searches can be initiated within the Help window using the **Search** field at the top left of the window.

# **Refining the Search Results**

## Reducing the Scope of the Search

Sites licensed for both Speedcore and Speedster devices can narrow the **Scope** of a search by restricting the scope to only the preferred user guide(s).

### Changing the Appearance of the Search Results

Two buttons on the search results toolbar can be used to change the way results are displayed:

- The ( = ) **Show result categories** button, when clicked, causes the results to be grouped by book (this action only has a noticeable effect at sites licensed for both Speedcore and Speedster devices, i.e., when both ACE User Guides are available).
- The ( 🗏 ) Show result descriptions button, when clicked, causes a brief description of each result to be shown.

# **Highlighting Search Terms**

By default, when a search result is selected, the search terms used to find the document are highlighted in the

document content. Clicking the ( *A*) **Highlight Search Terms** toolbar button toggles this feature on and off. This button is available in both the help window and the help view. The state of this button is remembered in both views when displaying subsequent search results.

# Search Query Syntax

Follow these expression rules for searching local help content:

- The following stop words are common English words which are ignored (not searched for) if they appear in the search expression:
  - a, and, are, as, at, be, but, by, in, into, is, it, no, not, of, on, or, s, such, t, that,

UG070

the, their, then, there, these, they, to, was, will, with

- The search engine ignores character case (i.e., "Workbench" returns topics that contain "workbench", "Workbench", "Workbench", and "WORKBENCH")
- Unless otherwise stated, there is an implied AND between all search terms so that topics that contain all the search terms are returned (e.g., "verilog module" returns topics that contain the word "verilog" and the word "module" but does not return topics that contain only one of these words)
- Use "OR" before optional terms (e.g., "project OR implementation" returns topics that contain the word "project", or the word "implementation", or both)
- Use "NOT" before terms to exclude from search results (e.g., "verilog NOT module" returns topics that contain the word "verilog" and do not contain the word "module")

#### (i) Note

The word "NOT" only works as a binary operator (e.g., "NOT module" is an illegal search query by itself).

 Use "?" for a single-character wildcard and "\*" for a multi-character wildcard (e.g., "par?" returns topics that contain "part" or "park", but not "participate", while "par\*" returns topics that contain "part", "park", "participate", "pardon", etc.)

#### (i) Note

The search engine does not accept terms with a wild card at first character position.

- Use double quotation marks around terms which should be treated as a phrase (e.g., "creating projects" returns topics that contain the entire phrase "creating projects" while topics where the words "creating" and "projects" are not consecutive are not returned)
- Punctuation acts as term delimiters (e.g., "plugin.xml" returns hits on topics that contain "plugin" and "xml", so to limit the search to the item, include the double quotes as shown)

#### (i) Note

The search engine automatically performs "fuzzy" searches and word stemming. Entering "create" returns results including hits on topics that contain "creates", "creating", "creator", etc. To prevent the search engine from stemming a term, enclose the term in double quotes as shown.

# Using the ACE SecureShare Tool to Create a Support Zip File

When encountering some problems, the **Troubleshooting** (page 762) chapter and/or opening a case with Achronix Technical Support (at support.achronix.com/hc/en-us) might not be enough to find a solution. For these instances, ACE includes the SecureShare tool.

The **Create a SecureShare Zip File dialog** (page 164) gathers all the important information from a user design and collects it into a single ZIP file. Sensitive files may be optionally excluded, or additional files included, before the ZIP file is created by the SecureShare tool. Optionally, the SecureShare tool can even encrypt the information in the ZIP file. Achronix technical support engineers can decrypt any files encrypted by the tool as they help track down and solve the problem.

To use the SecureShare tool:

 Load (and activate) the project (page 224) and implementation (page 231) for which help is desired. (See also Active Project and Implementation (page 231).) The SecureShare tool gathers the relevant files for whichever project and implementation are active when the tool is started.

### (i) Note

If help is needed for multiple projects or implementations, each need to be handled using separate SecureShare ZIP files.

- Open the Create a SecureShare Zip File dialog (page 164) by selecting Help → Start SecureShare, or by using the keyboard shortcut Ctrl+Alt+Shift+S.
- 3. Examine each file category and **Remove** any files containing sensitive information which should not be transmitted to Achronix.
- 4. **Add** any additional files which might help Achronix track down the problem. Ideally, add the files to the appropriate categories. If no appropriate category exists, add the files to the "Other" category.
- 5. Make sure the ZIP file (under the **Configure SecureShare** heading at the top) is pointing to an appropriate directory/filename.
- 6. Select the Encrypt included files checkbox if desired.
- 7. Click the Finish button at the bottom of the dialog.

ACE then creates a ZIP file with the chosen name in the chosen directory. If the Encrypt option was chosen, an additional file with the .zip.encrypted file extension is created alongside the (not-encrypted) ZIP file. The resulting .zip or .zip.encrypted file can be attached to the support request ticket.

# Importing and Exporting Preferences

Preference files can be both imported to and exported from ACE, allowing individual or group preferences to be shared or migrated from an existing version of ACE to a newer version when upgrading.

# **Import Preferences**

The Import wizard can be used to import preferences from the file system into ACE. To import a preference file:

- 1. Select File  $\rightarrow$  Import...
- 2. In the Import wizard, select Preferences and click Next.

| O Import                                              |   |     | ×   |
|-------------------------------------------------------|---|-----|-----|
| Select Import preferences from the local file system. |   | Ľ   | 1   |
| Select an import wizard:                              |   |     |     |
| type filter text                                      |   |     |     |
| Preferences                                           |   |     |     |
| < <u>B</u> ack <u>N</u> ext > <u>F</u> inish          | I | Can | cel |

# Figure 233 • Import Wizard Select Preferences Example

- 3. Click **Browse...** and locate the Preferences file on the file system.
- 4. Select **Import all** to accept all of the preferences defined in the file.
- 5. Click Finish.

| O Import Preferences                                                                        | —              | □ ×             |
|---------------------------------------------------------------------------------------------|----------------|-----------------|
| Import Preferences<br>Import preferences from the local file system.                        |                |                 |
| From preference file: C:\code\misc\prefs\my_ace_pref                                        | s.epf ~        | B <u>r</u> owse |
| ☑ Import <u>a</u> ll                                                                        |                |                 |
| type filter text                                                                            |                |                 |
| Descrip <u>t</u> ion:<br>Empty list.<br>Note: Not all preferences support individual import |                | <u>`</u>        |
| Select All Deselect All                                                                     |                |                 |
|                                                                                             |                |                 |
| < <u>B</u> ack <u>N</u> ext >                                                               | <u>F</u> inish | Cancel          |

Figure 234 • Import Wizard Locate File Example

# **Export Preferences**

The Export wizard can be used to export preferences from ACE to the file system. To export a preference file:

- 1. Select File  $\rightarrow$  Export...
- 2. In the Export wizard select **Preferences** and click **Next**.

| C Export                                               | – 🗆 X       |
|--------------------------------------------------------|-------------|
| Select<br>Export preferences to the local file system. | 2           |
| Select an export wizard:                               |             |
| type filter text                                       |             |
| ↓ Preferences                                          |             |
| < <u>B</u> ack <u>N</u> ext > <u>F</u> ir              | nish Cancel |

# Figure 235 • Export Wizard Select Preferences Example

- 3. Select **Export all** to add all of the preferences to the file.
- 4. Click **Browse...** and locate the preferences file on the file system.
- 5. Click Finish.

| C Export Preferences                                    | – <b>D</b> X      |
|---------------------------------------------------------|-------------------|
| Export Preferences                                      |                   |
| Export preferences to the local file system.            |                   |
| ⊡ Export <u>a</u> ll<br>↑                               |                   |
| type filter text                                        |                   |
|                                                         |                   |
|                                                         |                   |
| Descrip <u>t</u> ion:                                   |                   |
|                                                         | ^                 |
|                                                         | ~                 |
| Select All Deselect All                                 |                   |
| To greference file: C:\code\misc\prefs\my_ace_prefs.epf | ∽ B <u>r</u> owse |
|                                                         | <b>†</b>          |
| Overwrite existing files without warning                |                   |
|                                                         |                   |
| < Back Next > Finish                                    | Cancel            |
| <u>Dack</u> <u>H</u> ext > <u>Finish</u>                | Cancel            |

Figure 236 • Export Wizard Locate File Example

# Plotting SerDes Receiver Diagrams Using JTAG

Using an open JTAG connection to the SerDes hardware, it is possible to capture Rx diagnostic data and plot Eye diagrams, Histograms, and Bathtub plots.



Figure 237 • SerDes Rx Eye Diagram Plot Example

# Plotting a SerDes Diagram for a SerDes Lane

Diagrams can be plotted using the following simple steps. For advanced users, the jtag::capture\_serdes\_diagram\_data and jtag::plot\_serdes\_diagram\_data\_matlab Tcl commands may be used directly.

- 1. Open an ACE project containing the I/O Ring design configuration, and switch to the IP Configuration perspective.
- 2. Open a valid JTAG connection to the FPGA using the JTAG Tcl commands in the Tcl Console view (page 146):

```
set jtag_id "AC12345"
jtag::open $jtag_id
jtag::ac7t1500_initialize_fcu $jtag_id
```

3. With an open JTAG connection, right-click any configured (green) SerDes Lane in the I/O Layout Diagram view (page 68):

|                                                                                                                             |                     | A         | C7t1500ES0-F53                                                                                                                                    |         |                                                                                  |
|-----------------------------------------------------------------------------------------------------------------------------|---------------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------|---------|----------------------------------------------------------------------------------|
| CULNW<br>CULNW<br>CULNW<br>CULNW<br>CULNW<br>CULNW<br>CULNW<br>CULN<br>CULN<br>CULN<br>CULN<br>CULN<br>CULN<br>CULN<br>CULN | SerDes 0-7<br>ETH_0 | SerDes 8- | 15 SerDes 16-31 Open IP Plot Serdes Diagram Rename IP Add IP to another project. Add copies of IP to another project. Remove IP from project CORE | GPIO. N | CLK_NE PLL<br>D<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C |
| GDDR6_0                                                                                                                     |                     |           |                                                                                                                                                   |         | GDDR                                                                             |

## Figure 238 • Plot SerDes Diagram Lane Selection Example

4. Configure the diagram plotting options in the Plot Serdes Diagram dialog (page 181):

| 🧿 Plot a Serdes Rx [  | Diagram using JTAG                                                                    |   | ×      |
|-----------------------|---------------------------------------------------------------------------------------|---|--------|
| Serdes Diagram Plo    | t Configuration                                                                       |   |        |
| Using an existing ope | en JTAG connection, capture and plot internal Rx diagrams from the chosen SerDes lane |   |        |
| IP Block Name:        | SERDES_LN_11                                                                          |   |        |
| JTAG Device ID:       | \$jtag_id                                                                             |   |        |
| Number of Samples:    | 500                                                                                   |   |        |
| Capture Point:        | FFE                                                                                   | ~ |        |
| Diagram Type:         | Eye Plot                                                                              | ~ |        |
| Figure Name:          | SERDES_LN_11 Rx Plot                                                                  |   |        |
| Figure Number:        | 1                                                                                     |   |        |
| Capture Data File:    | D:/proj_7/impl_1/output/SERDES_LN_11_diagram.txt                                      |   | Browse |
|                       |                                                                                       |   |        |
|                       |                                                                                       |   |        |
| 0                     | Finish                                                                                | G | ancel  |

Figure 239 • Plot SerDes Diagram Dialog Configuration Example

### 5. Click Finish.

### (i) Note

Multiple diagrams can be plotted from the same capture data file using the jtag::plot\_serdes\_diagram\_data\_matlab Tcl command after completing these steps. The diagram plotting capture over JTAG takes a long time. For 500 samples, it typically takes upwards of 10 minutes to run.

# Using Partial Reconfiguration

This section begins with a high-level overview, and then continues with detailed tutorials.

# Partial Reconfiguration Tutorial

Partial Reconfiguration tutorial examples are provided for two different flows. ACE currently supports Partial Reconfiguration for the Speedster7t AC7t1500ES0 FPGA only.

# **Partial Reconfiguration Flows**

- PR Flow 1: Multi-Project PR Flow Using Partition Export/Import (page 489)
- PR Flow 2: Multi-Project PR Flow Using Keep Out Regions (page 515)

ACE currently supports 2 different partial reconfiguration flows. PR flow 1 is the recommended flow.

## **Overview of PR Flow 1**

PR Flow 1 uses the ACE partitions feature. Familiarity with the ACE partition flow is recommended before proceeding with PR flow 1.

The partition import/export flow requires separate projects for the top-level design as well as each PR Core. The partition export flow must first be run in its own Synplify and ACE project for the PR core to be exported as a partition. After the partition export flow is run, ACE generates a placed and routed partition for the PR core. The partition import flow is next run in a separate Synplify and ACE project. In the partition import flow, the top-level design instantiates the previously exported PR core blackbox module and ACE imports the placed and routed data for the PR core into the top-level design.

#### (i) Note

In the partition import flow, ACE only places and routes the top-level design and not the imported PR cores.

The base bitstream is created in the first partition import run where the previously exported PR cores are imported into the top-level design. On Silicon, the base bitstream is programmed onto the device first. The partial bitstream for the second set of PR Cores is subsequently programmed onto the device. The base bitstream includes the top-level logic as well as the PR Core logic. The partial bitstream is generated in the second partition import run where a different set of exported PR Cores are imported in the same top-level design.

## **Overview of PR Flow 2**

The Multi-Project PR flow using keepout regions is another method to create designs that can be partially reconfigured. This flow involves using separate ACE projects to generate separate base and partial bitstreams for the top-level design and each PR core. On silicon, the base bitstream consisting of only the top-level logic is programmed first. The partial bitstreams for the other PR core can be programmed subsequently. Using this flow, the user design is stitched together at the bitstream level. There is no integration in ACE between the the top-level design and each PR core since the designs are stitched at the bitstream level. As such, this flow comes with a few pitfalls so that only high-level users are recommended to use this flow. PR flow 1 is therefore considered an improvement to PR flow 2.

## Flow Comparisons

| ltem                                    | PR Flow 1                                                                                                                                                                                                                                                                                                                                                         | PR Flow 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Turn-around Time                        | <b>Con:</b><br>PR flow 1 has a slower turn-around time. The base<br>bitstream consists of the top-level design as well as<br>the PR cores. PR Cores must be exported in separate<br>ACE sessions before being imported into the top-level<br>design.                                                                                                              | <b>Pro:</b><br>PR Flow 2 has a faster turn-around time. The base<br>bitstream consists only of the top-level design. PR<br>cores place-and-route can be bypassed. Only a keep-<br>out region is needed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Integrating Third-Party<br>Accelerators | <b>Pro:</b><br>PR flow 1, allows integrating third party accelerator cores at a bitstream level and also within ACE. The partition binary file for third-party accelerators can be integrated in an ACE project which allows running checks and timing analysis for the integrated design to ensure that the accelerator is compatible with the top-level design. | <b>Con:</b><br>PR flow 2 enables integrating third party accelerator cores only at the bitstream level. Third party accelerators cannot be tested until programmed at the bitstream level.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bitstream Stitching                     | <b>Pro:</b><br>In PR flow 1, ACE integrates the PR core project<br>together with the top-level project using the partitions<br>feature. A series of checks are performed to ensure<br>that the base and partial bitstreams can be stitched<br>together without issue.                                                                                             | <ul> <li>Con:</li> <li>In PR Flow 2, bitstreams might not be stitched together correctly if any of the ACE projects are configured incorrectly. The base bitstream and partial bitstreams are created in separate independent ACE projects so if all user projects are not set up correctly, ACE cannot catch the errors.</li> <li>Scenario 1 – if clock nets used in the partial bitstream are not pre-routed in the base bitstream, the clock signal cannot be correctly connected to the PR cores after partial reconfiguration.</li> <li>Scenario 2 – if clock nets on different clock tracks are pre-routed in the partial and base bitstream, the clock signals cannot be correctly connected to the PR Cores after partial reconfiguration.</li> <li>Scenario 3 – if keep-out regions are not set on clusters in the base bitstream that are used by PR cores, the top-level logic might be lost after partial reconfiguration.</li> </ul> |

### Table 149 • Pros and Cons For Each PR Flow

| ltem           | PR Flow 1                                                                                                                                                                                                 | PR Flow 2                                                                                                                                                                                                                                                                                                                                                            |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Closing Timing | <b>Pro:</b><br>In PR flow 1, ACE integrates the PR core project<br>together with the top-level project during the partition<br>import run and also performs timing analysis for the<br>integrated design. | <b>Con:</b><br>In PR Flow 2, the design might not meet timing on<br>paths between the top-level and PR core after the<br>partial bitstream is programmed because timing<br>analysis is performed separately in projects for the<br>top-level design and PR cores (timing delays are<br>different on the east and west sides of the<br>Speedster7t AC7t1500ES0 FPGA.) |
| Simulation     | <b>Pro:</b><br>Simulating the entire design is possible in the partition import run.                                                                                                                      | <b>Con:</b><br>Simulating the entire design within an ACE project is difficult because there is no integration between separate ACE projects. Though not impossible, a lot of manual work is required.                                                                                                                                                               |

# **Flow Diagrams**

The following sequence outlines the high-level steps needed to partially reconfigure PR core A as PR core B.

## PR Flow 1: Multi-project PR Flow Using Partition Export/Import

In the operating procedure for this example, the base bitstream in step 3 is programmed onto silicon first. This base bitstream includes the top-level logic and the PR Core A logic. To partially reconfigure PR Core A with PR Core B, the partial bitstream created in step 6 is programmed subsequently.

1. Export PR core A as a partition using ACE.



Figure 240 • Export PR Core as a Partition Example

2. Import PR core A partition into top-level design.

3. Generate a base bitstream for the entire device.



Figure 241 • Import PR Core to Top Level Example

4. Export PR core B as a partition using ACE.



Figure 242 • Export PR Core as a Partition Example

- 5. Import the PR core B partition into the same top-level design.
- 6. Generate a partial bitstream only for PR core B.



Figure 243 • Generate Partial Bitstream Example

## PR Flow 2: Multi-project PR Flow Using Keep Out Regions

In the operating procedure for this example, the base bitstream created in step 3 is programmed onto silicon first. Unlike PR Flow 1, the base bitstream only contains the top-level logic (not the PR Core A logic). The partial bitstream for PR Core A (created in step 1) is programmed next. To partially reconfigure PR Core A with PR Core B, the partial bitstream for PR Core B (created in step 2) is programmed subsequently.

1. Generate a partial bitstream for PR core A using ACE.



Figure 244 · Generate Partial Bitstream Example

2. Generate a partial bitstream for PR core B using ACE.



## Figure 245 • Generate Partial Bitstream Example

- SerDes (1-112 Gbps) 400 Gbps Ethernet PCIe Gen5 GDDR6 GDDR6 2D N Top-Level Design **GDDR6 GDDR6** 2D Network-on-Chip Chi. GDDR6 D No. **GDDR6** GDDR6 **GDDR6** 2D Network-on-Chi Secure Configuration DDR4 **GPIO** 120569590-01.2023.01.27
- 3. Generate a base bitstream for the top-level design using ACE with keep out regions for the PR cores.

Figure 246 • Generate Bitstream Example

# **Design Details**

This tutorial uses a simple example design to illustrate running a design through PR Flow 1. In this tutorial, three separate bitstreams are created:

- 1. Base Bitstream (Top-level design)
- 2. Partial Bitstream 1 (PR Core 1)
- 3. Partial Bitstream 2 (PR Core 2)

# Base Bitstream (Top-level design)

RTL files:

- PR flow 1- <ACE\_INSTALL\_DIR>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_1/pr\_top\_a/src/rtl/...
- 2. PR flow 2 <ACE\_INSTALL\_DIR>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_2/pr\_top/src/rtl/...

### Constraint files:

- PR flow 1 <ACE\_INSTALL\_DIR>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_1/pr\_top\_a/src/constraints/...
- 2. PR flow 2 <ACE\_INSTALL\_DIR>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_2/pr\_top/src/constraints/...

The top-level design instantiates the user static logic. Static Logic refers to any user design logic which is not intended to be reconfigured in the PR flow. The base bitstream is generated using the top-level design. The top-level design in this tutorial demonstrates a 2-bit binary up-counting LED display to indicate that the board and FPGA are operating properly upon powerup. The RTL along with the device-specific netlists and constraints are available under the <ACE\_install\_dir>/Achronix/examples/partial\_reconfiguration directory.

Other than just instantiating the user static logic, the top-level design also must instantiate any shared system controller logic, I/O Ring, and I/O interfaces used in the other PR cores. Clock nets used in each PR core to be partially reconfigured must also be carefully pre-routed since clock nets are also routed on the core fabric HW clock network, which is not reconfigurable. Also, a keep-out region for each PR Core must be created to prevent any logic and routing from the top-level design from entering the cluster(s) used by the PR Cores in the partial bitstreams.

# Partial Bitstream 1 (PR Core 1A)

RTL files:

- 1. PR flow 1 <ACE\_INSTALL\_DIR>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_1/pr\_core\_1a/src/rtl/...
- 2. PR flow 2 <ACE\_INSTALL\_DIR>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_2/pr\_core\_1a/src/rtl/...

Constraint files:

- 1. PR flow 1 <ACE\_INSTALL\_DIR>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_1/pr\_core\_1a/src/constraints/...
- 2. PR flow 2 <ACE\_INSTALL\_DIR>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_2/pr\_core\_1a/src/constraints/..

PR core 1 consists of a 32-bit adder with outputs connected to a 32-bit register. This 32-bit register is connected to the NAP initiator in the cluster. The NAP Initiator can be used to read the 32-bit adder output register via the 2D NoC with the JTAG interface or with PCIe. In this tutorial, the JTAG interface is used to read the user registers. There is also a reset register that can be written to in this design. The reset register drives all resets in PR core 1.

Partial bitstreams must not contain any I/O ring programming. Clock nets also must be pre-routed on the clock network on a specified track number. The top-level design must also pre-route the same clock net on the same track number to the same cluster where PR core 1 is placed. A cluster map also must be set to identify which core fabric cluster(s) are to be re-programmed. The following sections in this tutorial cover this in more detail.

## Partial Bitstream 1 (PR Core 1B)

RTL files:

- 1. PR flow 1 <ACE\_INSTALL\_DIR>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_1/pr\_core\_1b/src/rtl/...
- 2. PR flow 2 <ACE\_INSTALL\_DIR>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_2/pr\_core\_1b/src/rtl/...

#### Constraint files:

- PR flow 1 <ACE\_INSTALL\_DIR>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_1/pr\_core\_1a/src/constraints/...
- 2. PR flow 2 <ACE\_INSTALL\_DIR>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_2/pr\_core\_1a/src/constraints/..

PR core 1B is identical to PR core 1A except that the 32-bit adder increments by 2 instead of 1 during each read.

## Partial Bitstream 2 (PR Core 2A)

RTL files:

- PR flow 1 <ACE\_INSTALL\_DIR>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_1/pr\_core\_2a/src/rtl/...
- 2. PR flow 2 <ACE\_INSTALL\_DIR>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_2/pr\_core\_2a/src/rtl/...

#### Constraint files:

- PR flow 1 <ACE\_INSTALL\_DIR>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_1/pr\_core\_2a/src/constraints/...
- 2. PRfFlow 2 <ACE\_INSTALL\_DIR>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_2/pr\_core\_2a/src/constraints/...

PR core 2A is identical to PR core 1A except that the 32-bit adder instead is implemented as a 32-bit subtractor. The 32-bit subtractor decrements by 1 at each NAP read.

## Partial Bitstream 2 (PR Core 2B)

RTL files:

 PR flow 1 - <ACE\_INSTALL\_DIR>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_1/pr\_core\_2b/src/rtl/... 2. PR flow 2 - <ACE\_INSTALL\_DIR>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_2/pr\_core\_2b/src/rtl/...

Constraint files:

- PR flow 1- <ACE\_INSTALL\_DIR>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_1/pr\_core\_2b/src/constraints/...
- 2. PR flow 2 <ACE\_INSTALL\_DIR>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_2/pr\_core\_2b/src/constraints/...

PR core 2B is identical to PR core 2A except that the 32-bit subtractor now decrements by 2 instead of 1 at each NAP read.

## **Reset Configuration Options**

This tutorial uses option 1, below, but there are several ways resets for a partial reconfiguration design can be configured. The different methods are listed below, ordered by recommendation (1 being the most and 4 being the least recommended method).

1. Use a NAP to control reset via the 2D NoC. This can be performed using host software (e.g.,

jtag::nap\_axi\_write or PCle), or top-level control logic.

This reset scheme is utilized by the demo in this tutorial. All nets driven by reset are self contained within the PR zone.

- 2. Use a DFF chain to de-assert reset when the cluster enters user mode.
  - Use init values on DFFs to toggle the reset when a cluster enters user mode.
  - This is an example showing how to instantiate a DFF chain for an active-low reset design:

```
wire rst_wire_1;
wire rst_wire_2;
wire i_rst;
// First DFF in chain
(* must_keep=1 *) ACX_DFF #(
    .init
            (1'b1)
) reset_dff_1 (
             (rst_wire_1),
    .q
    .d
             (),
    .ck
             (i_clk)
);
// Second DFF in chain
(* must_keep=1 *) ACX_DFF #(
    .init
           (1'b0)
) reset_dff_2 (
             (rst_wire_2),
    ٠q
    .d
             (rst_wire_1),
    .ck
             (i_clk)
);
```

```
// Third DFF in chain (q-pin drives the PR Core reset)
(* must_keep=1 *) ACX_DFF #(
    .init (1'b0)
) reset_dff_3 (
    .q (i_rst),
    .d (rst_wire_2),
    .ck (i_clk)
);
```

- In this example, reset\_dff\_3 drives the reset with 1'b0 for 2 clock cycles before being de-asserted to 1'b1.
- The disadvantage of this reset scheme is that the resets cannot be toggled by the user.
- 3. Use top-level CLK I/O pads to drive the reset to the global clock trunk using clock-preroute constraints.
  - Pre-route the reset net on a specified track on the global clock trunk.
  - PDC constraints:

```
#Create a clock IPIN for your reset and place it on a clock IPIN tile
create_boundary_pins {p:i_reset_n} {i_reset_n_ipin} -clock
set_placement -fixed -batch {p:i_reset_n} {d:i_user_06_00_trunk_00[16]}
#Pre-route the reset net on clock track 1 to the PR Zone defined for your PR
Core.
#add_clock_preroute "i_reset_n_ipin_net" 1 -placement_regions "PR_ZONE_2_7"
```

- Disadvantage: The reset net is routed over the clock network so there is one less clock track available.
- 4. Use top-level Data I/O pads to drive the reset and use the data2clk path to route the reset to the global clock trunk using clock-preroute constraints.
  - Pre-route the reset net on a specified track on the global clock trunk.
  - PDC constraints

```
#Create a data IPIN for your reset and place it on a data IPIN tile
create_boundary_pins {p:i_reset_n} {i_reset_n_ipin}
set_placement -fixed -batch {p:i_reset_n} {d:i_user_11_09_lut_13[15]}
#Pre-route the reset net on clock track 1 to the PR Zone defined for your PR
Core.
#add_clock_preroute "i_reset_n_ipin_net" 1 -placement_regions "PR_ZONE_2_7"
```

• Disadvantages: There must be a path available from the data IPIN to the central clock trunk. If there are no paths available because all clusters are blocked off and in use, the router cannot pre-route this reset net.

# PR Flow 1: Multi-Project PR Flow Using Partition Export/Import

## Introduction

The Multi-Project flow with partition export/import is the recommended flow for partial reconfiguration.

The partition import/export flow requires separate projects for the top-level design as well as for each PR core. The partition export flow must first be run in its own Synplify and ACE project in order for a PR core to be exported as a partition. After the partition export flow is run, ACE generates a placed-and-routed partition for the PR core. The partition import flow is next run in a separate Synplify and ACE project in which the top-level design instantiates the PR core blackbox module that was previously exported. ACE imports the placed-and-routed data for the PR core into the top-level design.

### (i) Note

In the partition import flow, ACE does not place-and-route the imported PR cores, only the top-level design.

## **Moving Partitions**

Partitions are also very useful for replicating and moving logic. Each PR core can be placed-and-routed, and the timing-closed, once in one location of the fabric, and then stamped down multiple times and relocated throughout the fabric. This is accomplished by instantiating multiple copies of the exported PR core partition in the top-level design. ACE then imports the timing-closed PR core partition database. Initially, each instance of the PR core is placed on top of each other but ACE has a special feature which allows partitions to be moved/re-mapped to other locations in the fabric. This is made possible using relative placement and routing to map to the repetitive cluster-based architecture of the fabric.

## High-Level Design Flow

The bottom-up flow must be used for PR flow 1. This involves exporting a partition for each of the PR cores and importing them into the top-level design. The base bitstream can be generated for the top-level design to contain each of the PR cores. Subsequent partial bitstreams can be generated from the top-level design project or from each PR core project.

Please follow this high-level design flow carefully:

- 1. Export Partition for PR Core 1A (page 490)
  - a. Synthesize PR Core 1A Using Synplify (page 490)
  - b. Run PR Core 1A Through Run Prepare in ACE (page 492)
  - c. Set Up Region Constraints for PR Core 1A (page 493)
  - d. Set Up Clock Pre-Routing Constraints for PR Core 1A (page 494)
  - e. Run PR Core 1A Through Place-and-Route in ACE (page 496)
  - f. Run Final Sign-Off Timing Analysis for PR Core 1A (page 496)
  - g. Save Region/Clock Pre-Routing Constraints Back to PDC File (page 497)
  - h. Ensure ACE Generated Blackbox File and Exported Partition for PR Core 1A (page 498)
- 2. Export Partition for PR Core 2A (page 498)
  - a. Repeat Procedure for PR Core 2A (page 498)
- 3. Importing PR Core 1A and 2A Partitions and Generating Base Bitstream for Top-Level Design (page 499)

- a. Create I/O Ring Configuration for Target Board (page 499)
- b. Synthesize Top-Level Design Using Synplify (page 503)
- c. Run Top-Level Design Through Run Prepare in ACE (page 504)
- d. Set Up Clock Pre-Routing Constraints (page 505)
- e. Set Up Region Constraints (Optional) (page 506)
- f. Run Top-Level Design Through Place-and-Route in ACE (page 508)
- g. Run Final Sign-Off Timing Analysis in ACE (page 509)
- h. Generate Base Bitstream for Top-level Design (page 510)
- i. Save Region/Clock Pre-Routing and Partition Placement Constraints Back to PDC File (page 510)
- 4. Generate Partial Bitstream for PR Core 1B and 2B (page 511)
  - a. Export PR Core 1B as Partition (page 511)
  - b. Export PR Core 2B as Partition (page 512)
  - c. Import PR Core 1B and 2B Into Top-Level Design (page 512)
  - d. Generate Partial Bitstream for PR Core 1B and 2B in Top-level Design (page 513)
- 5. Bitstream Programming Sequence (page 514)
  - a. Apply Power to Board (page 514)
  - b. Program Top-Level Base Bitstream Containing PR Core 1A and 2A (page 514)
  - c. Run PR Core 1A and 2A Test Scripts (page 515)
  - d. Program Partial Bitstream for PR Core 1B and 2B (page 515)
  - e. Run PR Core 1B and 2B Test Scripts (page 515)

## Export Partition for PR Core 1A

## Synthesize PR Core 1A Using Synplify

1. Navigate to the following directory:

```
<ace_install_dir>/examples/partial_reconfiguration/tutorial/AC7t1500ES0/
pr_flow_1/pr_core_1a/src
```

#### (i) Note

<ace\_install\_dir> is the directory path where ACE was installed.

Below this directory should be the following two directories:

• rtl

```
• constraints
```

- 2. In the rtl directory, create a new Synplify project and add all of the RTL files.
- 3. Add the pr\_core\_1a\_timing.sdc file to the constraints directory.
- 4. Create a compile point for the PR core 1 module to be exported as a partition.

#### (i) Note

The compile point cannot be set for the top-level module.

5. Add the pr\_core\_1a\_export\_partitions.fdc file from the constraints directory to the project. The compile point is set in the file as follows:

define\_compile\_point {v:work.pr\_core\_1a} -type {locked}

- 6. In the Project → Implementation Options → Device tab, set Technology to Achronix Speedster7t.
- 7. Set Part to AC7t1500ES0.
- 8. Set Package to F53.
- 9. Set Speed to C2.
- 10. In the **Project** → **Implementation Options** → **Implementation Results** tab, set **Result Base Name** to pr\_core\_1a\_top.
- 11. In the Project  $\rightarrow$  Implementation Options  $\rightarrow$  Verilog tab, set Top Level Module to pr\_core\_1a\_top.
- 12. Set Include Path Order to <ace\_install\_dir>/libraries.
- Add the AC7t1500ES0\_synplify.sv file to the project, this file is under <ace\_install\_dir>/ libraries/device\_models.



#### Figure 247 • Project Example

14. Run and compile the design using Synplify.

- 15. After successful completion, Synplify generates a gate-level netlist under <synplify\_out\_dir>/rev\_1/ pr\_core\_1a\_top.vm.
- 16. Synplify also creates a .prt file indicating that the compile point was successfully set for PR core 1A. This file is generated under <synplify\_out\_dir>/rev\_1/pr\_core\_1a\_top\_partition.prt.

### Run PR Core 1A Through Run Prepare in ACE

- 1. In the **Projects** view, click the (<sup>1</sup>) Create a New Project button.
- 2. Create a project using the pop-up dialog and click **Finish** when complete.
- 3. In the **Projects** view, click the ( 🖆 ) Add Source Files to Project button.
- 4. Add the following files to the project:
  - pr\_core\_1a\_top\_partition.prt (the partition info file created by Synplify in step 1a)
  - pr\_core\_1a\_top.vm (the synthesized netlist created by Synplify in step 1a)
  - <ace\_install\_dir>/examples/partial\_reconfiguration/tutorial/AC7t1500ES0/
     pr\_flow\_1/pr\_core\_1a/src/ioring\_design/pr\_core\_1a\_ioring.pdc
  - <ace\_install\_dir>/examples/partial\_reconfiguration/tutorial/AC7t1500ES0/
     pr\_flow\_1/pr\_core\_1a/src/ioring\_design/pr\_core\_1a\_ioring.sdc
- 5. In the **Options** view, navigate to the **Design Preparation** section and ensure that the **Export All Partitions** option is checked and all other options are correctly set.
- 6. Copy the option values as shown in the following figure.
- 7. In the Flow view, right-click Run Prepare and select Run Selected Flow Step:

|                                                    | Achronix CAD Envi                      | ronment - Version 0.X (Main) - pr_core_1a->impl_1 (AC7t1500ES0)                                                |
|----------------------------------------------------|----------------------------------------|----------------------------------------------------------------------------------------------------------------|
| File Edit Actions Window Help                      |                                        |                                                                                                                |
| 🐸 🗟 🗠 🕜 🗈 🖄 🕐 📴 🖷 📾 📰 🔗 🔗                          | @ <sub>8</sub> 0                       | ٩                                                                                                              |
| ea *Projects 🛛 🗖 🗖                                 | E Options 🕱                            |                                                                                                                |
| 🖀 😂 🍇 🎯 🖨 🖨 🤣 🛠 🕴                                  | Project: pr_core                       | a_la                                                                                                           |
| ▼ ∯ pr_core_la                                     | Implementation: impl_1                 |                                                                                                                |
| 🔻 🗁 Netlists                                       | <ul> <li>Design Preparation</li> </ul> |                                                                                                                |
| ≧ pr_core_la_top.vm ✓ ➢ Constraints                | Target Device                          | AC7t1500ES0                                                                                                    |
| pr_core_la_top_partition.prt pr core la ioring.pdc | Package                                | F53 •                                                                                                          |
| pr_core_la_ioring.sdc                              | Speed Grade                            | C2                                                                                                             |
|                                                    | Core Voltage                           | 0.85                                                                                                           |
| 🕞 output                                           | Junction Temperature                   | 0 •                                                                                                            |
| i reports                                          | Flow Mode                              | Normal                                                                                                         |
| 🎭 Flow 🕱 🕨 🕒                                       | Incremental Compile                    |                                                                                                                |
| ▼ ■ 🟵 Prepare                                      | Enable Increment                       | tal Compile                                                                                                    |
| 🖃 🛦 Run Pr 📃 Run 🗙 lected Flow Step                | Incremental Compile                    | Mode Smart                                                                                                     |
| A Run Es<br>Run Selected Flow Step                 | Export All Partition                   | 28                                                                                                             |
| ▼ ■  Place and Clear Flow                          | Auto-Select Top M                      | odule                                                                                                          |
| Create How Step                                    | Constraint Files                       |                                                                                                                |
| A Run Rouce     A Run Rouce                        | File                                   | Full Path                                                                                                      |
| A Run Post-Route Timing Analysis                   | ✓ pr_core_la_top_p                     |                                                                                                                |
| - S Design Completion                              | ✓ pr_core_la_ioring                    |                                                                                                                |
| Post-Process Design                                | ✓ pr_core_1a_ioring                    | g.s /partial_reconfiguration/tutorial/AC7t1500E50/pr_flow_1/pr_core_1a/src/ioring_design/pr_core_1a_ioring.sdc |
| A Run Final DRC Checks                             |                                        |                                                                                                                |
| 🗹 🛦 Run Sign-off Timing Analysis                   | Advanced Design P                      | reparation                                                                                                     |
| 🗹 🛦 Generate Final Reports                         | Place and Route                        |                                                                                                                |
| 🗌 🛦 Generate Final Simulation Netlist              | Report Generation                      |                                                                                                                |
|                                                    |                                        | 68M of 512M                                                                                                    |

Figure 248 • Run Prepare Flow Step Example

## Set Up Region Constraints for PR Core 1A

- 1. Ensure that the run\_prepare flow step has completed successfully.
- 2. On the Floorplanner view, click the Placement Region Tool button (highlighted in red in the following image).
- 3. Click and drag within the Floorplanner to create a PR zone for the PR core.



Figure 249 • Creating a Placement Region Zone Example

- 4. After releasing the left mouse button, the Create Placement Region dialog appears.
- 5. In **Region Name**, enter a name for the PR zone.
- 6. Set **Region Alignment** to **Snap to Fabric Clusters** (a "fabric cluster" represents the lowest level of granularity at which the core fabric can be partially reconfigured).
- 7. Set the Region Type to Inclusive (ensures that all instances are constrained to the region).
- 8. Select **Include Routing** (ensures that all routed nets are constrained to the region).
- 9. Select Is Partial Reconfiguration Zone (indicates this region is a PR zone).

493

| -                             | Create Placement Region                                                                                |
|-------------------------------|--------------------------------------------------------------------------------------------------------|
| Create Placem                 | ent Region                                                                                             |
| You can create                | placement regions in the Core and constrain instances to them later via drag and drop or TCL commands. |
| -                             |                                                                                                        |
| Region Name                   | PR_ZONE_2_7                                                                                            |
| Region Alignme                | nt                                                                                                     |
| None                          |                                                                                                        |
| O Snap to Tile                |                                                                                                        |
| Snap to Fab                   |                                                                                                        |
| Snap to Clo                   | ck Region Boundaries                                                                                   |
| Region Type                   |                                                                                                        |
| <ul> <li>Inclusive</li> </ul> |                                                                                                        |
| C Keep out                    |                                                                                                        |
| ◯ Soft                        |                                                                                                        |
| Include Rout                  | ing                                                                                                    |
| 🕑 Is Partial Re               | configuration Zone                                                                                     |
| Subtile Grid Cod              | rdinates                                                                                               |
| X1 Coordinate                 | 29                                                                                                     |
| Y1 Coordinate                 | 40                                                                                                     |
| X2 Coordinate                 | 53                                                                                                     |
| Y2 Coordinate                 | 78                                                                                                     |
|                               |                                                                                                        |
|                               |                                                                                                        |
|                               |                                                                                                        |
| (?)                           | Cancel                                                                                                 |
| U                             | Cancel                                                                                                 |
|                               |                                                                                                        |

Figure 250 • Create Placement Region Dialog Example

10. Click **Finish**. The Tcl console displays the following:

```
create_region "PR_ZONE_2_7" {29 40 53 78} -snap fabric_clusters -type inclusive
-include_routing -pr_zone
```

11. Add all instances in the PR core to the region. A recommended quick way of doing so is to use the add\_region\_find\_insts Tcl command nested with the find Tcl command. Run the following example in the Tcl Console to add all instances in PR core 1A to the PR zone (i\_pr\_core\_1a is the instance name for the top-level partial reconfigurable module).

add\_region\_find\_insts "PR\_ZONE\_2\_7" {find {\*i\_pr\_core\_1a\*} -insts}

### Set Up Clock Pre-Routing Constraints for PR Core 1A

1. In the **Partitions** view, right-click the cell below the **Clock Pre-Routes** column heading and select **Configure Clock Pre-Routes** as shown:

| Partition Name                           | Hi                                                             | Clock Pre-Routes                                                                                           | Timestamp                                          | Anchor Instance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Re-compiled | Force Re-compile on | Imported                                    | LUTs    | Flops | ALUS |
|------------------------------------------|----------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---------------------|---------------------------------------------|---------|-------|------|
| hpr_core_la_top                          |                                                                |                                                                                                            | Tue Nov 22 14:37:51 PST 2022                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 4           |                     |                                             | 0       | 0     | 0    |
| <pre>#/pr_core_la_top/i_pr_core_la</pre> | Add II     Add II     Add II     J Highli     Vn-Hi     Choose | how How 23 14:32:51 DST 2022<br>h for Instances ght Partition ghlight Partition ghlight Color To Instances |                                                    | Image: Constraint of the second sec |             |                     | 506  50  5  5  5  5  5  5  5  5  5  5  5  5 | 365<br> | 12    |      |
|                                          |                                                                | Config<br>Force Par                                                                                        | tition Changed Partition Changed Partition Changed |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |             |                     |                                             |         |       |      |

# Figure 251 • Configure Clock Pre-Routes Example

2. The **Configure Clock Pre-Routes** dialog appears with the i\_clk\_pr\_1\_ipin\_net signal that drives the PR core 1A clock pins pre-routed on clock track 1.

| - Configure Clock Pre-Routes |                     |                              |  |
|------------------------------|---------------------|------------------------------|--|
| Net Name:                    | i_clk_pr_1_ipin_net | Partitions:                  |  |
| Clock Tracks:                | 0                   | /pr_core_la_top/i_pr_core_la |  |
|                              | 1                   |                              |  |
|                              | 2                   |                              |  |
|                              | 3                   |                              |  |
|                              | 4                   |                              |  |
|                              | 5                   |                              |  |
|                              | 7                   |                              |  |
|                              | 8                   |                              |  |
|                              | 9                   |                              |  |
|                              | 10                  |                              |  |
|                              | 11                  |                              |  |
|                              | 12                  |                              |  |
|                              | 13                  |                              |  |
|                              | 14<br>15            |                              |  |
|                              | 13                  |                              |  |
|                              |                     |                              |  |
|                              |                     | Cancel OK                    |  |
|                              |                     |                              |  |

# Figure 252 · Configure Clock Pre-Routes Dialog Example

3. Click **OK**. The Tcl console displays the following:

```
add_clock_preroute i_clk_pr_1_ipin_net { 1 } -partitions { /pr_core_1a_top/
i_pr_core_1a }
```

# Run PR Core 1A Through Place-and-Route in ACE

1. In the Flow view, right-click Place and Route and select Run Selected Flow Step as shown:

| ACE - Achronix CAD Environment - Version 0.X (Main) - pr_top_a->impl_1 (AC7t1500ES0) |              |   |  |  |
|--------------------------------------------------------------------------------------|--------------|---|--|--|
| File Edit Actions Window Help                                                        |              |   |  |  |
| 😹 🖬 🖬 🗠 🖈 🖻 🛍 🖉 🔗 📴 🖆 🛤 📕 🗗 🖗                                                        |              | Q |  |  |
| e Projects 🕱 🗖 🗖                                                                     | E Options 🛛  | 8 |  |  |
|                                                                                      |              |   |  |  |
|                                                                                      | 563M of 640M |   |  |  |
|                                                                                      | 563M of 640M |   |  |  |

Figure 253 • Run Place and Route Flow Step Example

# Run Final Sign-Off Timing Analysis for PR Core 1A

- 1. Ensure that the place-and-route flow step completed successfully.
- 2. In the Flow view, right-click Design Completion and select Run Selected Flow Step as shown:

|                                                       | ACE - Achronix CAD Environment - Version 0.X (Main) - pr_core_1a->impl_1 (AC7t1500ES0) | • 🗆 |
|-------------------------------------------------------|----------------------------------------------------------------------------------------|-----|
| File Edit Actions Window Help                         |                                                                                        |     |
| 😹 🔛 🗠 🕑 🖉 🗈 🗴 🖬                                       | 🚑 😓 🙀 👟 🕴 🖇 🖕 수 수 공                                                                    | Q   |
| e Projects 🕱 🖓 🖓                                      | E Options 🛛 🔍 🗖                                                                        | -   |
| 업 년 월 월 월 <b>월 월 월 월</b> 월 ¥ 왕<br>▶ ≝ pr_core_ta      | Project: pr_core_la<br>Implementation: impl_1                                          |     |
|                                                       | Design Preparation                                                                     |     |
|                                                       | Advanced Design Preparation                                                            |     |
|                                                       | ) Place and Route                                                                      |     |
|                                                       | Report Generation                                                                      |     |
|                                                       | • Timing Analysis                                                                      | a   |
|                                                       | Bitstream Generation                                                                   | h   |
|                                                       | > FPGA Download                                                                        | h   |
|                                                       |                                                                                        |     |
| 🎭 Flow 😫 🕨 🕨 🕨 🗮 🖇 🖓 🗖                                |                                                                                        |     |
| 🔻 🔳 🔁 Prepare                                         |                                                                                        |     |
| ■ 🖋 Run Prepare                                       |                                                                                        |     |
| 🗌 🛦 Run Estimated Timing Analysis                     |                                                                                        |     |
| 🔲 🛦 Generate Pre-Placed Simulation Netlist            |                                                                                        |     |
| ▼ ■ @ Place and Route                                 |                                                                                        |     |
| ● � Run Place<br>▲ Run Post-Placement Timing Analysis |                                                                                        |     |
| ■ ✓ Run Route                                         |                                                                                        |     |
| ₩ W Run Post-Route Timing Analysis                    |                                                                                        |     |
| ▼ ■ ③ Design Completion                               |                                                                                        |     |
| A Post-Process                                        |                                                                                        |     |
| A Run Final DRC Run Selected Flow Step                |                                                                                        |     |
| 🗹 🛕 Run Sign-off T                                    |                                                                                        |     |
| 🗹 🛦 Generate Fina 🛛 Clear Flow                        |                                                                                        |     |
| 🗌 🛦 Generate Fina 🔺 Create Flow Step                  |                                                                                        |     |
| Generate Bitstream     A Generate Bitstream           |                                                                                        |     |
| Generate Bitstream     A FPGA Download                |                                                                                        |     |
|                                                       |                                                                                        |     |
|                                                       | 565M of 640M                                                                           |     |
| ·····                                                 |                                                                                        |     |

Figure 254 • Run Design Completion Flow Step Example

# Save Region/Clock Pre-Routing Constraints Back to PDC File

- 1. Ensure that the Design Completion flow step completed successfully.
- 2. In the **Placement Regions** view, click the (**I**) Save Placement Regions button.

| Placement R | egions 🕱 🙀 Clu | sters 💽 Clock F | tegions 品 Partiti | ions 📮 Tcl Conse | ble      |                                       |         |           |            | 🗟 💉 🥖    | 🗖 🔍 🛐 😨 🕴 🖻            |
|-------------|----------------|-----------------|-------------------|------------------|----------|---------------------------------------|---------|-----------|------------|----------|------------------------|
| Visibility  | Name           | Overlay Color   | Clock Pre-Rou     | Soft             | Keep out | Include Routing                       | PR Zone | LUTs      | Flops      | ALUS     | Save Placement Regions |
|             | PR_ZONE_2_7    |                 |                   |                  |          | a a a a a a a a a a a a a a a a a a a | ø       | 505/8,640 | 358/17,280 | 12/2,160 |                        |
|             |                |                 |                   |                  |          |                                       |         |           |            |          |                        |
|             |                |                 |                   |                  |          |                                       |         |           |            |          |                        |
|             |                |                 |                   |                  |          |                                       |         |           |            |          |                        |
|             |                |                 |                   |                  |          |                                       |         |           |            |          |                        |
|             |                |                 |                   |                  |          |                                       |         |           |            |          |                        |
|             |                |                 |                   |                  |          |                                       |         |           |            |          |                        |
|             |                |                 |                   |                  |          |                                       |         |           |            |          |                        |
|             |                |                 |                   |                  |          |                                       |         |           |            |          |                        |
|             |                |                 |                   |                  |          |                                       |         |           |            |          |                        |
|             |                |                 |                   |                  |          |                                       |         |           |            |          |                        |
|             | 1              |                 |                   |                  |          |                                       |         |           |            |          |                        |

## Figure 255 • Save Placement Regions Example

- 3. The Save Placement Regions dialog appears.
- 4. Click **Finish** to save the PR zone region constraints.
- 5. The Tcl console displays the following and the placement\_regions.pdc file is created.

```
create_region "PR_ZONE_2_7" {32 41 87 92} -snap fabric_clusters -type inclusive
-include_routing -pr_zone
add_region_find_insts "PR_ZONE_2_7" {find {*i_pr_core_1a*} -insts
```

6. ACE automatically generates a clock pre-route file to the output area under <ace\_output\_dir>/ace/ impl\_1/output/partial\_reconfig\_core\_1\_top\_clock\_preroutes.pdc.

### (i) Note

This file should not be added to the ACE project as it is regenerated during each run. Make a copy of this file before adding it to the project.

```
Alternately, use the save_clock_preroute Tcl command to generate a .pdc file with the clock pre-route constraints.
```

### Ensure ACE Generated Blackbox File and Exported Partition for PR Core 1A

ACE generates a blackbox file for the exported partition (PR core 1A). Ensure that this file exists in the following directory:

```
<ace_install_dir>/examples/partial_reconfig/tutorial/AC7t1500ES0/pr_flow_1/pr_core_1a/
ace/impl_1/output/blackboxes/pr_core_1a_bb.v
```

ACE also exports a partition database file for the exported partition (PR core 1a). Ensure this file exists in the following directory:

```
<ace_install_dir>/examples/partial_reconfig/tutorial/AC7t1500ES0/pr_flow_1/pr_core_1a/
ace/impl_1/output/partitions/pr_core_1a_top.i_pr_core_1a.epdb
```

## Export Partition for PR Core 2A

#### **Repeat Procedure for PR Core 2A**

1. Repeat the steps in section 1 to export a partition for PR core 2A.

PR core 2A is placed on a different cluster (row=7, col=6) than PR core 1A. Steps 1c, 1d and 1g are skipped by directly adding the following file to the project:

<ace\_install\_dir>/examples/partial\_reconfiguration/tutorial/AC7t1500ES0/pr\_flow\_1/ pr\_core\_2a/pr\_core\_2a\_ace\_placements.pdc

This file contains all the correct region and clock pre-route constraints.

# Importing PR Core 1A and 2A Partitions and Generating Base Bitstream for Top-Level Design

## Create I/O Ring Configuration for Target Board

In this design, a simple clock input is driving a PLL to create clocks for the core fabric. Also, a simple GPIO interface to display LEDs is in the top-level design.

- 1. Navigate to the IP Libraries view.
- 2. Right-click the Clock I/O Bank IP and select New IP Configuration:



Figure 256 • New IP Configuration Example

3. Configure the Clock I/O Bank for the PR cores using the options shown in the following image:

|        | roperties for the Clock | I/O Bank can be edited      | d below.                     |                                          |                |        |         |         |       |              |      |        |              |        |    |         |           |       |         |         |   |
|--------|-------------------------|-----------------------------|------------------------------|------------------------------------------|----------------|--------|---------|---------|-------|--------------|------|--------|--------------|--------|----|---------|-----------|-------|---------|---------|---|
| Bank C | onfiguration            |                             |                              |                                          |                |        |         |         |       |              |      |        |              |        |    |         |           |       |         |         |   |
| ~      | Target Device           | AC7t1500ES0                 |                              |                                          |                |        |         |         |       |              |      |        |              |        |    |         |           |       |         |         | • |
|        | Placement               | CLKIO_SW                    |                              |                                          |                |        |         |         |       |              |      |        |              |        |    |         |           |       |         |         | • |
|        |                         | _                           |                              |                                          |                |        |         |         |       |              |      |        |              |        |    |         |           |       |         |         |   |
| × '    | VREF Source             | Internal VDD                |                              |                                          |                |        |         |         |       |              |      |        |              |        |    |         |           |       |         |         |   |
| ~      | Bank Voltage Level      | 1.5                         |                              |                                          |                |        |         |         |       |              |      |        |              |        |    |         |           |       |         |         | • |
| nabl   |                         | nce Name<br>ank sw 0 msio p | Ball Name<br>CLKIO SE MSIO P | Bump Name<br>CLKIO SW MSIO P             | Ball E<br>AU35 | Differ | .Signal | Port Di | Reset | I/O Standard | Vref | Input. | Output Clock | O Pull | sl | . Tx Ta | . Drive H | yster | ODT Mod | e Rx Ta |   |
|        |                         | ank_sw_0_msio_n             |                              |                                          | AU34           |        |         |         |       |              |      |        |              |        |    |         |           |       |         |         |   |
|        |                         |                             |                              | CLKIO_SW_REFIO_P_0                       |                |        |         | INPUT • |       | LVCMOS_15 •  |      | 100    |              |        |    |         |           |       | High_Z  |         |   |
| ~      |                         |                             |                              | CLKIO_SW_REFIO_N_0                       |                | ~      | Clock   | INPUT   | 1     | LVCMOS_15    |      | 100    |              |        |    |         |           |       | High_Z  | 50      |   |
|        |                         |                             |                              | CLKIO_SW_REFIO_P_1<br>CLKIO_SW_REFIO_N_1 |                |        |         |         |       |              |      |        |              |        |    |         |           |       |         |         |   |
|        | pr_core_clock_lo_b      | ank_sw_o_reno_ri_1          | CERIO_SE_REFIO_N_I           | CERIO_SW_REFIO_N_1                       | AW 30          |        |         |         |       |              |      |        |              |        |    |         |           |       |         |         |   |
| LL an  | d DLL Bank Reset Co     | onfiguration (CAUTIO        | N: not CLKIO!)               |                                          |                |        |         |         |       |              |      |        |              |        |    |         |           |       |         |         |   |
| ~      | PLL/DLL Bank Reset      | Source                      | Internal Reset from F        | cu                                       |                |        |         |         |       |              |      |        |              |        |    |         |           |       |         |         |   |
|        | nu nu nationali         | I Denot Ginnel Marrie       | input_reset_from_an          |                                          |                |        |         |         |       |              |      |        |              |        |    |         |           |       |         |         | 1 |
| ×      | PLL/DLL Bank Globa      | ii keset signal Name        | Input_reset_from_an          |                                          |                |        |         |         |       |              |      |        |              |        |    |         |           |       |         |         |   |
| L Co   | nfiguration (CAUTION    | N: not CLKIO!)              |                              |                                          |                |        |         |         |       |              |      |        |              |        |    |         |           |       |         |         |   |
| ~      | Enable DLL              |                             |                              |                                          |                |        |         |         |       |              |      |        |              |        |    |         |           |       |         |         |   |
| ~      | DLL Reference Clock     | Name clock_f                | rom_local_plls               |                                          |                |        |         |         |       |              |      |        |              |        |    |         |           |       |         |         | , |
|        |                         |                             |                              |                                          |                |        |         |         |       |              |      |        |              |        |    |         |           |       |         |         |   |

Figure 257 • Clock I/O Bank Configuration Example

- 4. In the IP Libraries view, right-click the PLL IP and select New IP Configuration.
- 5. Configure the PLL for the PR core using the options shown in the following image:

| Speedster7t PLL<br>overview                                            |                          |
|------------------------------------------------------------------------|--------------------------|
| Using basic properties, this editor attempts to auto-configure the PLI |                          |
| ✓ Target Device AC7t1500ES0                                            | •                        |
| ✓ Placement PLL_SW_0                                                   | •                        |
| Reference Clock Name     pr_core_clock_io_bank_sw_0                    | •                        |
| Reference Clock Frequency 100.0 MHz                                    |                          |
| ✓ Number of Clock Outputs 3                                            |                          |
| 🖌 🗌 Force Integer Feedback Divider for reduced jitter                  |                          |
| Clock Output 0                                                         |                          |
| ✓ clkout0 Desired Frequency 500                                        |                          |
| clkout0 Achieved Frequency 500.0 MHz                                   |                          |
| Desired - Achieved difference 0.0 MHz                                  |                          |
| Percentage difference 0.0%                                             |                          |
| ✓ Clkout Output 0 Port Name i_clk_pr_1                                 |                          |
| Expose Clock Output to Core Fabric                                     |                          |
| ✓ Phase Shift Factor 0                                                 | -                        |
| VCO Frequency 8000.0 MHz                                               |                          |
| Clock Output 1                                                         |                          |
| ✓ clkout1 Desired Divider                                              | 400.0 MHz                |
| Clkout Output 1 Port Name i_clk_pr_2                                   | Core Fabric              |
| Phase Shift Factor 0                                                   |                          |
| Clock Output 2                                                         |                          |
| ✓ clkout2 Desired Divider 40                                           | 200.0 MHz                |
| ✓ Clkout Output 2 Port Name noc_clk                                    | Core Fabric              |
| ✓ Phase Shift Factor                                                   |                          |
| Expose PLL Lock Signal to Core                                         |                          |
| 0                                                                      | Generate << Back Next >> |

Figure 258 • PLL IP Configuration Example

- 6. In the IP Libraries view, right-click the NoC IP and select New IP Configuration.
- 7. Configure the 2D NoC IP for the PR core using the options shown in the following image:

| 0 | Deedster7t No<br>verview<br>Nis page contains the top-le |             | ies that gover       | n the structure | and base conf | figuration of the | 9 NoC Interface | e. |  |          |       |    |      |    |
|---|----------------------------------------------------------|-------------|----------------------|-----------------|---------------|-------------------|-----------------|----|--|----------|-------|----|------|----|
| ~ | Target Device                                            | AC7t1500ES0 |                      |                 |               |                   |                 |    |  |          |       |    |      | •  |
|   | NoC Frequency Profile<br>NoC Ref Clock Settings          |             | .5 GHz)              |                 |               |                   |                 |    |  |          |       |    |      | -  |
|   | VoC Reference (                                          | Clock Name  | noc_clk<br>200.0 MHz |                 |               |                   |                 |    |  |          |       |    |      | -  |
|   |                                                          |             |                      |                 |               |                   |                 |    |  |          |       |    |      |    |
| ? |                                                          |             |                      |                 |               |                   |                 |    |  | Generate | << Ba | :k | Next | >> |

Figure 259 • 2D NoC IP Configuration Example

- 8. In the IP Libraries view, right-click the Clock I/O Bank IP and select New IP Configuration.
- 9. Configure the Clock I/O Bank for the top-level design using the options shown in the following image:

| Sp    | eedster7t C                         | Clock I/O B          | ank                                   |                                                 |                      |        |           |           |         |              |      |        |                |     |        |       |       |       |        |          |       |
|-------|-------------------------------------|----------------------|---------------------------------------|-------------------------------------------------|----------------------|--------|-----------|-----------|---------|--------------|------|--------|----------------|-----|--------|-------|-------|-------|--------|----------|-------|
| All   | /erview<br>properties for the Clock | I/O Bank can be edit | ted below.                            |                                                 |                      |        |           |           |         |              |      |        |                |     |        |       |       |       | ų.     |          |       |
| Bank  | Configuration                       |                      |                                       |                                                 |                      |        |           |           |         |              |      |        |                |     |        |       |       |       |        |          |       |
| ~     | Target Device                       | AC7t1500ES0          |                                       |                                                 |                      |        |           |           |         |              |      |        |                |     |        |       |       |       |        |          | •     |
| ~     | Placement                           | CLKIO_NE             |                                       |                                                 |                      |        |           |           |         |              |      |        |                |     |        |       |       |       |        |          | •     |
| ~     | VREF Source                         | Internal VDD         |                                       |                                                 |                      |        |           |           |         |              |      |        |                |     |        |       |       |       |        |          | •     |
| ~     | Bank Voltage Level                  | 1.5                  |                                       |                                                 |                      |        |           |           |         |              |      |        |                |     |        |       |       |       |        |          | •     |
| Enabl | pr_top_clock_io_ba                  | ank_ne_0_msio_p      |                                       | Bump Name<br>CLKIO_NE_MSIO_P<br>CLKIO NE MSIO N | Ball 0<br>U16<br>U17 | )iffer | . Signal. | Port Di   | . Reset | I/O Standard | Vref | Input. | . Output Clock | . 0 | Pull T | sl    | Tx Ta | Drive | Hyster | ODT Mode | Rx Ta |
|       |                                     |                      | CLKIO_NW_MSIO_N<br>CLKIO NW REFIO P 0 |                                                 |                      |        | Clock ·   | · INPUT · |         | LVCMOS 15 -  |      | 100    |                | -   |        | -     |       |       |        | High Z • | 50 •  |
|       |                                     |                      | CLKIO NW REFIO N 0                    |                                                 |                      |        |           |           |         |              |      |        |                |     |        |       |       |       |        |          |       |
|       | pr_top_clock_io_ba                  | ank_ne_0_refio_p_1   | CLKIO_NW_REFIO_P_1                    | CLKIO_NE_REFIO_P_1                              | R16                  |        |           |           |         |              |      |        |                |     |        |       |       |       |        |          |       |
|       | pr_top_clock_io_ba                  | ank_ne_0_refio_n_1   | CLKIO_NW_REFIO_N_1                    | CLKIO_NE_REFIO_N_1                              | R17                  |        |           |           |         |              |      |        |                |     |        |       |       |       |        |          |       |
|       |                                     |                      |                                       |                                                 |                      |        | -         |           |         |              |      |        |                |     |        |       |       |       |        |          |       |
| PLL a | ind DLL Bank Reset Co               | onfiguration (CAUT   | ION: not CLKIO!)                      |                                                 |                      |        |           |           |         |              |      |        |                |     |        |       |       |       |        |          |       |
| ~     | PLL/DLL Bank Reset                  | Source               | Internal Reset from                   | FCU                                             |                      |        |           |           |         |              |      |        |                |     |        |       |       |       |        |          | •     |
| ~     | PLL/DLL Bank Globa                  | al Reset Signal Nan  | ne input_reset_from_ar                | iy_clkio_bank                                   |                      |        |           |           |         |              |      |        |                |     |        |       |       |       |        |          | -     |
| DLL C | onfiguration (CAUTIO                | N: not CLKIO!)       |                                       |                                                 |                      |        |           |           |         |              |      |        |                |     |        |       |       |       |        |          |       |
| ~     | Enable DLL                          |                      |                                       |                                                 |                      |        |           |           |         |              |      |        |                |     |        |       |       |       |        |          |       |
| ~     | DLL Reference Clock                 | Name clock           | _from_local_plls                      |                                                 |                      |        |           |           |         |              |      |        |                |     |        |       |       |       |        |          | -     |
| ?     |                                     |                      |                                       |                                                 |                      |        |           |           |         |              |      |        |                |     |        | Gener | rate  | <     | < Back | Ne       | xt >> |

### Figure 260 • Clock I/O Bank IP Configuration Example

- 10. In the IP Libraries view, right-click the PLL IP and select New IP Configuration.
- 11. Configure the PLL for the top-level design using the options shown in the following image:

| Speedster7t PLL                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          | 1.1     |         |   |
|-------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------|---------|---|
| Overview<br>Using basic properties, this editor | tempts to auto-configure the PLL wrapper. For more complicated configurations, see the Advanced PLL.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          | 1       |         |   |
| ✓ Target Device                                 | AC7t1500ES0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |          |         | -       | • |
| V Placement                                     | PLL_NE_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |          |         | -       | Ī |
| ✓ Reference Clock Name                          | clock_io_bank_2_refio_p_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |          |         | -       | Ā |
| Reference Clock Frequency                       | .00.0 MHz                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |          |         |         |   |
| ✓ Number of Clock Outputs                       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |         | -       | • |
| ✓ □ Force Integer Feedback                      | ivider for reduced jitter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |          |         |         |   |
| Clock Output 0                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |         |         |   |
| 🖌 clkout0 Desired Free                          | 500 March Ma |          |         |         |   |
| clkout0 Achieved Fre                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |         |         |   |
| Desired - Achieved o<br>Percentage difference   | erence 0.0 MHz<br>0.0%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |          |         |         |   |
| Clkout Output 0 Port                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |         |         |   |
| 🖌 🗹 Expose Clock Ou                             | ut to Core Fabric                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |         |         |   |
| 🖋 Phase Shift Factor                            | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |         | -       |   |
| VCO Frequency                                   | 3000.0 MHz                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          |         |         |   |
| 🖋 🗌 Expose PLL Lock Signal                      | Core                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          |         |         |   |
| •                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Generate | << Back | Next >> |   |

## Figure 261 • PLL IP Configuration Example

12. In the IP Libraries view, right-click the GPIO Bank IP and select New IP Configuration.

501

13. Configure the GPIO Bank for the top-level design using the options shown in the following image:

| ov           | eedster7t GPIO Ba<br>erview<br>properties for the GPIO Bank can be o |                     |                     |      |         |           |       |                       |         |          |        |      |       |         |        |       |        |         |           |      |       |
|--------------|----------------------------------------------------------------------|---------------------|---------------------|------|---------|-----------|-------|-----------------------|---------|----------|--------|------|-------|---------|--------|-------|--------|---------|-----------|------|-------|
| ank (        | Configuration                                                        |                     |                     |      |         |           |       |                       |         |          |        |      |       |         |        |       |        |         |           |      |       |
| ~            | Target Device                                                        | AC7t1500ES0         |                     |      |         |           | •     | 🖌 Placemen            |         |          |        |      | GPI   | O_N_B   | D      |       |        |         |           |      |       |
| ~            | DDR Mode                                                             | No                  |                     |      |         |           | -     | 🖌 SerDes Ra           | tio     |          |        |      | 1     |         |        |       |        |         |           |      |       |
| ~            | Rx Register Mode                                                     |                     |                     |      |         |           |       | 🖌 🗌 Tx Reg            | ister M | ode      |        |      |       |         |        |       |        |         |           |      |       |
| ~            | Rx Edge Select                                                       | Positive edge       |                     |      |         |           | -     | 🖌 Tx Edge S           | elect   |          |        |      | Pos   | itive e | lge    |       |        |         |           |      |       |
| ~            | Bank Clock Signal Name                                               | pr_top_gpio_bank_   | n_b0_clk_0          |      |         |           | -     | Valid GPIC            | DLL re  | fclk Fre | equer  | ncy: |       |         |        |       |        |         |           |      |       |
|              | Bank (Serial) Clock Frequency<br>GPIO DLL Reference Clock Period     |                     |                     |      |         |           |       | Bank (Par<br>GPIO DLL |         |          |        |      |       |         |        |       |        |         |           |      |       |
| ~            | Bank Reset Source                                                    | Internal Reset from |                     |      |         |           | -     | 🖌 🖌 Bank Glob         | al Rese | t Signa  | al Nai | me   | bar   | nk_rese | t      |       |        |         |           |      |       |
| ~            | VREF Source                                                          | Internal VDD        |                     |      |         |           | •     | 🖋 🛛 Bank Volt         | ige Lev | el       |        |      | 1.1   |         |        |       |        |         |           |      |       |
| nabl.        | I/O Instance Name                                                    | Placement           | Ball/Bump Name      | Ball | Differ. | Port Dire | Pad C | I/O Standard          | Vref    | Pull T.  | sl.    | Tx   | та    | Drive.  | .Tx Ph | Tx To | Hyster | ODT Mod | le Rx Ta. | Rx P | Rx To |
|              | pr_top_gpio_bank_n_b0_clk_0                                          |                     |                     |      |         |           |       |                       |         |          |        |      |       |         |        |       |        |         |           |      |       |
|              | pr_top_gpio_bank_n_b0_clk_1                                          | GPIO_N_B0_CLK_1     | GPIO_N0_BYTE0_BIT_5 | AA16 | 5       |           |       |                       |         |          |        |      |       |         |        |       |        |         |           |      |       |
| $\checkmark$ | outcount[0]                                                          |                     | GPIO_N0_BYTE0_BIT_0 |      |         | OUTPUT -  |       | LVCMOS_11 -           |         | None     | - 3    | - 28 | 3.8 - | 13.9    | 0      | •     |        |         |           |      |       |
| $\checkmark$ | outcount[1]                                                          |                     | GPIO_N0_BYTE0_BIT_1 |      |         | OUTPUT •  |       | LVCMOS_11 •           |         | None     | • 3    | • 28 | 3.8 • | 13.9    | 0      | •     |        |         |           |      |       |
|              | pr_top_gpio_bank_n_b0_data_2                                         |                     |                     |      |         |           |       |                       |         |          |        |      |       |         |        |       |        |         |           |      |       |
|              | pr_top_gpio_bank_n_b0_data_3                                         |                     |                     |      |         |           |       |                       |         |          |        |      |       |         |        |       |        |         |           |      |       |
|              | pr_top_gpio_bank_n_b0_data_4                                         | GPIO_N_B0_DATA_4    | GPIO_N0_BYTE0_BIT_6 | AB17 | 7       |           |       |                       |         |          |        |      |       |         |        |       |        |         |           |      |       |
|              | pr_top_gpio_bank_n_b0_data_5                                         |                     |                     |      |         |           |       |                       |         |          |        |      |       |         |        |       |        |         |           |      |       |
|              | pr_top_gpio_bank_n_b0_data_6                                         | GPIO_N_B0_DATA_6    | GPIO_N0_BYTE0_BIT_8 | AD16 | 5       |           |       |                       |         |          |        |      |       |         |        |       |        |         |           |      |       |
|              | pr_top_gpio_bank_n_b0_data_7                                         | GPIO_N_B0_DATA_7    | GPIO_N0_BYTE0_BIT_9 | AD17 | 7       |           |       |                       |         |          |        |      |       |         |        |       |        |         |           |      |       |

# Figure 262 • GPIO Bank IP Configuration Example

14. Click Generate to display the Generate IO Ring Design Files dialog and select Add to active project.

| -                       | Generate IO Ring Design Files                                                                  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|
| IO Ring File Generation | IO Ring File Generation Configuration                                                          |  |  |  |  |  |  |  |  |  |  |  |
|                         | o generate IO Ring design files into a specified directory,<br>enerated files to your project. |  |  |  |  |  |  |  |  |  |  |  |
| Directory:              | /partial_reconfiguration/tutorial/pr_flow_2/pr_top/ace/ioring_design Browse                    |  |  |  |  |  |  |  |  |  |  |  |
| Add to active project   |                                                                                                |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                                |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                                |  |  |  |  |  |  |  |  |  |  |  |
| 0                       | Cancel Finish                                                                                  |  |  |  |  |  |  |  |  |  |  |  |
|                         |                                                                                                |  |  |  |  |  |  |  |  |  |  |  |



- 15. Click **Finish** to generate the I/O ring design files.
- 16. When complete, the following files should be added to the ACE project:



Figure 264 • I/O Ring Design Files

# Synthesize Top-Level Design Using Synplify

- Create a new Synplify project and add all RTL files from the <ace\_install\_dir>/examples/ partial\_reconfiguration/tutorial/AC7t1500ES0/pr\_flow\_1/pr\_top\_a/src/rtl directory.
- Add the pr\_top\_a\_timing.sdc file from the <ace\_install\_dir>/examples/ partial\_reconfiguration/tutorial/AC7t1500ES0/pr\_flow\_1/pr\_top/src/constraints directory.
- 3. Add the PR core 1A and PR core 2A blackboxes generated by ACE in the previous 2 steps as follows:
  - PR core 1A blackbox <ace\_install\_dir>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_1/pr\_core\_1a/ace/impl\_1/output/blackboxes/pr\_core\_1a\_b.v
  - PR core 2A blackbox <ace\_install\_dir>/examples/partial\_reconfiguration/tutorial/ AC7t1500ES0/pr\_flow\_1/pr\_core\_2a/ace/impl\_1/output/blackboxes/ pr\_core\_2a\_bb.v
- 4. From the main menu, select Project  $\rightarrow$  Implementation Options  $\rightarrow$  Device.
- 5. Set Technology to Achronix Speedster7t.
- 6. Set **Part** to **AC7t1500ES0**.
- 7. Set Package to F53.

- 8. Set Speed to C2.
- 9. From the main menu, select Project  $\rightarrow$  Implementation Options  $\rightarrow$  Implementation Results.
- 10. Set **Result Base Name** to "pr\_top\_a".
- 11. Select Project  $\rightarrow$  Implementation Options  $\rightarrow$  Verilog.
- 12. Set **Top Level Module** to "pr\_top\_a".
- 13. Set Include Path Order to "<ace\_install\_dir>/libraries".
- 14. Add the AC7t1500ES0\_synplify.sv file to the project from the <ace\_install\_dir>/libraries/ device\_models directory.
- 15. Verify that the Synplify project matches the following configuration:

| Project Files Design Hierarchy                                                                                                                                                                                                                                                                                                                                                        |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| proj_1 : rev_1 (pr_top_a) - Achronix Speedster7t : AC7t1500ES0 : F53 : C2                                                                                                                                                                                                                                                                                                             |
| <pre>     /partial_reconfiguration/tutorial/AC7t1500ES0/pr_flow_1/pr_top_a/synplify/proj_1.prj     Verlog     AC7t1500ES0_synplify.sv [work] <sysv>     pr_core_1a_bb.v [work]     pr_top_a.sv [work] <sysv>     pr_shell.sv [work] <sysv>     counter.v [work]     Logic Constraints (SDC)     pr_top_a_timing.sdc     rev_1 <out-of-date> </out-of-date></sysv></sysv></sysv></pre> |
|                                                                                                                                                                                                                                                                                                                                                                                       |

Figure 265 • Synplify Project Example

- 16. Run and compile the design in Synplify.
- 17. When successfully completed, Synplify generates a gate-level netlist as <synplify\_out\_dir>/rev\_1/ pr\_top\_a.vm.

## Run Top-Level Design Through Run Prepare in ACE

- 1. Navigate to the Projects view and click the ( ) Create a New Project button.
- 2. Create a project using the pop-up dialog and click Finish when complete.
- 3. In the Projects view, click the ( 🖹 ) Add Source Files to a Project button.
- 4. Add the following files to your project:

- Blackbox file generated by ACE in step 1j -<ace\_install\_dir>/examples/partial\_reconfig/tutorial/AC7t1500ES0/pr\_flow\_1/ pr\_core\_1a/ace/impl\_1/output/blackboxes/pr\_core\_1a\_bb.v
- Blackbox file generated by ACE in step 2j <ace\_install\_dir>/examples/partial\_reconfig/tutorial/AC7t1500ES0/pr\_flow\_1/ pr\_core\_2a/ace/impl\_1/output/blackboxes/pr\_core\_2a\_bb.v
- Synthesized netlist created by Synplify in step 3a <ace\_install\_dir>/examples/partial\_reconfig/tutorial/AC7t1500ES0/pr\_flow\_1/ pr\_top\_a/synplify/rev\_1/pr\_top\_a.vm
- 5. Add all ioring files created in step 3a to the project.
- 6. Ensure that the blackbox files pr\_core\_1a\_bb.v and pr\_core\_2a\_bb.v are both above the pr\_top\_a.vm file (click and drag the files to change the order).
- 7. In the **Options** view, navigate to the **Design Preparation** section and ensure that the **Export All Partitions** option is <u>cleared</u> and all other options are correctly set.
- 8. In the Flow view, right-click Run Prepare and select Run Selected Flow Step.
- 9. Ensure that the run\_prepare flow step completed successfully.

# Set Up Clock Pre-Routing Constraints

1. In the **Partitions** view, right-click the cell below the **Clock Pre-Routes** heading and select **Configure Clock Pre-Routes** as shown in the following image:

| Partition Name        | Hi | Clock Pre-Routes         | Timestamp                  |          | And                          | hor Instance                     | Re-compiled | Force Re-compile on | Imported  | LUTS | Flops | ALUS | LRAMS | BRAMs | IPINS | OPIN |
|-----------------------|----|--------------------------|----------------------------|----------|------------------------------|----------------------------------|-------------|---------------------|-----------|------|-------|------|-------|-------|-------|------|
| .册/pr_top_a           |    |                          | Thu Dec 08 11:14:47 PST 20 | 022 i    | i_pr_core_1a.i_reg_row_cs_bl | ock.i_axi_master.i_axi_master    | ~           | 4                   |           | 14   | 78    | 8    | 0     | 0     | 0     | 8    |
|                       |    | (i_clk_pr_1_ipin_net: 1) | Thu Dec 08 11:14:47 PST 20 | 022 i    | i_pr_core_1a.i_reg_row_cs_bl | ock.i_axi_master.i_axi_master    |             | ~                   | ~         | 1004 | 690   | 24   | 0     | 0     | 0     | 0    |
| /pr_top_a/i_pr_core_2 | 1  | (i_clk_pr_2_ipin_net: 2  | Thu Dec 08 11:14:47        | 🛷 Sear   | rch for Instances            | _block.i_axi_master.i_axi_master |             | <b>\$</b>           | <b>\$</b> | 1004 | 694   | 24   | 0     | 0     | 0     | 0    |
|                       |    |                          |                            | 💠 Add    | Instances to Selection       |                                  |             |                     |           |      |       |      |       |       |       | 4    |
|                       | -  |                          |                            | / High   | hlight Partition             |                                  |             |                     |           |      |       |      |       |       |       | -    |
|                       | -  |                          |                            | 🚽 Un-H   | Highlight Partition          |                                  |             |                     |           |      |       |      |       |       |       |      |
|                       |    |                          |                            |          | ose Highlight Color          |                                  |             |                     |           |      |       |      |       |       |       |      |
|                       |    |                          |                            |          | m To Instances               |                                  |             |                     |           |      |       |      |       |       |       | _    |
|                       | -  |                          |                            | 🗜 Con    | figure Clock Pre-Routes      |                                  |             |                     |           |      |       |      |       |       |       | +    |
|                       |    |                          |                            | Force P  | artition Changed             |                                  |             |                     |           |      |       |      |       |       |       |      |
|                       |    |                          |                            | Un-Ford  | ce Partition Changed         |                                  |             |                     |           |      |       |      |       |       |       | -    |
|                       | -  |                          |                            | Export I | Partition                    |                                  |             |                     |           |      |       |      |       |       |       | -    |

# Figure 266 • Configure Clock Pre-routes Example

2. In the **Configure Clock Pre-Routes** dialog, ensure that the clock net is pre-routed into the same track specified in step 1d:

| -             | Configure Clock Pro   | e-Routes               |
|---------------|-----------------------|------------------------|
| Net Name:     | i_clk_pr_1_ipin_net 🔹 | Partitions:            |
| Clock Tracks: | 0                     | /pr_top_a/i_pr_core_la |
|               | 1                     |                        |
|               | 2                     |                        |
|               | 3                     |                        |
|               | 4                     |                        |
|               | 5                     |                        |
|               | 6<br>7                |                        |
|               | 8                     |                        |
|               | 9                     |                        |
|               | 10                    |                        |
|               | 11                    |                        |
|               | 12                    |                        |
|               | 13                    |                        |
|               | 14                    |                        |
|               | 15                    |                        |
|               |                       |                        |
|               |                       | Cancel OK              |
|               |                       |                        |

Figure 267 • Configure Clock Pre-Routes Dialog Example

3. Click **OK**. The Tcl Console displays the following:

```
add_clock_preroute i_clk_pr_1_ipin_net 2 -partitions {/pr_top_a/i_pr_core_1a}
```

# Set Up Region Constraints (Optional)

- 1. In the Floorplanner view, navigate to the top section and click the (**1**) Placement Region Tool button.
- 2. Click and drag in the Floorplanner to draw a region bounding box for the top-level logic:





## (i) Note

ACE automatically creates a PR Zone for the imported partition.

- 3. In the Create Placement Region dialog, set Region Alignment to Snap to Fabric Clusters.
- 4. Set Region Type to Inclusive.
- 5. Clear the Is Partial Reconfiguration Zone checkbox.

| -                               | Create Placement Region                                                                                |
|---------------------------------|--------------------------------------------------------------------------------------------------------|
| Create Placem                   | ent Region                                                                                             |
| You can create                  | placement regions in the Core and constrain instances to them later via drag and drop or TCL commands. |
| _                               |                                                                                                        |
| Region Name                     | pr_top_region                                                                                          |
| Region Alignme                  | nt                                                                                                     |
| O None                          |                                                                                                        |
| 🔵 Snap to Tile                  |                                                                                                        |
| <ul> <li>Snap to Fab</li> </ul> |                                                                                                        |
| Snap to Clo                     | ck Region Boundaries                                                                                   |
| Region Type                     |                                                                                                        |
| <ul> <li>Inclusive</li> </ul>   |                                                                                                        |
| 🔵 Keep out                      |                                                                                                        |
| 🔘 Soft                          |                                                                                                        |
| Include Rout                    | ing                                                                                                    |
| 📃 Is Partial Red                | configuration Zone                                                                                     |
| Subtile Grid Cod                | rdinates                                                                                               |
| X1 Coordinate                   | 218                                                                                                    |
| Y1 Coordinate                   | 8                                                                                                      |
| X2 Coordinate                   | 231                                                                                                    |
| Y2 Coordinate                   | 33                                                                                                     |
|                                 |                                                                                                        |
|                                 |                                                                                                        |
|                                 |                                                                                                        |
| 0                               | Cancel                                                                                                 |
|                                 |                                                                                                        |
|                                 |                                                                                                        |

Figure 269 • Create Placement Region Dialog Example

6. Click **Finish**. The Tcl console displays the following:

```
create_region "pr_top_region" {218 8 231 33} -snap fabric_clusters -type inclusive
-include_routing
```

7. As before, add all instances in the PR core to the region using the add\_region\_find\_insts Tcl command nested with the find command. i\_pr\_shell is the instance name for the top-level partial reconfigurable module:

add\_region\_find\_insts "pr\_top\_region" {find {\*i\_pr\_shell\*} -insts}

# Run Top-Level Design Through Place-and-Route in ACE

1. In the Flow view, right-click Place and Route and select Run Selected Flow Step:

|                                                                   |                             |                                                                                  | 1   |
|-------------------------------------------------------------------|-----------------------------|----------------------------------------------------------------------------------|-----|
| .e                                                                |                             | - Achronix CAD Environment - Version 0.X (Main) - pr_top_a->impl_1 (AC7t1500ES0) | ·   |
| File Edit Actions Window Help                                     |                             |                                                                                  |     |
| 🐸 🖬 🖬 🖂 🖷 🖻 🤇                                                     | ) 🌾 🔁 🖻 🖻 📾 🗗 🔗 🖗           | e <sub>6</sub> <mark>0</mark> ⇔ ↔ ↔                                              | ۹   |
| 😋 Projects 🛙                                                      | - 8                         | E Options 2                                                                      | . 0 |
| 🖆 🥩 🖓 1                                                           | 8 🕜 🖓 🖓 😵 👔                 | Project: pr top a                                                                |     |
|                                                                   |                             | Implementation: impl_1                                                           |     |
| Netlists                                                          |                             | Design Preparation                                                               | 49  |
| Constraints                                                       |                             | > Advanced Design Preparation                                                    |     |
| ) ⊜IP                                                             |                             | > Place and Route                                                                | θ   |
| ♥ @ impl_1 > ≥ log                                                |                             | Report Generation                                                                |     |
| iog iog iog                                                       |                             | Thing Analysis                                                                   |     |
| > 🗁 reports                                                       |                             | • Inimity Autorysis<br>• Bitstream Generation                                    |     |
|                                                                   |                             |                                                                                  |     |
|                                                                   |                             | FPGA Download                                                                    |     |
|                                                                   |                             |                                                                                  |     |
| 3) Flow 23                                                        | ► I► III II III             |                                                                                  |     |
| 👻 🚍 🚯 Prepare                                                     |                             |                                                                                  |     |
| 🗖 🖌 Run Prepare                                                   |                             |                                                                                  |     |
| 📃 🛦 Run Estimated Timing Ana                                      |                             |                                                                                  |     |
| 📃 🛦 Generate Pre-Placed Simu                                      | alation Netlist             |                                                                                  |     |
|                                                                   |                             |                                                                                  |     |
| A Run Place                                                       | Ru Kelected Flow Step       |                                                                                  |     |
| <ul> <li>A Run Post-Placement Tim</li> <li>A Run Route</li> </ul> | Re-Run Flow with "-ic init" |                                                                                  |     |
| A Run Post-Route Timing A                                         | Stop Flow                   |                                                                                  |     |
| ▼ ■ Obesign Completion                                            | Clear Flow                  |                                                                                  |     |
| A Post-Process Design                                             | 📥 Create Flow Step          |                                                                                  |     |
| A Run Final DRC Checks                                            | 🎄 Remove Flow Step          |                                                                                  |     |
| 🗹 🛦 Run Sign-off Timing Analy                                     | sis                         |                                                                                  |     |
| 🗹 🛦 Generate Final Reports                                        |                             |                                                                                  |     |
| 🗌 🛦 Generate Final Simulation                                     | Netlist                     |                                                                                  |     |
| 🔻 🚍 🚯 FPGA Programming                                            |                             |                                                                                  |     |
| 🗹 🛦 Generate Bitstream                                            |                             |                                                                                  |     |
| 🔲 🛦 FPGA Download                                                 |                             |                                                                                  |     |
|                                                                   |                             |                                                                                  |     |
|                                                                   |                             |                                                                                  |     |
|                                                                   |                             | 563M of 640M                                                                     |     |



Run Final Sign-Off Timing Analysis in ACE

1. In the Flow view, right click the Design Completion step and select Run Selected Flow Step:





### Generate Base Bitstream for Top-level Design

### (i) Note

The top-level base bitstream contains the top-level design plus the two imported PR cores.

- 1. In the "Options" view, click the Bitstream Generation tab.
- 2. In the FCU Configuration section, check the Lock FCU After Programming checkbox:

| FCU Configuration                 |                              |
|-----------------------------------|------------------------------|
| 4-bit Speedcore Instance ID (hex) | 0                            |
| Memory Scrubbing Mode             | Background Scan and Repair 🗸 |
| CRC Checking Mode                 | Fully Enabled                |
| ✓ Lock FCU After Programming      |                              |

### Figure 272 • Bitstream Generation FCU Configuration Example

3. In the Flow view, right-click the FPGA Programming step and select Run Selected Flow Step:



### Figure 273 • Run FPGA Programming Flow Step Example

### Save Region/Clock Pre-Routing and Partition Placement Constraints Back to PDC File

- 1. Repeat step 1g to save the placement region and clock pre-routing constraints to a pdc file.
- 2. In the **Partitions** view, click the (<sup>SA</sup>) **Save Partition Pre-Placement** button:

| Partition Name                     | Hi | Clock Pre-Routes         | Timestamp                    | Anchor Instance                                           | Re-compiled | Force Save Par | tition Pre-placement Co  | netrainte . | Onens th | e Save  | Dart   |
|------------------------------------|----|--------------------------|------------------------------|-----------------------------------------------------------|-------------|----------------|--------------------------|-------------|----------|---------|--------|
| &/pr_top_a                         |    |                          | Tue Nov 22 21:52:56 PST 2022 | i_pr_core_1a.i_reg_row_cs_block.i_axi_master.i_axi_master | ~           | Placeme        | nt dialog allowing the u | ser to save | the cum  | ent par | titior |
| <pre>}/pr_top_a/i_pr_core_1a</pre> |    | (i_clk_pr_1_ipin_net: 1) | Tue Nov 22 21:52:56 PST 2022 | i_pr_core_1a.i_reg_row_cs_block.i_axi_master.i_axi_master |             | to a pre-      | placement constraints fi | le (.pdc).  |          |         |        |
| /pr_top_a/i_pr_core_2a             |    | (i_clk_pr_2_ipin_net: 2) | Tue Nov 22 21:52:56 PST 2022 | i_pr_core_2a.i_reg_row_cs_block.i_axi_master.i_axi_master |             | ~              | v                        | 502         | 349      | 12      | -      |
|                                    |    |                          |                              |                                                           |             |                |                          |             |          |         |        |
|                                    |    |                          |                              |                                                           |             |                |                          |             |          |         |        |
|                                    |    |                          |                              |                                                           |             |                |                          |             |          |         |        |
|                                    |    |                          |                              |                                                           |             |                |                          |             |          |         |        |
|                                    |    |                          |                              |                                                           |             |                |                          |             |          |         |        |
|                                    |    |                          |                              |                                                           |             |                |                          |             |          |         |        |

Figure 274 • Save Partition Pre-Placement Example

3. In the **Save Partition Pre-Placement Data** dialog, ensure that the **Save Specific List of Partitions** checkbox is <u>cleared</u> in order to save the partition placement constraints for each partition.

| _  | Save Partition Pre-Placement Data                                                                  |
|----|----------------------------------------------------------------------------------------------------|
| Sa | ave Partition Pre-Placements Data: Files                                                           |
| Т  | he current placement data may be saved to disk and optionally added to your project for later use. |
| (  | Suse Default Location for Partition Placement file                                                 |
|    | /partial_reconfiguration/tutorial/pr_flow_1/pr_top_a/ace/partition_preplacement.pdc Browse         |
| (  | Save Specific List of Partitions                                                                   |
|    | /partial_reconfig_partition_top                                                                    |
| (  | Add to project                                                                                     |
|    | Cancel Finish                                                                                      |

Figure 275 • Save Partition Pre-Placement Data Dialog Example

## Generate Partial Bitstream for PR Core 1B and 2B

## Export PR Core 1B as Partition

1. Repeat all steps in section 1 to export PR core 1B as a partition.

PR core 1B is identical to PR core 1A except that the 32-bit adder increments by 2 instead of 1 at each NAP read. The source files for PR core 1B are located in the following directory:

```
<ace_install_dir>/examples/partial_reconfiguration/tutorial/AC7t1500ES0/pr_flow_1/
pr_core_1b/src/...
```

## **Export PR Core 2B as Partition**

1. Repeat all steps in section 1 to export PR core 2B as a partition.

PR core 2B is identical to PR core 2A except that the 32-bit subtractor decrements by 2 instead of 1 at each NAP read.

The source files for PR core 2B are located in the following directory:

```
<ace_install_dir>/examples/partial_reconfiguration/tutorial/AC7t1500ES0/pr_flow_1/
pr_core_2b/src/...
```

## Import PR Core 1B and 2B Into Top-Level Design

- 1. Create an ACE Project named "pr\_top\_b".
- 2. In the **Options** view, set the same options used in step 3b.
- 3. In the **Projects** view, click the ( 🖹 ) **Add Source Files to Project** button.
- 4. Add the following files to the project:
  - All ioring config files generated in step 3a (the I/O in pr\_top\_b is the same as pr\_top\_a so the files can be reused)
  - <ace\_install\_dir>/examples/partial\_reconfig/tutorial/AC7t1500ES0/pr\_flow\_1/
     pr\_core\_1b/ace/impl\_1/output/blackboxes/pr\_core\_1b\_bb.v (blackbox file generated by
     ACE in step 4a).
  - o <ace\_install\_dir>/examples/partial\_reconfig/tutorial/AC7t1500ES0/pr\_flow\_1/ pr\_core\_2b/ace/impl\_1/output/blackboxes/pr\_core\_2b\_bb.v (blackbox file generated by ACE in step 4b).
  - <ace\_install\_dir>/examples/partial\_reconfig/tutorial/AC7t1500ES0/pr\_flow\_1/
     pr\_top\_b/synplify/rev\_1/pr\_top\_b.vm (synthesized netlist created by Synplify in step 3a)
- 5. Ensure that the blackbox files pr\_core\_1b\_bb.v and pr\_core\_2b\_bb.v are both above the pr\_top\_b.vm file (drag and drop files to change the order):



Figure 276 • PR Core Source Files Example

- 6. Run the design through "Place-and-Route" (remember to configure the clock pre-routes by repeating the step 3d).
- 7. Ensure that the clock nets are pre-routed on the same clock track.

## Generate Partial Bitstream for PR Core 1B and 2B in Top-level Design

- 1. Ensure that the Place-and-Route flow step completed successfully.
- 2. Set the bitstream cluster mask and partial reconfiguration option for PR core 1B and 2B (set the mask for both partitions by selecting both in the **Partitions** view):

| Partition Name                  | Hi   | Clock Pre-Routes         | Timestamp                    | Anchor Instance                                           | Re-compiled | Force Re-compile on | Imported | LUTs | Flops | ALUS | LRAMs | BRAMs | IPINS |
|---------------------------------|------|--------------------------|------------------------------|-----------------------------------------------------------|-------------|---------------------|----------|------|-------|------|-------|-------|-------|
| ₽./pr_top_b                     |      |                          | Fri Dec 09 12:38:14 PST 2022 | i_pr_core_1b.i_reg_row_cs_block.i_axi_master.i_axi_master | ~           | ~                   |          | 7    | 39    | 4    | 0     | 0     | 0     |
| <pre>%/pr_top_b/i_pr_core</pre> | _1b  | (i_clk_pr_1_ipin_net: 1) | Fri Dec 09 12:38:14 PST 2022 | i_pr_core_1b.i_reg_row_cs_block.i_axi_master.i_axi_master |             |                     |          | 502  | 345   |      |       |       |       |
| <pre></pre>                     | 2b ( | i clk pr 2 ipin net: 2)  | Fri Dec 09 12:38:14 PST 2022 | i_pr_core_2b.i_reg_row_cs_block.i_axi_master.i_axi_master |             |                     |          | 502  | 345   |      |       |       |       |

### Figure 277 • Selecting PR Core 1B and 2B Example

3. Click the (🗐 ) Send Tcl Command button to set this implementation option. The Tcl Console displays the following:

UG070

set\_impl\_option bitstream\_prc\_cluster\_map 000021000000000000

- 4. In the Options view, click the Bitstream Generation tab.
- 5. In the Partial Reconfiguration section, Check the Enable Partial Reconfiguration checkbox.
- 6. Ensure that the Partial Reconfig Cluster Map (hex) is set to the same value as in the Placement Regions view:

| Partial Reconfiguration                            |                    |  |
|----------------------------------------------------|--------------------|--|
| <ul> <li>Enable Partial Reconfiguration</li> </ul> |                    |  |
| Partial Reconfig Cluster Map (hex)                 | 000021000000000000 |  |

### Figure 278 • Partial Reconfiguration Settings Example

- 7. In the Options view, click the Bitstream Generation tab.
- 8. In the Partial Reconfiguration section, check the Lock FCU After Programming checkbox:

| FCU Configuration                 |                              |
|-----------------------------------|------------------------------|
| 4-bit Speedcore Instance ID (hex) | 0                            |
| Memory Scrubbing Mode             | Background Scan and Repair 🔹 |
| CRC Checking Mode                 | Fully Enabled                |
| ✓ Lock FCU After Programming      |                              |

### Figure 279 • Partial Reconfiguration Settings Example

9. Run the **FPGA Programming** flow step to generate a single partial bitstream for PR core 1B and 2B.

### **Bitstream Programming Sequence**

### **Apply Power to Board**

1. Apply power to the board and ensure cables are properly connected.

### Program Top-Level Base Bitstream Containing PR Core 1A and 2A

1. Run the following commands.

Remember that the pr\_top\_a base bitstream contains PR core 1A, 2A and the top-level logic.

```
set jtag_id [jtag::get_connected_devices]
jtag::open $jtag_id
jtag::configure_scan_chain $jtag_id AC7t1500ES0 0 0 0 -single_device
jtag::ac7t1500_initialize_fcu $jtag_id -reset
jtag::ac7t1500_program_bitstream $jtag_id <ace_install_dir>/examples/
partial_reconfiguration/tutorial/AC7t1500ES0/pr_flow_1/pr_top_a/ace/impl_1/output/
pr_top_a.hex
```

## Run PR Core 1A and 2A Test Scripts

1. Run the following comnands.

The scripts contain NAP reads from PR core 1A and 2A.

```
source <ace_install_dir>/examples/partial_reconfiguration/tutorial/AC7t1500ES0/
pr_flow_1/test_scripts/read_pr_core_1a.tcl
source <ace_install_dir>/examples/partial_reconfiguration/tutorial/AC7t1500ES0/
pr_flow_1/test_scripts/read_pr_core_2a.tcl
```

# Program Partial Bitstream for PR Core 1B and 2B

1. Run the following command.

PR core 1B and 2B can be partially reconfigured onto the board at the same time since a single partial bitstream was generated for both PR core 1B and 2B in step 4d.

```
#Program partial bitstream
jtag::ac7t1500_program_bitstream $jtag_id <ace_install_dir>/examples/
partial_reconfiguration/tutorial/AC7t1500ES0/pr_flow_1/pr_top_b/ace/impl_1/output/
pr_top_b.hex
```

# Run PR Core 1B and 2B Test Scripts

1. Run the following commands.

The scripts contain NAP reads from PR core 1B and 2B.

```
source <ace_install_dir>/examples/partial_reconfiguration/tutorial/AC7t1500ES0/
pr_flow_1/test_scripts/read_pr_core_1b.tcl
source <ace_install_dir>/examples/partial_reconfiguration/tutorial/AC7t1500ES0/
pr_flow_1/test_scripts/read_pr_core_2b.tcl
```

# PR Flow 2: Multi-Project PR Flow Using Keep Out Regions

## Introduction

The Multi-project PR flow using keepout regions is an alternate method to create designs that can be partially reconfigured.

This flow involves using separate ACE projects to generate separate base and partial bitstreams for the top-level design and each PR core. On silicon, the base bitstream is programmed first. Partial bitstreams can be programmed subsequently. Using this flow, the user design is stitched together at a bitstream level. There is no integration in ACE between the the top-level design and each PR core since the designs are stitched at the bitstream level. As such, this flow has a few pitfalls and can only be recommended for advanced users.

## Advantages of Using This PR Flow

- Very fast turn-around time in that the top-level design bypasses place-and-route of the PR cores requiring only a keep-out region
- Enables integrating third party accelerator cores at the bitstream level while not requiring any knowledge of the logic
- Instead of simulating the entire design together, partial bitstreams can be run/tested on the Achronix Virtual Lab which has a faster turn-around time than simulation

## Possible Issues Encountered When Using This PR Flow

- The bitstream might not be stitched together correctly at the bitstream level if any of the ACE projects are configured incorrectly as in the following scenarios:
  - a. In the base bitstream, clock nets to be used in the partial bitstream are not pre-routed. The clock signal is not correctly connected to the PR cores after partial reconfiguration.
  - b. Clock nets are pre-routed on different clock tracks in the partial and base bitstreams. The clock signals are incorrectly connected to the PR cores after partial reconfiguration.
  - c. In the base bitstream, keep-out regions are not set on clusters to be used by PR cores. The top-level logic might be lost after partial reconfiguration.
- The design might not meet timing on paths between the top-level and PR core after the partial bitstream is programmed since timing analysis is done separately in each ACE project.

### (i) Note

The timing delays on the east side are different than those on the west side of the AC7t1500ES0 device.

• Simulating the entire design within an ACE project is difficult as no integration exists between separate ACE projects. It is not impossible but requires a lot of manual work.

To avoid these issues, consider using the multi-project flow with partition export/import (PR flow 1) instead. In that flow, ACE can integrate separate projects created for both the top-level design and for each PR core by taking advantage of the partition export/import feature. This feature enables ACE to run checks to ensure that the top-level design and each PR core can be stitched together correctly. Timing can be closed and simulation run on the integrated design.

### High-level design flow

The bottom-up flow is recommended for PR flow 2. This involves generating the partial bitstreams for each of the PR cores before generating the full bitstream for the top-level design. In the the top-level design, keep-out regions and clock pre-routes on each cluster where the PR cores are partially reconfigured, must be set. As such, it is easier to finish floor planning and generating the partial bitstream for each PR core before working on the top-level design used to create the full bitstream.

Please follow this high-level design flow carefully:

- 1. Partial Bitstream Generation for PR Core 1A (page 517)
  - a. Synthesize PR Core 1A Using Synplify (page 517)
  - b. Run PR Core 1A Through Run Prepare in ACE (page 519)
  - c. Set Up Region Constraints for PR Core 1A (page 520)

- d. Set Up Clock Pre-Routing Constraints for PR Core 1A (page 522)
- e. Run PR Core 1A Through Place-and-Route in ACE (page 524)
- f. Run Final Sign-Off Timing Analysis for PR Core 1A (page 524)
- g. Set Bitstream Cluster Mask and Partial Reconfiguration Option for PR Core 1A (page 525)
- h. Generate Partial Bitstream for PR Core 1A (page 526)
- i. Save Region and Clock Pre-Routing Constraints to PDC File (page 527)
- 2. Generate Partial Bitstream for PR Cores 1B 2A and 2B (page 528)
  - a. Generate Partial Bitstream for PR Core 1B (page 528)
  - b. Generate Partial Bitstream for PR Core 2A (page 528)
  - c. Generate Partial Bitstream for PR Core 2B (page 529)
- 3. Generate Full Bitstream for Top-Level Design (page 529)
  - a. Create I/O Ring Configuration for Target Board (page 529)
  - b. I/O Ring Configuration Steps (page 529)
  - c. Synthesize Top-Level Design Using Synplify (page 534)
  - d. Run Top-Level Design Through Run Prepare in ACE (page 535)
  - e. Set Up Keep Out Regions and Placement Region Constraints for Static Logic (page 536)
  - f. Set Up Clock Pre-Routing Constraints (page 539)
  - g. Run Place-and-Route in ACE for Top-Level Design (page 540)
  - h. Run Final Sign-Off Timing Analysis in ACE for Top-Level Design (page 541)
  - i. Generate Base Bitstream for Top-Level Design (page 542)
  - j. Save Placement Region and Clock Pre-Routing Constraints to PDC File (page 542)
- 4. Bitstream Programming Sequence (page 543)
  - a. Apply Power to Board (page 543)
  - b. Program Top-Level Design Full Bitstream (page 543)
  - c. Program PR Core 1A Partial Bitstream (page 543)
  - d. Run PR Core 1A Test Scripts (page 543)
  - e. Program PR Core 2A Partial Bitstream (page 543)
  - f. Run PR Core 2A Test Scripts (page 544)
  - g. Program PR Core 1B Partial Bitstream (page 544)
  - h. Run PR Core 1B Test Scripts (page 544)
  - i. Program PR Core 2B Partial Bitstream (page 544)
  - j. Run PR Core 2B Test Scripts (page 544)

## Partial Bitstream Generation for PR Core 1A

### Synthesize PR Core 1A Using Synplify

1. Navigate to the following directory:

```
<ace_install_dir>/examples/partial_reconfiguration/tutorial/AC7t1500ES0/
pr_flow_2/pr_core_1a/src
```

### (i) Note

<ace\_install\_dir> is the directory path where ACE was installed.

Below this directory should be the following two directories:

- rtl
- constraints
- 2. In the rtl directory, create a new Synplify project and add all of the RTL files.
- 3. Add the pr\_core\_1a\_timing.sdc file to the constraints directory.
- 4. In the Project  $\rightarrow$  Implementation Options  $\rightarrow$  Device tab, set Technology to Achronix Speedster7t.
- 5. Set Part to AC7t1500ES0.
- 6. Set Package to F53.
- 7. Set **Speed** to **C2**.
- 8. In the Project → Implementation Options → Implementation Results tab, set Result Base Name to pr\_core\_1a\_top.
- 9. In the Project  $\rightarrow$  Implementation Options  $\rightarrow$  Verilog tab, set Top Level Module to pr\_core\_1a\_top.
- 10. Set Include Path Order to <ace\_install\_dir>/libraries.
- 11. In the <ace\_install\_dir>/libraries/device\_models directory, add the AC7t1500ES0\_synplify.sv file to the project

Figure 280 • Project Example

- 12. Run and compile the design using Synplify.
- 13. After successful completion, Synplify generates a gate-level netlist under <synplify\_out\_dir>/rev\_1/ pr\_core\_1a\_top.vm.

## Run PR Core 1A Through Run Prepare in ACE

- 1. In the **Projects** view, click the (<sup>1</sup>) Create a New Project button.
- 2. Create a project using the pop-up dialog and click **Finish** when complete.
- 3. In the **Projects** view, click the ( 🖹 ) Add Source Files to a Project button.
- 4. Add the following files to your ACE project:

  - o <ace\_install\_dir>/examples/partial\_reconfiguration/tutorial/AC7t1500ES0/ pr\_flow\_2/pr\_core\_1a/src/ioring\_design/pr\_core\_1a\_top\_ioring.pdc

(i) Note

This file is required to generate a bitstream because all top-level core fabric pins need to be preplaced.

For partial bitstream projects, either create a dummy .pdc file for the top-level pins, or, use the .pdc file generated from the top-level design through the I/O Designer.

- <ace\_install\_dir>/examples/partial\_reconfiguration/tutorial/AC7t1500ES0/
   pr\_flow\_2/pr\_core\_1a/src/ioring\_design/pr\_core\_1a\_top\_ioring.sdc
- 5. In the **Options** view, navigate to the **Design Preparation** tab and make sure all options are correctly set.
- 6. Copy the option values shown in the following example.
- 7. In the Flow view, right click Run Prepare and select Run Selected Flow Step.

|                                                                  | AD Environment - Version 0.X (Main) - pr_core_la->impl_1 (AC7t1500ES0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |     |
|------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|
| File Edit Actions Window Help                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     |     |
| 🐸 🖬 🖬 🗁 🖟 🐘 🖄 🔍 🕫 🛅 🗗 📾 🏛 🗬 🗮 👘 🗮 🐁 💱 🗇 🗠                        | 5 A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     | Q   |
| 🗞 *Projects 🕱 📫 😂 😂 😂 😫 😫 🗳 🖨 🖨 😭 🥔 🗶 💲 ° 🗆                      | E Options 33                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | - 0 | 6   |
| '≠ ∰ pr_core_1a                                                  | Project: pr core la                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     | 10  |
| ▼ 🕑 Netlists                                                     | Implementation: impl_1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     | 1.7 |
| pr_core_la_top.vm                                                | Design Preparation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |     |
| ♥ Constraints                                                    | Target Device AC7t1500ES0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     |     |
| pr core 1a joring.sdc                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     | 1   |
| > P                                                              | Package F53                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | •   | 6   |
| → @impl_1                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     |     |
|                                                                  | Speed Grade C2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | · · |     |
|                                                                  | Core Woltage 0.85                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |     |     |
|                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     |     |
| 0 <sub>5</sub> Flow ti                                           | Junction Temperature 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | -   |     |
| V Prepare                                                        | Flow Mode Normal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | -   |     |
| A Run Prepare Run Selec X Flow Step                              | Incremental Compile                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |     |
| A Run Estimation Run Selected Flow Step                          | Enable Incremental Compile                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |     |
| 📄 🛦 Generate Pri                                                 | Incremental Compile Mode Smart                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |     |
| Place and Rout Clear Flow     A grant flow from                  | incremental compre Prote Smart                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |     |
| Cleate riow step                                                 | Export All Partitions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     |     |
| A Run Post-Pla                                                   | Auto-Select Top Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |     |
| ✓ ▲ Run Post-Route Timing Analysis                               | Constraint Files                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     |     |
| - Operation                                                      | File Full Path                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |     |
| A Post-Process Design                                            | ✓ pr core 1a ioring.p     /partial reconfiguration,tutorial(AC7t1500ES0/pr flow 2/pr core 1a/src/ioring design/pr core 1a ioring.pdc                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |     |
| A Run Final DRC Checks                                           | ✓ pore_a_tengs // participer consignment of the |     |     |
| 🗹 🛦 Run Sign-off Timing Analysis                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     |     |
| A Generate Final Reports     A Generate Final Simulation Netlist | Advanced Design Preparation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |     |
| Generate Hnal Simulation Netlist     FIGA Programming            | > Place and Route                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |     |     |
| A Generate Bitstream                                             | Report Generation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |     |     |
| A FPGA Download                                                  | Timing Analysis                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     |     |
|                                                                  | Bitstream Generation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     | 1   |
|                                                                  | > FPGA Download                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | _   | 1   |
|                                                                  | 61M of 512M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |     |
|                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | _   | -   |

Figure 281 • Run Prepare Flow Step Example

# Set Up Region Constraints for PR Core 1A

- 1. Ensure that the run\_prepare flow step has completed successfully.
- 2. In the Floorplanner view, click the (**b**) Placement Region Tool button.
- 3. Click and drag on the Floorplanner to draw a PR Zone for the PR Core.



## Figure 282 • Creating a Placement Region Zone Example

- 4. After releasing the left mouse button, the Create Placement Region dialogue appears.
- 5. In Region Name, enter a name for the PR zone
- 6. Set **Region Alignment** to **Snap to Fabric Clusters** (a fabric cluster represents the lowest level of granularity at which the core fabric can be partially reprogrammed).
- 7. Set **Region Type** to **Inclusive** (ensures that all instances are constrained to the region).
- 8. Select Include Routing (ensures that all routed nets are constrained to the region).
- 9. Select Is Partial Reconfiguration Zone (must be selected to indicate this region is a PR Zone).

| -                             | Create Placement Region                                                                                |
|-------------------------------|--------------------------------------------------------------------------------------------------------|
| Create Placem                 | ent Region                                                                                             |
| You can create p              | placement regions in the Core and constrain instances to them later via drag and drop or TCL commands. |
|                               |                                                                                                        |
| Region Name                   | PR_ZONE_2_7                                                                                            |
| Region Alignme                | nt                                                                                                     |
| O None                        | N                                                                                                      |
| 🔵 Snap to Tile                | Boundaries                                                                                             |
| Snap to Fab                   |                                                                                                        |
| Snap to Clo                   | ck Region Boundaries                                                                                   |
| Region Type                   |                                                                                                        |
| <ul> <li>Inclusive</li> </ul> |                                                                                                        |
| 🔘 Keep out                    |                                                                                                        |
| 🔾 Soft                        |                                                                                                        |
| 🗹 Include Rout                | ing                                                                                                    |
| 🕑 Is Partial Rec              | configuration Zone                                                                                     |
| Subtile Grid Coo              | rdinates                                                                                               |
| X1 Coordinate                 | 32                                                                                                     |
| Y1 Coordinate                 | 41                                                                                                     |
| X2 Coordinate                 | 87                                                                                                     |
| Y2 Coordinate                 | 92                                                                                                     |
|                               |                                                                                                        |
|                               |                                                                                                        |
|                               |                                                                                                        |
| 0                             | Cancel                                                                                                 |
| U U                           | Cancer                                                                                                 |
|                               |                                                                                                        |

Figure 283 • Create Placement Region Dialog Example

10. Click Finish. The Tcl console displays the following:

```
create_region "PR_ZONE_2_7" {32 41 48 77} -snap fabric_clusters -type inclusive
-include_routing -pr_zone
```

- 11. Add all the instances in the PR Core to the region. A quick and recommended way of doing so is to use the add\_region\_find\_insts Tcl command nested with the find Tcl command. Run the following example in the Tcl console to add all instances in PR Core 1A to the PR zone (i\_pr\_core\_1a is the instance name for the top-level partial reconfigurable module).
- 12. In the GUI, drag the PR core 1A module in the netlist browser view to the PR\_ZONE\_2\_7 to issue this Tcl command:

add\_region\_find\_insts "PR\_ZONE\_2\_7" {find {\*i\_pr\_core\_1a\*} -insts

13. In the **Floorplanner** tab, the image should resemble the following (the red box represents the bounding box of the PR zone just created):



Figure 284 • PR Zone Bounding Box Example

## Set Up Clock Pre-Routing Constraints for PR Core 1A

There are several different methods for setting up clock pre-routing. For PR flow 2, the easiest way to configure clock pre-routes is to use the **Placement Regions** view.

1. In the **Placement Regions** view, right-click the box below the **Clock Pre-Routes** heading and select **Configure Clock Pre-Routes** as shown:

| isibility | Name        | Overlay Color | Clock Pre-Rou | Soft           | Keep out         | Include Routing                       | PR Zone | LUTs      | Flops      | ALUS     | LRAMs | BRAMS |   |
|-----------|-------------|---------------|---------------|----------------|------------------|---------------------------------------|---------|-----------|------------|----------|-------|-------|---|
|           | PR_ZONE_2_7 |               |               |                |                  | I I I I I I I I I I I I I I I I I I I | ø       | 505/8,640 | 358/17,280 | 12/2,160 | 0/32  | 0/32  |   |
|           |             |               |               | erlay: PR_ZOM  |                  |                                       |         |           |            |          |       |       | 4 |
|           |             |               |               | Constrained In |                  |                                       |         |           |            |          |       |       | + |
|           |             |               |               | t Constrained  |                  |                                       |         |           |            |          |       |       | + |
|           |             |               | Change        | Overlay Colo   | r                |                                       |         |           |            |          |       |       | 1 |
|           |             |               | Reset Over    | lay Color      |                  |                                       |         |           |            |          |       |       |   |
|           |             |               | 🥖 Highligh    | nt Constrained | l Instances      |                                       |         |           |            |          |       |       | 4 |
|           |             |               | 🚽 🖌 🖌 🖌       | ight Constrair | ned Instances    |                                       |         |           |            |          |       |       | - |
|           |             |               | Choose        | Highlight Col  | or for next Higl | nlight command                        |         |           |            |          |       |       | 1 |
|           |             |               | C Zoom T      | : PR_ZONE_2    | _7               |                                       |         |           |            |          |       |       |   |
|           |             |               | Print Instar  | ices: PR_ZON   | E_2_7            |                                       |         |           |            |          |       |       |   |
|           |             |               | Kernove       | All Instances  |                  |                                       |         |           |            |          |       |       |   |
|           |             |               | X Delete I    | Placement Re   | gion             |                                       |         |           |            |          |       |       | - |
|           |             |               | 💄 Configu     | re Clock Pre-F | koutod           |                                       |         |           |            |          |       |       |   |
|           |             |               | Show/H        |                | ~                |                                       |         |           |            |          |       |       |   |
|           |             |               |               | verlay Colors  |                  |                                       |         |           |            |          |       |       | 4 |
|           |             |               | Nebec / III O | venuy colors   |                  |                                       |         |           |            |          |       |       | - |
|           |             |               |               |                |                  |                                       |         |           |            |          |       |       | 1 |
|           |             |               |               |                |                  |                                       |         |           |            |          |       |       |   |
|           |             |               |               |                |                  |                                       |         |           |            |          |       |       |   |
|           |             |               |               |                |                  |                                       |         |           |            |          |       |       |   |
|           |             |               |               |                |                  |                                       |         |           |            |          |       |       |   |

Figure 285 • Configure Clock Pre-Routes Example

2. The **Configure Clock Pre-Routes** dialog appears with the i\_clk\_pr\_1\_ipin\_net signal that drives PR core 1 clock pins pre-routed on clock track 1.

| -             | Configure Clock     | Pre    | -Routes            |
|---------------|---------------------|--------|--------------------|
| Net Name:     | j_clk_pr_1_ipin_net | -      | Placement Regions: |
| Clock Tracks: | 0                   |        | PR_ZONE_2_7        |
|               | 1                   |        |                    |
|               | 2                   |        |                    |
|               | 3                   |        |                    |
|               | 4                   |        |                    |
|               | 5                   |        |                    |
|               | 6                   |        |                    |
|               | 7                   |        |                    |
|               | 9                   |        |                    |
|               | 10                  |        |                    |
|               | 11                  |        |                    |
|               | 12                  |        |                    |
|               | 13                  |        |                    |
|               | 14                  |        |                    |
|               | 15                  |        |                    |
|               |                     |        |                    |
|               |                     | Cancel | ОК                 |
|               |                     | Lance  |                    |

Figure 286 • Configure Clock Pre-Routes Dialog Example

3. Click **OK**. The Tcl console displays the following:

add\_clock\_preroute i\_clk\_pr\_1\_ipin\_net { 1 } -placement\_regions { PR\_ZONE\_2\_7 }

### (i) Note

Each clock net used in the top-level design must be routed on a different clock track.

## Run PR Core 1A Through Place-and-Route in ACE

1. In the Flow view, right-click the Place and Route step and select Run Selected Flow Step.

|                                              | D Environment - Version 0.X (Main) - pr_core_1a->impl_1 (λC7t1500ESO) | •   E |
|----------------------------------------------|-----------------------------------------------------------------------|-------|
| File Edit Actions Window Help                |                                                                       |       |
| 🖉 📓 📾 🔄 🐮 🗈 🖉 🌾 📴 📅 🏙 🗗 🖓 👒 🖓 🗘 🗇 🔿          | ¢                                                                     | Q     |
| 🎦 Projects 🔉 📫 🐸 😂 📽 😫 🖗 📽 🖗 🛠 🕴 " 🗆         | E Options 🛙 🗖                                                         | 8     |
| ▼ <sup>66</sup> pr_core_1a                   | Project: pr core la                                                   |       |
| > Detlists                                   | Implementation: impl_1                                                |       |
| > 🗁 Constraints                              | Design Preparation                                                    | 49    |
| ≥ıP<br>▶∰impl 1                              | Advanced Design Preparation                                           |       |
| r wannipi_x                                  | > Place and Route                                                     | 8     |
|                                              | > Report Generation                                                   |       |
|                                              | > Timing Analysis                                                     |       |
|                                              | Bistream Generation                                                   |       |
|                                              | > FPGA Download                                                       |       |
|                                              | r FGA Duwinoau                                                        |       |
| 93 Flow 23 ► 🕨 🔳 🖇 🗖 🗖                       |                                                                       |       |
| ▼ ■⊕ Prepare                                 |                                                                       |       |
|                                              |                                                                       |       |
| ▲ Run Estimated Timing Analysis              |                                                                       |       |
| 🗌 🛦 Generate Pre-Placed Simulation Netlist   |                                                                       |       |
| ▼ ■ 3 Place and Route                        |                                                                       |       |
| 🖃 🛦 Run Place 🍡 F🗙 Selected Flow Step        |                                                                       |       |
| A Run Post-Place Re-Run Flow with "-ic init" |                                                                       |       |
| Arun Route     Stop Flow                     |                                                                       |       |
| Clearnow                                     |                                                                       |       |
| A part Private File                          |                                                                       |       |
| A Run Final DRC crecks                       |                                                                       |       |
| 🗹 🛦 Run Sign-off Timing Analysis             |                                                                       |       |
| 🗹 🛦 Generate Final Reports                   |                                                                       |       |
| 🗌 🛦 Generate Final Simulation Netlist        |                                                                       |       |
| ▼ ■ G FPGA Programming                       |                                                                       |       |
| 🗹 🛦 Generate Bitstream                       |                                                                       |       |
|                                              |                                                                       |       |
|                                              |                                                                       |       |
|                                              |                                                                       |       |
|                                              | 625M of 712M                                                          |       |

Figure 287 • Run Place and Route Flow Step Example

Run Final Sign-Off Timing Analysis for PR Core 1A

1. In the Flow view, right-click Design Completion and select Run Selected Flow Step.

| ile dit Actions Window Help<br>Projects D Projects D Proj                                                                                                                                 | ACE - Ashronix C                        | AD Environment - Version 0.X (Main) - pr_core_1a->impl_1 (AC7t1500ES0) | • 🗆   |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|------------------------------------------------------------------------|-------|
| Image:                                                                                                                                                                  |                                         | D Environment - version U.X (Main) - pr_core_ia-ximpi_i (Ac/cisuoEsu)  | لك (ك |
| Project: X     • Mediation: impl_1     • Maxined Design Preparation        • Maxined Design Preparation        • Maxined Design Preparation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                         |                                                                        | 0     |
| Project: p_core_1a<br>implementation: impl_1 > Constraints > for x: > Advanced Design Preparation > Advanced Design Preparation > Project: p_core_1a<br>implementation: impl_1 > Obsolute > Advanced Design Preparation > Project: p_core_1a<br>implementation: impl_1 > Obsolute > Advanced Design Preparation > Project: p_core_1a<br>implementation: impl_1 > Obsolute > Advanced Design Preparation > Project: p_core_1a<br>implementation: impl_1 > Obsolute > Advanced Design Preparation > Project: p_core_1a<br>implementation: impl_1 > Obsolute > Advanced Design Preparation > Project: p_core_1a<br>implementation: impl_1 > Obsolute > Advanced Design Preparation > Project: p_core_1a<br>implementation: impl_1 > Obsolute > Advanced Design Preparation > Project: p_core_1a > Project: p_core_1a > Advanced Design Preparation > Project: p_core_1a > Project: p_core_1a > Project: p_core_1a > Project: p_core_1a > Advanced Design Preparation > Project: p_core_1a > Pr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                         |                                                                        | ~     |
| In bedicis In constraints I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 😋 Projects 🛛 📫 🐸 🖼 🎯 😰 🕼 🤣 🗱 🕴 " 🗆      | E Options X                                                            | 8     |
| implementation:   implementation: <td>≠ ≝pr_core_la</td> <td>Project: pr_core la</td> <td></td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ≠ ≝pr_core_la                           | Project: pr_core la                                                    |       |
| ) Design Preparation > Asign Preparation > Asign Preparation > Asign Preparation > Asign Preparation > Bace and Route > Bit Text and Concertation > Timing Analysis > Bit Text and Route > Prepare > Ann Estimated Timing Analysis > Asing Complete > Ann Prepare                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                         | Implementation: impl_1                                                 |       |
| <ul> <li>Advacad Design Preparation</li> <li>Advacad Design Preparation</li> <li>Paration</li> <li>Report Generation</li> <li>Timing Analysis</li> <li>Bitstream Generation</li> <li>FPGA Download</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                         | > Design Preparation                                                   |       |
| Place and Route       > Place and Route     >       > Rop of Generation     >       > Pfor X I     >       > Propare     >       > Place and Route     >       > Pfor X I     >       > Propare     >       > Place and Route     >       > Pfor A Programe     >       > Pfor A Programing Analysis     >       > Prot Proceer Doe     >       > Post Proceer Boo     >       > Ann Final Droc Chornel Boo     >       > Ann Final Strated Timing Analysis     >       > Proce Area Flow Step     >       > Ann Final Droc Chornel Boo     >       > Ann Final Droc Chornel Boo     >       > Ann Final Droc Chornel Boo     >       > Ann Final Strated Timing Analysis     >       > Proce Area Flow Step     >       > A Generate Final Strated Timing Analysis     >       > Proce Area Flow Step     >       > A Generate Final Strated Timing Analysis     >       > Proce Area Flow Step     >       > A Generate Final Strated Timing Analysis     >       > Proce Area Flow Step     >       > A Generate Final Strated Timing Analy                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                         | Advanced Design Preparation                                            |       |
| • Floor Xt • Floor Xt • Prepare •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | / white_r                               |                                                                        |       |
| <ul> <li>Timing Analysis</li> <li>BitStream Generation</li> <li>FPor A Download</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                         | > Penort Generation                                                    |       |
| B Row IS B Row IS C Row Rom                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                         |                                                                        |       |
| PGA Download                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                         |                                                                        |       |
| A flow X<br>P Prepare<br>P Ann Frepare<br>A Run Estimated Timing Analysis<br>A Generate Pre-Paced Simulation Netlist<br>P Bula cand Noute<br>P Run Post-Placement Timing Analysis<br>P Run Sost-Placement P Run Sost-Placement Timing Analysis<br>P Run Sost-Placement Timing Analy                      |                                         |                                                                        |       |
| Prepare                                                                                                                                              |                                         | > FPGA Download                                                        |       |
| Prepare                                                                                                                                              |                                         |                                                                        |       |
| <ul> <li>Vibun Prepare</li> <li>Xiun Estimated Timing Analysis</li> <li>Generate Bitsream</li> <li>Kenove Flow Step</li> <li>A Generate Bitsream</li> <li>Create Bitsream</li> <li>A Generate Bitsream</li> <li>A FBGA Download</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | • • • • • • • • • • • • • • • • • • • • |                                                                        |       |
| A Run Estimated Timing Analysis<br>C Place and Route<br>Place and Route<br>Place Nun Place<br>A Run Post-Placement Timing Analysis<br>Place Shearen Timing Analysis |                                         |                                                                        |       |
| A Generate Pre-Placed Simulation Netlist         ● Place and Route         ● V Run Place         ● V Run Post-Placement Timing Analysis         ● V Run Post-Route Timing Analysis         ● V Run Post-Route Timing Analysis         ● A Dest-Process Dest         ● A Generate Final Re         C Dest Proces         ● ProcA Dewnload                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                         |                                                                        |       |
| VRun Place VRUN Pla                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                         |                                                                        |       |
| ▲ Run Post-Placement Timing Analysis         ✓ Run Post-Placement Timing Analysis         ✓ Run Post-Rutet Timing Analysis         ▲ Run Timing Analysis         ▲ Run Final DRC chw         ▲ Run Sign of Timing         ▲ Generate Final Rist         ← Generate Final Rist         ▲ Generate Final Site         ▲ Remove Final Site         ▲ Final Site         ▲ Remove Final Site                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 👻 🖃 😨 Place and Route                   |                                                                        |       |
| Van Route     Van Route     Van Route     Van Route     Van Stote Thing Analysis     Van School Route Thing Analysis                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                         |                                                                        |       |
| ✓ Man Post-Route Timing Analysis         ✓ Machine Conspletion         ▲ Arun Final DRC Chu       Run Selected Flow Step         ✓ A Brun Sign-off Timing       Clear Flow         ▲ Generate Final Ric       Clear Flow         ▲ Generate Final Rist       Create Flow Step         ✓ A Generate BitIstrature       ▲ Remove Flow Step         ✓ A Generate BitIstrature       ▲ Remove Flow Step                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                         |                                                                        |       |
| <ul> <li>Charles Design Completion</li> <li>A post-Process Design Completion</li> <li>A num Sign-OfT Timit</li> <li>Charles Final Step</li> <li>Generate Final Strep</li> <li>A Create Flow Step</li> <li>A Remove Flow Step</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                         |                                                                        |       |
| A Post-Process Des      Run Sing Cethed Flow Step     A Run Sing Final Si     A Generate Final Si     A Generate Final Si     A Generate Bitttream     A FPGA Download                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                         |                                                                        |       |
| ▲ Run Signoff Timi     ▲ Run Signoff Timi     ▲ Run Salected Flow Step     ▲ Generate Final Re     ← Clear Flow     ▲ Generate Final Site     ← FRoA Popuming     ▲ FPGA Download                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                         |                                                                        |       |
| ✓ A Generate Final Re       Clear Flow         △ A Generate Final Strip       ▲ Create Flow Step         ④ FPGA Pownload       ▲ Remove Flow Step                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | A Run Singl DRC Ch                      |                                                                        |       |
| □ A FPGA Download                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Run Selected Flow Step                  |                                                                        |       |
| PGA Programming     A Enerove Flow Step     A Enerove Flow Step     A FPGA Download                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                         |                                                                        |       |
| ✓ ▲ Generate Bitstream             ▲ FPGA Download                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                         |                                                                        |       |
| □ ▲ FPGA Download                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                         |                                                                        |       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                         |                                                                        |       |
| SSBM of 656M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                         |                                                                        |       |
| 553M of 656M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                         |                                                                        |       |
| SS3M of 656M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                         |                                                                        |       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                         | 553M of 656M                                                           |       |

Figure 288 • Run Design Completion Flow Step Example

## Set Bitstream Cluster Mask and Partial Reconfiguration Option for PR Core 1A

- 1. Ensure that the **Design Completion** flow step has run successfully.
- 2. In the **Placement Regions** view, check the **Visibility** checkbox for the PR\_ZONE\_2\_7 region to be partially reconfigured (the partial reconfig cluster value is computed based on the placement regions having the **Visibility** item checked.

At the bottom of the **Placement Regions** view, in the **Partial reconfig cluster value** section, the bitstream cluster mask value appears for the PR zone region created in step 1c. This value indicates which clusters are occupied by the PR zone. When the bitstream\_prc\_cluster\_map implementation option is set to this value, a partial bitstream is generated for the clusters within the PR Zone.

3. Click the (🗐 ) Send Tcl Command button to set this implementation option.

| Placem       | nent Regions 🛛   |      |                          |      |    |    |   |             |                | ×9 8      | í 🗖       | ्   🖪     | 72       | 000     |   |
|--------------|------------------|------|--------------------------|------|----|----|---|-------------|----------------|-----------|-----------|-----------|----------|---------|---|
| Visibility   | Name             | O    | Clock Pre-Routes         | Soft | Ke | In | P | LUTs        | Flops          | ALUs      | LRAMs     | BRAMs     | IPINs    | OPINs   | С |
| $\checkmark$ | PR_ZONE_2_7      |      | (i_clk_pr_1_ipin_net: 1) |      |    | ~  | ~ | 523/8,208   | 371/16,416     | 12/2,052  | 0/32      | 0/32      | 0/0      | 0/0     | 0 |
|              |                  |      |                          |      |    |    |   |             |                |           |           |           |          |         | - |
|              |                  |      |                          |      |    |    |   |             |                |           |           |           |          |         | _ |
|              |                  |      |                          |      |    |    |   |             |                |           |           |           |          |         |   |
|              |                  |      |                          |      |    |    |   |             |                |           |           |           |          |         | + |
|              |                  |      |                          |      |    |    |   |             |                |           |           |           |          |         |   |
|              |                  |      |                          |      |    |    |   |             |                |           |           |           |          |         | _ |
| Partial ree  | config cluster v | alue | . 00002000000000000      | 900  |    |    | R |             |                |           | _         |           |          |         |   |
|              |                  |      |                          |      |    |    |   | Click to se | nd Tcl comm    | nand:     |           |           |          |         |   |
|              |                  |      |                          |      |    |    |   | set_impl_o  | option bitstre | eam_prc_o | cluster_m | 1ap 00002 | 20000000 | 0000000 | D |

Figure 289 • Send Tcl Command Example

- 4. In the Options view, click the Bitstream Generation tab.
- 5. In the Partial Reconfiguration section, check the Enable Partial Reconfiguration checkbox and ensure that the Partial Reconfig Cluster Map (hex) is set to the value from the Placement Regions view:

| Partial Reconfiguration            |                    |
|------------------------------------|--------------------|
| Enable Partial Reconfiguration     |                    |
| Partial Reconfig Cluster Map (hex) | 000020000000000000 |

### Figure 290 • Partial Reconfiguration Settings Example

6. In the FCU Reconfiguration section, ensure that the Lock FCU After Programming item is checked:

| FCU Configuration                                                                                                                                       |                              |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|--|--|--|--|
| 4-bit Speedcore Instance ID (hex)       0         Memory Scrubbing Mode       Background Scan and Repair         CRC Chasking Mode       Fully Speedcod |                              |  |  |  |  |
| Memory Scrubbing Mode                                                                                                                                   | Background Scan and Repair 🗸 |  |  |  |  |
| CRC Checking Mode                                                                                                                                       | Fully Enabled                |  |  |  |  |
| ✓ Lock FCU After Programming                                                                                                                            |                              |  |  |  |  |

### Figure 291 • FCU Configuration Settings Example

### Generate Partial Bitstream for PR Core 1A

1. In the Flow view, right-click the FPGA Programming step and select Run Selected Flow Step.

| -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                             | ACI     | E - A      | chronix | CAD Environment - Version 0.X (Main) - pr_core_1a->impl_1 (AC7t1500ES0) |     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|---------|------------|---------|-------------------------------------------------------------------------|-----|
| File Edit Actions Windo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | w Help                      |         |            |         |                                                                         |     |
| 🥴 🖬 🖬 📥 i 🖌 🖻                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 💿 📀 😕 🖻 🗰 🔳                 | 🐢 😥 i i | <b>0</b>   | 010     |                                                                         |     |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                             |         |            | 8 = 1   |                                                                         |     |
| Projects 🛿                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                             | • • •   | <i>е</i> ж | 8 -     | D Options 22                                                            | , 🗆 |
| ▼ ≝ pr_core_la                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                             |         |            |         | Project: pr_core_la                                                     |     |
| <ul> <li>&gt; Netlists</li> <li>&gt; Constraints</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                             |         |            |         | Implementation: impl_1                                                  |     |
| Constraints                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                             |         |            |         | + Design Preparation                                                    |     |
| )∰impl 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                             |         |            |         | Advanced Design Preparation                                             |     |
| , at mitiga                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                             |         |            |         | > Place and Route                                                       |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                             |         |            |         | > Report Generation                                                     |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                             |         |            |         | Timing Analysis                                                         |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                             |         |            |         | Bitstream Generation                                                    |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                             |         |            |         | FPGA Download                                                           |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                             |         |            |         | > FPGA Download                                                         |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                             |         |            | 0       |                                                                         |     |
| €, Flow ⊠                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                             | ▶ ₩     | -          | 8 -     |                                                                         |     |
| 🔻 🖃 🔁 Prepare                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                             |         |            |         |                                                                         |     |
| 💻 🖋 Run Prepare                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                             |         |            |         |                                                                         |     |
| 🔲 🛦 Run Estimated Tir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                             |         |            |         |                                                                         |     |
| 📃 🛦 Generate Pre-Pla                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ced Simulation Netlist      |         |            |         |                                                                         |     |
| 🕶 🖻 🕑 Place and Route                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                             |         |            |         |                                                                         |     |
| ■ ✔ Run Place                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                             |         |            |         |                                                                         |     |
| 🗌 🛦 Run Post-Placeme                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ent Timing Analysis         |         |            |         |                                                                         |     |
| ■ ✓ Run Route<br>▼ ✓ Run Post-Route Ti                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                             |         |            |         |                                                                         |     |
| <ul> <li>Run Post-Route II</li> <li>Design Completion</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ming Analysis               |         |            |         |                                                                         |     |
| ✓ Post-Process Des                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                             |         |            |         |                                                                         |     |
| ■ ✓ Post-Process Des                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                             |         |            |         |                                                                         |     |
| Run Sign-off Timi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                             |         |            |         |                                                                         |     |
| ✓ ✓ Generate Final Re                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                             |         |            |         |                                                                         |     |
| 🗌 🛦 Generate Final Si                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                             |         |            |         |                                                                         |     |
| <ul> <li>E Generate man of the second se</li></ul> | Run SeXcted Flow Step       |         |            | (       |                                                                         |     |
| 🗹 🛦 Generate Bitstrea                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                             |         |            |         |                                                                         |     |
| 📃 🛦 FPGA Download                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Re-Run Flow with "-ic init" |         |            |         |                                                                         |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Stop Flow                   |         |            |         |                                                                         |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Clear Flow                  |         |            |         |                                                                         |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 📥 Create Flow Step          |         |            |         |                                                                         |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 🎄 Remove Flow Step          |         |            |         | 555M of 640M                                                            |     |

## Figure 292 • Run FPGA Programming Flow Step Example

## Save Region and Clock Pre-Routing Constraints to PDC File

Subsequent runs must use the same clock pre-routing and placement region constraints. These constraints must be saved to .pdc files and added to the ACE project.

# 🔥 Warning!

Adding .pdc files to an ACE project invalidates the flow and requires re-running the flow steps beginning with Run Prepare.

1. In the **Placement Regions View**, click the (**I**) Save Placement Regions button:

|             | Overlay Color | Clock Pre-Rou | Soft | Keep out | Include Routing       | PR Zone | LUTs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Flops      | ALUS     | Save Placement F | S S    |
|-------------|---------------|---------------|------|----------|-----------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------|------------------|--------|
| PR_ZONE_2_7 |               |               |      |          | <ul> <li>✓</li> </ul> | ø       | 505/8,640                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 358/17,280 | 12/2,160 | Save Placement   | egions |
|             |               |               |      |          |                       |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |            |          |                  |        |
|             |               |               |      |          |                       |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |            |          |                  |        |
|             |               |               |      |          |                       |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |            |          |                  |        |
|             |               |               |      |          |                       |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |            |          |                  |        |
|             |               |               |      |          |                       |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |            |          |                  |        |
|             |               |               |      |          |                       |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |            |          |                  |        |
|             |               |               |      |          |                       |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |            |          |                  |        |
|             |               |               |      |          |                       |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |            |          |                  |        |
|             |               |               |      |          |                       |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |            |          |                  |        |
|             |               |               |      |          |                       |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |            |          |                  |        |
|             |               |               |      |          |                       |         | ACLORE_2_1         V         V           Image: Sector | A          | A        | A                | A      |

Figure 293 • Save Placement Regions Example

2. The Save Placement Regions dialog appears. Click Finish to save the PR zone region constraints:

| -                                                                   | Save Placement Regions                                                                       | [      |
|---------------------------------------------------------------------|----------------------------------------------------------------------------------------------|--------|
| Save Placement Regions Data                                         |                                                                                              |        |
| The current placement regions m<br>optionally added to your project |                                                                                              |        |
| Output File                                                         | /partial_reconfiguration/tutorial/AC7t1500ES0/pr_flow_2/pr_core_1a/ace/placement_regions.pdc | Browse |
| Save All Regions                                                    |                                                                                              |        |
| O Save Specified Region                                             |                                                                                              |        |
| Region Name                                                         |                                                                                              | -      |
| Automatically Add to Project                                        |                                                                                              |        |
|                                                                     |                                                                                              |        |
|                                                                     |                                                                                              |        |
|                                                                     |                                                                                              |        |
| 0                                                                   | Cancel                                                                                       | Finish |
|                                                                     |                                                                                              |        |

Figure 294 • Save Placement Regions Dialog Example

3. The Tcl console displays the following and the placement\_regions.pdc file is created.

```
create_region "PR_ZONE_2_7" {32 41 48 77} -snap fabric_clusters -type inclusive
-include_routing -pr_zone
add_region_find_insts "PR_ZONE_2_7" {find {*i_pr_core_1a*} -insts
```

4. ACE automatically generates a clock pre-route file to the output area under <ace\_output\_dir>/ace/ impl\_1/output/pr\_core\_1a\_top\_clock\_preroutes.pdc.

### (i) Note

This file should not be added to the ACE project as it is regenerated during each run. Make a copy of this file before adding it to the project.

```
Alternately, use the save_clock_preroute Tcl command to generate a .pdc file with the clock pre-route constraints.
```

## Generate Partial Bitstream for PR Cores 1B 2A and 2B

### Generate Partial Bitstream for PR Core 1B

- 1. Repeat the same steps used in section 1 to generate the partial bitstream for PR Core 1 but use the following file:
  - o <ace\_install\_dir>/examples/partial\_reconfiguration/tutorial/AC7t1500ES0/ pr\_flow\_2/pr\_core\_1b

### Generate Partial Bitstream for PR Core 2A

1. Repeat the same steps used in section 1 to generate the partial bitstream for PR Core 1 but use the following file:

o <ace\_install\_dir>/examples/partial\_reconfiguration/tutorial/AC7t1500ES0/ pr\_flow\_2/pr\_core\_2a

## Generate Partial Bitstream for PR Core 2B

1. Repeat the same steps used in section 1 to generate the partial bitstream for PR Core 1 but use the following file:

```
    <ace_install_dir>/examples/partial_reconfiguration/tutorial/AC7t1500ES0/
    pr_flow_2/pr_core_2b
```

## Generate Full Bitstream for Top-Level Design

## Create I/O Ring Configuration for Target Board

In this design, a simple clock input is driving a PLL to create clocks for the core fabric. Also, a simple GPIO interface to display LEDs is in the top-level design.

### I/O Ring Configuration Steps

1. In the IP Libraries view, under IO Ring, right-click Clock I/O Bank and select New IP Configuration.



### Figure 295 • Clock I/O Bank New IP Configuration Example

2. Configure the Clock I/O Bank for the PR Cores using the options shown in the following example:

| Ove      | eedster7t C<br>erview<br>properties for the Clock |                      |                       |                    |        |              |          |           |        |              |      |       |                |          |      |        |              |             |           |      |
|----------|---------------------------------------------------|----------------------|-----------------------|--------------------|--------|--------------|----------|-----------|--------|--------------|------|-------|----------------|----------|------|--------|--------------|-------------|-----------|------|
| ank C    | Configuration                                     |                      |                       |                    |        |              |          |           |        |              |      |       |                |          |      |        |              | 1           |           |      |
|          | Target Device                                     | AC7t1500ES0          |                       |                    |        |              |          |           |        |              |      |       |                |          |      |        |              |             |           |      |
|          |                                                   |                      |                       |                    |        |              |          |           |        |              |      |       |                |          |      |        |              |             |           |      |
| ~        | Placement                                         | CLKIO_SW             |                       |                    |        |              |          |           |        |              |      |       |                |          |      |        |              |             |           | •    |
| <b>~</b> | VREF Source                                       | Internal VDD         |                       |                    |        |              |          |           |        |              |      |       |                |          |      |        |              |             |           | -    |
| ~        | Bank Voltage Level                                | 1.5                  |                       |                    |        |              |          |           |        |              |      |       |                |          |      |        |              |             |           |      |
| nabl     | 1/O Insta                                         | nce Name             | Ball Name             | Bump Name          | Poll ( | Diffor       | Signal   | Port Di   | Porot  | 1/O Standard | Vrof | Input | Output Clack   | O Pull T | cl T | × T2   | Drive Hyster | ODT Made    | Dy Th     |      |
|          |                                                   | ank sw 0 msio p      |                       |                    | AU35   | Jinein       | . Jignan | Port Dimi | veseum | iyo standard | VIEI | mpuc. | . output clock | O Puir I | 511  | × 10   | Dirve Hyster | . 001 14004 | 5 11A 10. |      |
|          |                                                   | ank_sw_0_msio_n      |                       |                    | AU34   |              |          |           |        |              |      |       |                |          |      |        |              |             |           |      |
|          |                                                   |                      |                       | CLKIO_SW_REFIO_P_0 | AY34   | $\checkmark$ | Clock •  | INPUT -   |        | LVCMOS_15 -  |      | 100   |                |          |      |        |              | High_Z      | • 50 ·    |      |
| ~        | pr_core_clock_io_b                                | ank_sw_0_refio_p_0   | CLKIO_SE_REFIO_N_0    | CLKIO_SW_REFIO_N_0 | AW34   | ~            | Clock    | INPUT     |        | LVCMOS_15    |      | 100   |                |          |      |        |              | High_Z      | 50        |      |
|          |                                                   |                      |                       | CLKIO_SW_REFIO_P_1 |        |              |          |           |        |              |      |       |                |          |      |        |              |             |           |      |
|          | pr_core_clock_io_b                                | ank_sw_0_refio_n_1   | CLKIO_SE_REFIO_N_1    | CLKIO_SW_REFIO_N_1 | AW36   |              |          |           |        |              |      |       |                |          |      |        |              |             |           |      |
|          | d DLL Bank Reset Co                               | onfiguration (CAUTIC | Nu pet CLKIQU)        |                    |        |              |          |           |        |              |      |       |                |          |      |        |              |             |           |      |
|          |                                                   | *                    |                       |                    |        |              |          |           |        |              |      |       |                |          |      |        |              |             |           | _    |
| ~        | PLL/DLL Bank Reset                                | Source               | Internal Reset from I | cu                 |        |              |          |           |        |              |      |       |                |          |      |        |              |             |           | 1    |
| ~        | PLL/DLL Bank Globa                                | il Reset Signal Name | input_reset_from_an   | y_clkio_bank       |        |              |          |           |        |              |      |       |                |          |      |        |              |             |           |      |
| 11.00    | nfiguration (CAUTIO                               | N: not CLKIQI)       |                       |                    |        |              |          |           |        |              |      |       |                |          |      |        |              |             |           |      |
|          | Enable DLL                                        | In not carto.)       |                       |                    |        |              |          |           |        |              |      |       |                |          |      |        |              |             |           |      |
| ~        | DLL Reference Clock                               | Name clock_f         | rom_local_plls        |                    |        |              |          |           |        |              |      |       |                |          |      |        |              |             |           |      |
| ?        |                                                   |                      |                       |                    |        |              |          |           |        |              |      |       |                |          |      | ienera |              | Back        | Nex       |      |
| 9        |                                                   |                      |                       |                    |        |              |          |           |        |              |      |       |                |          | 6    | enera  | ste <<       | Back        | Nex       | : >> |

Figure 296 • SW Clock I/O Bank IP Configuration Example

- 3. In the IP Libraries view, under IO Ring, right-click the PLL and select New IP Configuration.
- 4. Configure the PLL for the PR core using the options shown in the following example:

| Speedster7t PLL<br>overview<br>Using basic properties, this editor at                                                                                                                                                 | empts to auto-configure the PLL wrapper. For more complicated configurations, see | ne Advanc                              | red PLL                            |  |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|----------------------------------------|------------------------------------|--|--|--|--|--|--|
| Target Device                                                                                                                                                                                                         | AC7t1500ES0                                                                       |                                        |                                    |  |  |  |  |  |  |
| Placement                                                                                                                                                                                                             | PLL_SW_0                                                                          |                                        |                                    |  |  |  |  |  |  |
| Reference Clock Name     pr_core_clock_io_bank_sw_0_refio_p_0                                                                                                                                                         |                                                                                   |                                        |                                    |  |  |  |  |  |  |
| Reference Clock Frequency 100.0 MHz                                                                                                                                                                                   |                                                                                   |                                        |                                    |  |  |  |  |  |  |
| Number of Clock Outputs                                                                                                                                                                                               | 3                                                                                 |                                        |                                    |  |  |  |  |  |  |
| Force Integer Feedback Di     Clock Output 0                                                                                                                                                                          | vider for reduced jitter                                                          |                                        |                                    |  |  |  |  |  |  |
| <ul> <li>clkout0 Desired Freque<br/>clkout0 Achieved Freque<br/>Desired - Achieved fiff<br/>Percentage difference</li> <li>Clkout Output 0 Port N</li> <li>Expose Clock Output</li> <li>Phase Shift Factor</li> </ul> | erecy 500.0 MHz<br>erence 0.0 MHz<br>0.0%<br>arme i_clk_pr_1                      |                                        | -                                  |  |  |  |  |  |  |
| VCO Frequency 8<br>Clock Output 1                                                                                                                                                                                     | 000.0 MHz                                                                         |                                        |                                    |  |  |  |  |  |  |
| v clkout1 Desired Divide                                                                                                                                                                                              | r 20                                                                              |                                        | clkout1 Output Frequency 400.0 MHz |  |  |  |  |  |  |
| 🖌 Clkout Output 1 Port N                                                                                                                                                                                              | ame i_clk_pr_2                                                                    | ~                                      | Expose Clock Output to Core Fabric |  |  |  |  |  |  |
| ✓ Phase Shift Factor                                                                                                                                                                                                  | 0                                                                                 | •                                      |                                    |  |  |  |  |  |  |
| Clock Output 2                                                                                                                                                                                                        |                                                                                   |                                        |                                    |  |  |  |  |  |  |
| 🖌 clkout2 Desired Divide                                                                                                                                                                                              | r 40                                                                              |                                        | clkout2 Output Frequency 200.0 MHz |  |  |  |  |  |  |
| V Clkout Output 2 Port N                                                                                                                                                                                              | ame noc_clk                                                                       | ✓ ✓ Expose Clock Output to Core Fabric |                                    |  |  |  |  |  |  |
| ✓ Phase Shift Factor                                                                                                                                                                                                  | 0                                                                                 | •                                      |                                    |  |  |  |  |  |  |
| Expose PLL Lock Signal to                                                                                                                                                                                             | Core                                                                              |                                        |                                    |  |  |  |  |  |  |
| 2                                                                                                                                                                                                                     |                                                                                   |                                        | Generate << Back Next >>           |  |  |  |  |  |  |

Figure 297 • SW PLL IP Configuration Example

- 5. In the IP Libraries view, under IO Ring, right-click NoC and select New IP Configuration.
- 6. Configure the 2D NoC IP for the PR Core using the options shown in the following example:

| Speedster7t N<br>Overview<br>This page contains the top-le |                 | es that govern the structure and base confi | guration of the NoC Interface. |          |         |         |
|------------------------------------------------------------|-----------------|---------------------------------------------|--------------------------------|----------|---------|---------|
| ✓ Target Device                                            | AC7t1500ES0     |                                             |                                |          |         | -       |
| ✓ NoC Frequency Profile                                    | C3 Standard (1  | 5 GHz)                                      |                                |          |         | -       |
| NoC Ref Clock Setting                                      |                 |                                             |                                |          |         |         |
| ✓ NoC Reference                                            | Clock Name      | noc_clk                                     |                                |          |         | -       |
| NoC Reference                                              | Clock Frequency | 200.0 MHz                                   |                                |          |         |         |
|                                                            |                 |                                             |                                |          |         |         |
|                                                            |                 |                                             |                                |          |         |         |
| ?                                                          |                 |                                             |                                | Generate | << Back | Next >> |

Figure 298 • 2D NoC IP Configuration Example

- 7. In the IP Libraries view, under IO Ring, right-click Clock I/O Bank and select New IP Configuration.
- 8. Configure the Clock I/O Bank for the top-level design using the options shown in the following example:

| Speedster7t Clock I/O Bank                                              |                                                      |                     |                                          |                    |     |         |             |       |              |      |       |              |   |        |       |       |       |         |          |       |
|-------------------------------------------------------------------------|------------------------------------------------------|---------------------|------------------------------------------|--------------------|-----|---------|-------------|-------|--------------|------|-------|--------------|---|--------|-------|-------|-------|---------|----------|-------|
| Overview All properties for the Clock I/O Bank can be edited below      |                                                      |                     |                                          |                    |     |         |             |       |              |      |       |              |   |        |       |       |       |         |          |       |
| Bank Configuration                                                      |                                                      |                     |                                          |                    |     |         |             |       |              |      |       |              |   |        |       |       |       |         |          |       |
| ✓ Target Device AC711500E50                                             |                                                      |                     |                                          |                    |     |         |             |       |              |      |       |              |   |        |       |       |       |         |          |       |
| ~                                                                       | ✓ Placement CLKIO_NE                                 |                     |                                          |                    |     |         |             |       |              |      |       |              |   |        |       |       |       |         |          |       |
| ~                                                                       | ✓ VREF Source Internal VDD                           |                     |                                          |                    |     |         |             |       |              |      |       |              |   |        |       |       |       |         |          |       |
| ✓ Bank Voltage Level 1.5                                                |                                                      |                     |                                          |                    |     |         |             |       |              |      |       |              |   |        |       |       |       |         |          |       |
| Enab                                                                    |                                                      |                     | Ball Name                                | Bump Name          |     | Signal  | . Port Di P | Reset | I/O Standard | Vref | Input | Output Clock | O | Pull T | sl    | Тх Та | Drive | Hyster  | ODT Mode | Rx Ta |
|                                                                         |                                                      |                     | CLKIO_NW_MSIO_P                          | CLKIO_NE_MSIO_P    | U16 |         |             |       |              |      |       |              |   |        |       |       |       |         |          |       |
|                                                                         |                                                      |                     |                                          | CLKIO_NE_MSIO_N    | U17 |         |             |       |              |      |       |              |   |        |       |       |       |         |          |       |
|                                                                         |                                                      |                     | CLKIO_NW_REFIO_P_0                       |                    |     | Clock • | INPUT -     |       | LVCMOS_15 •  |      | 100   |              |   |        |       |       |       |         | High_Z • | 50 •  |
|                                                                         |                                                      |                     | CLKIO_NW_REFIO_N_0<br>CLKIO NW REFIO P 1 |                    |     |         |             |       |              |      |       |              |   |        |       |       |       |         |          |       |
|                                                                         |                                                      |                     | CLKIO_NW_REFIO_P_1<br>CLKIO_NW_REFIO_N_1 |                    |     |         |             |       |              |      |       |              |   |        |       |       |       |         |          |       |
|                                                                         | pi_top_clock_lo_ba                                   | INK_Ne_0_ren0_N_1   | CLKIO_NW_REFIO_N_1                       | CERIO_NE_REFIO_N_1 | KI/ |         |             |       |              |      |       |              |   |        |       |       |       |         |          |       |
|                                                                         |                                                      |                     |                                          |                    |     |         |             |       |              |      |       |              |   |        |       |       |       |         |          |       |
| PLL a                                                                   | and DLL Bank Reset Co                                | onfiguration (CAUTI | ION: not CLKIO!)                         |                    |     |         |             |       |              |      |       |              |   |        |       |       |       |         |          |       |
| ✓ PLL/DLL Bank Reset Source Internal Reset from FCU                     |                                                      |                     |                                          |                    |     |         |             |       |              |      |       |              |   |        |       |       |       |         |          |       |
| ✓ PLL/DLL Bank Global Reset Signal Name input_reset_from_any_clkio_bank |                                                      |                     |                                          |                    |     |         |             |       |              |      |       |              |   |        |       |       |       |         |          |       |
| DLL C                                                                   | onfiguration (CAUTIO                                 | N: not CLKIO!)      |                                          |                    |     |         |             |       |              |      |       |              |   |        |       |       |       |         |          |       |
| ~                                                                       | Enable DLL                                           |                     |                                          |                    |     |         |             |       |              |      |       |              |   |        |       |       |       |         |          |       |
| *                                                                       | ✓ DLL Reference Clock Name     clock_from_local_plls |                     |                                          |                    |     |         |             |       |              |      |       |              |   | -      |       |       |       |         |          |       |
| ?                                                                       |                                                      |                     |                                          |                    |     |         |             |       |              |      |       |              |   | 0      | Gener | ate   |       | << Back | Ne       | xt >> |

Figure 299 • NE Clock I/O Bank IP Configuration Example

- 9. In the IP Libraries view, under IO Ring, right-click PLL and select New IP Configuration.
- 10. Configure the PLL for the top-level design using the options shown in the following example:

| Speedster7t PLL Overview Using basic properties, this editor attempts to auto-configure the PLL wrapper. For more complicated configurations, see the Advanced |                                                   |          |                             |          |         |         |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|----------|-----------------------------|----------|---------|---------|--|--|--|--|--|--|
| ~                                                                                                                                                              | Target Device AC7t1500ES0                         |          |                             |          |         |         |  |  |  |  |  |  |
| ✓ Placement                                                                                                                                                    |                                                   |          | PLL_NE_0                    |          |         |         |  |  |  |  |  |  |
| ~                                                                                                                                                              | Reference Clock Name                              | pr_top_c | lock_io_bank_ne_0_refio_p_0 |          |         | •       |  |  |  |  |  |  |
|                                                                                                                                                                | Reference Clock Frequency 100.0 MHz               |          |                             |          |         |         |  |  |  |  |  |  |
| ~                                                                                                                                                              | ✓ Number of Clock Outputs 1                       |          |                             |          |         |         |  |  |  |  |  |  |
| ~                                                                                                                                                              | Force Integer Feedback Divider for reduced jitter |          |                             |          |         |         |  |  |  |  |  |  |
|                                                                                                                                                                | Clock Output 0                                    |          |                             |          |         |         |  |  |  |  |  |  |
|                                                                                                                                                                | 🖌 clkout0 Desired Frequ                           | iency    | 500                         |          |         |         |  |  |  |  |  |  |
|                                                                                                                                                                | clkout0 Achieved Free                             |          | 500.0 MHz                   |          |         |         |  |  |  |  |  |  |
|                                                                                                                                                                | Desired - Achieved di<br>Percentage difference    |          | 0.0 MHz<br>0.0%             |          |         |         |  |  |  |  |  |  |
|                                                                                                                                                                | <ul> <li>Clkout Output 0 Port I</li> </ul>        |          | clk                         |          |         |         |  |  |  |  |  |  |
|                                                                                                                                                                | ✓ ✓ Expose Clock Output to Core Fabric            |          |                             |          |         |         |  |  |  |  |  |  |
|                                                                                                                                                                | ✓ Phase Shift Factor                              |          | 0                           |          |         | •       |  |  |  |  |  |  |
|                                                                                                                                                                | VCO Frequency 8000.0 MHz                          |          |                             |          |         |         |  |  |  |  |  |  |
| ~                                                                                                                                                              | ✓                                                 |          |                             |          |         |         |  |  |  |  |  |  |
|                                                                                                                                                                |                                                   |          |                             |          |         |         |  |  |  |  |  |  |
| ?                                                                                                                                                              |                                                   |          |                             | Generate | << Back | Next >> |  |  |  |  |  |  |

# Figure 300 • NE PLL IP Configuration Example

- 11. In the IP Libraries view, under IO Ring, right-click GPIO Bank and select New IP Configuration.
- 12. Configure the GPIO Bank for the top-level design using the options shown in the following example:

| OV<br>All p | eedster7t GPIO Ba<br>rview<br>roperties for the GPIO Bank can be e<br>onfiguration |                                                                                                                                                             |                                                                                                                                                                                      |                                                                  |  |                      |                                                                   |           |                 |           |        |        |                                                       |      |       |           |     |            |       |       |   |
|-------------|------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|--|----------------------|-------------------------------------------------------------------|-----------|-----------------|-----------|--------|--------|-------------------------------------------------------|------|-------|-----------|-----|------------|-------|-------|---|
|             | Target Device                                                                      | AC7t1500ES0                                                                                                                                                 |                                                                                                                                                                                      |                                                                  |  | •                    | ~                                                                 | Placement |                 |           | G      | PIO_N_ | BO                                                    |      |       |           |     |            |       | •     |   |
| ~           | DDR Mode                                                                           | No                                                                                                                                                          |                                                                                                                                                                                      |                                                                  |  |                      | *                                                                 | ~         | SerDes Ratio    |           |        | 1      |                                                       |      |       |           |     |            |       |       | • |
| ~           | ✓ □Rx Register Mode ✓ □Tx Register Mode                                            |                                                                                                                                                             |                                                                                                                                                                                      |                                                                  |  |                      |                                                                   |           |                 |           |        |        |                                                       |      |       |           |     |            |       |       |   |
| ~           | Rx Edge Select                                                                     | Positive edge                                                                                                                                               |                                                                                                                                                                                      |                                                                  |  |                      | -                                                                 | ~         | Tx Edge Select  |           |        |        | ositive                                               | edge |       |           |     |            |       |       | - |
| ~           | Bank Clock Signal Name                                                             | pr_top_gpio_bank_n_b0_clk_0                                                                                                                                 |                                                                                                                                                                                      |                                                                  |  |                      | ~                                                                 |           | Valid GPIO DLL  | efclk Fre | equer  | ncy:   | n                                                     |      |       |           |     |            |       |       |   |
|             | Bank (Serial) Clock Frequency<br>GPIO DLL Reference Clock Period                   |                                                                                                                                                             |                                                                                                                                                                                      |                                                                  |  |                      | Bank (Parallel) Clock Frequency<br>GPIO DLL Phase Shift Increment |           |                 |           |        |        |                                                       |      |       |           |     |            |       |       |   |
| ~           | Bank Reset Source                                                                  | Internal Reset from                                                                                                                                         | FCU                                                                                                                                                                                  |                                                                  |  |                      | ~                                                                 | ~         | Bank Global Re  | et Signa  | al Nar | ne b   | e bank_reset                                          |      |       |           |     | ~          |       |       |   |
| ~           | VREF Source                                                                        | Internal VDD                                                                                                                                                |                                                                                                                                                                                      |                                                                  |  |                      | •                                                                 | ~         | Bank Voltage Le | vel       |        | 1      | 1                                                     |      |       |           |     |            |       |       | • |
|             | pr_top_gpio_bank_n_b0_clk_0<br>pr_top_gpio_bank_n_b0_clk_1<br>outcount[0]          | GPIO_N_B0_CLK_1<br>GPIO_N_B0_DATA_0<br>GPIO_N_B0_DATA_1<br>GPIO_N_B0_DATA_2<br>GPIO_N_B0_DATA_3<br>GPIO_N_B0_DATA_4<br>GPIO_N_B0_DATA_5<br>GPIO_N_B0_DATA_6 | GPIO_NO_BYTE0_BIT_5<br>GPIO_NO_BYTE0_BIT_0<br>GPIO_NO_BYTE0_BIT_1<br>GPIO_NO_BYTE0_BIT_2<br>GPIO_NO_BYTE0_BIT_3<br>GPIO_NO_BYTE0_BIT_6<br>GPIO_NO_BYTE0_BIT_7<br>GPIO_NO_BYTE0_BIT_8 | AA17<br>AA16<br>W17<br>W16<br>Y17<br>Y16<br>AB17<br>AC16<br>AD16 |  | OUTPUT -<br>OUTPUT - | Pad C                                                             | LV        | O Standard Vre  | None      | • 3    | • 28.8 | <ul> <li>Drive</li> <li>13.9</li> <li>13.9</li> </ul> | 0    | •h Tx | To Hyster | ODT | 1ode Rx Ta | Rx P. | Rx Tr | D |

#### Figure 301 • GPIO Bank IP Configuration Example

13. Click Generate to display the Generate IO Ring Design Files dialog and select Add to active project:

| -                       | Generate IO Ring Design Files                                                                |
|-------------------------|----------------------------------------------------------------------------------------------|
| IO Ring File Generation | Configuration                                                                                |
|                         | generate IO Ring design files into a specified directory,<br>enerated files to your project. |
| Directory:              | /partial_reconfiguration/tutorial/AC7t1500ES0/pr_flow_2/pr_top/ace/ioring_design Browse      |
| Add to active project   |                                                                                              |
|                         |                                                                                              |
|                         |                                                                                              |
| 0                       | Cancel                                                                                       |
|                         |                                                                                              |

#### Figure 302 • Generate IO Ring Design Files Dialog Example

- 14. Click **Finish** to generate the I/O ring design files.
- 15. When complete, the following files should be added to the ACE project:

| 音 *Projects 🛛 |                                                                   | Ê        | 2 6    | 1 🔞   | Ê       | ٢      | ٢      |        | - S   | ж   | 000 |  |
|---------------|-------------------------------------------------------------------|----------|--------|-------|---------|--------|--------|--------|-------|-----|-----|--|
| ▼ 🚰 pr_top    |                                                                   |          |        |       |         |        |        |        |       |     |     |  |
| 🗁 Netlists    |                                                                   |          |        |       |         |        |        |        |       |     |     |  |
| 🔻 🗁 Constra   | ints                                                              |          |        |       |         |        |        |        |       |     |     |  |
| 📄 pr_to       | p_ioring.pdc                                                      |          |        |       |         |        |        |        |       |     |     |  |
| 📄 pr_to       | p_ioring.sdc                                                      |          |        |       |         |        |        |        |       |     |     |  |
| 📄 pr_to       | p_ioring_bits                                                     | tream0.h | nex    |       |         |        |        |        |       |     |     |  |
| 📄 pr_to       | p_ioring_bits                                                     | tream1.h | nex    |       |         |        |        |        |       |     |     |  |
| 📄 pr_to       | p_ioring_dela                                                     | ays_C2_8 | 50m∖   | _0C_f | ast.sdo | : (fas | t, 0.8 | 35V, C | )C)   |     |     |  |
| 📄 pr_to       | p_ioring_dela                                                     | ays_C2_8 | 50m∖   | _0C_9 | slow.sd | c (slo | w, 0   | .85V,  | 0C)   |     |     |  |
| 📄 pr_to       | 📄 pr_top_ioring_delays_C2_850mV_125C_fast.sdc (fast, 0.85V, 125C) |          |        |       |         |        |        |        |       |     |     |  |
| 📄 pr_to       | 📄 pr_top_ioring_delays_C2_850mV_125C_slow.sdc (slow, 0.85V, 125C) |          |        |       |         |        |        |        |       |     |     |  |
| 📄 pr_to       | 📄 pr_top_ioring_delays_C2_850mV_n40C_fast.sdc (fast, 0.85V, -40C) |          |        |       |         |        |        |        |       |     |     |  |
| 📄 pr_to       | p_ioring_dela                                                     | ays_C2_8 | 50m∖   | /_n40 | C_slow  | .sdc ( | slow   | , 0.85 | V, -4 | 0C) |     |  |
| 📄 pr_to       | p_ioring_pow                                                      | er.xml   |        |       |         |        |        |        |       |     |     |  |
| 📄 pr_to       | p_ioring_util.                                                    | xml      |        |       |         |        |        |        |       |     |     |  |
| 🔻 🧁 IP        |                                                                   |          |        |       |         |        |        |        |       |     |     |  |
|               | ore_clock_io_l                                                    | _        | .acxip | )     |         |        |        |        |       |     |     |  |
|               | ore_noc.acxip                                                     |          |        |       |         |        |        |        |       |     |     |  |
|               | ore_pll_sw_0.                                                     | -        |        |       |         |        |        |        |       |     |     |  |
|               | p_clock_io_b                                                      | -        |        |       |         |        |        |        |       |     |     |  |
|               | p_gpio_bank                                                       |          | xip    |       |         |        |        |        |       |     |     |  |
|               | p_pll_ne_0.ad                                                     | cxip     |        |       |         |        |        |        |       |     |     |  |
| 🕨 🎬 impl_1    |                                                                   |          |        |       |         |        |        |        |       |     |     |  |

Figure 303 • I/O Ring Design Files

#### Synthesize Top-Level Design Using Synplify

1. Navigate to the following directory:

```
<ace_install_dir>/examples/partial_reconfiguration/tutorial/AC7t1500ES0/
pr_flow_2/pr_top/src
```

Below this directory should be the following two directories:

• rtl

- ° constraints
- 2. Create a new Synplify project and add all RTL files from the rtl directory.
- 3. Add the pr\_top\_timing.sdc file from the constraints directory
- 4. In the **Project** → **Implementation Options** → **Device** tab, set **Technology** to **Achronix Speedster7t**.
- 5. Set Part to AC7t1500ES0.
- 6. Set Package to F53.

- 7. Set Speed to C2.
- 8. In the Project  $\rightarrow$  Implementation Options  $\rightarrow$  Implementation Results tab, set Result Base Name to pr\_top.
- 9. In the Project  $\rightarrow$  Implementation Options  $\rightarrow$  Verilog tab, set Top Level Module to pr\_top.
- 10. Set **Include Path Order** to <ace\_install\_dir>/libraries.
- 11. Add the AC7t1500ES0\_synplify.sv file from the following directory:

#### Figure 304 · Synplify Project Files Example

- 12. Run and compile the design using Synplify.
- 13. When the compile completes successfully, Synplify generates a gate-level netlist in the file: <synplify\_out\_dir>/rev\_1/pr\_top.vm.

#### Run Top-Level Design Through Run Prepare in ACE

- 1. In the **Projects** view, click the (<sup>1</sup>) Create a New Project button.
- 2. Create a project using the pop-up dialog and click **Finish** when complete.
- 3. In the Projects view and click the ( 🖹 ) Add Source Files to a Project button.
- 4. Add the following files to the ACE project:
  - $\,\circ\,\,$  All the ioring files created in step 3  $\,$

- 5. In the Options view, select Design Preparation and make sure all options are correctly set.
- 6. Copy the option values in the following example:

| File Edit Actions Window Help<br>🐸 🔛 🐚 🗁 📌 🖻 🟗 🕐 🌮 🎦 🃅 📅 📰 🗗 🖓 🍛 🕅 🌾 | 68.0                                      |              |                                                                                                                                                                                                   |     |  |  |
|----------------------------------------------------------------------|-------------------------------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|
|                                                                      | 1                                         |              |                                                                                                                                                                                                   |     |  |  |
| 💁 *Projects 🕱 📫 🖆 🛍 🛍 🦑 🗱 🕴 🖇                                        | " 🗖 🗄 Options 🕱                           |              |                                                                                                                                                                                                   |     |  |  |
| r <mark>f</mark> ≓pr_top                                             | Project: pr top                           |              |                                                                                                                                                                                                   |     |  |  |
| 🔻 🗁 Netlists                                                         | Implementation: impl_1                    | L            |                                                                                                                                                                                                   |     |  |  |
| pr_top.vm                                                            | <ul> <li>Design Preparation</li> </ul>    | 1            |                                                                                                                                                                                                   | al  |  |  |
| ▼ (⇒ Constraints                                                     | Target Device                             | AC7t1500ES0  |                                                                                                                                                                                                   | 1   |  |  |
| pr_top_ioring.pdc pr_top_ioring.sdc                                  | larget Device                             | AC/LISODESO  | •                                                                                                                                                                                                 | J   |  |  |
| pr_top_ioring.bitstream0.hex                                         | Package                                   | F53          | •                                                                                                                                                                                                 | 1 I |  |  |
| pr top ioring bitstream1.hex                                         |                                           |              |                                                                                                                                                                                                   | 1   |  |  |
| pr_cop_formg_bioscentration                                          | Speed Grade                               | C2           | •                                                                                                                                                                                                 |     |  |  |
| pr top ioring delays C2 850mV OC slow.sdc (slow, 0.85V, OC)          |                                           |              |                                                                                                                                                                                                   |     |  |  |
| pr_top_ioring_delays_C2_850mV_125C_fast.sdc (fast, 0.85V, 125C)      | Core Voltage                              | 0.85         | •                                                                                                                                                                                                 |     |  |  |
| pr_top_ioring_delays_C2_850mV_125C_slow.sdc (slow. 0.85V. 125C)      | Junction Temperature                      |              |                                                                                                                                                                                                   |     |  |  |
| 📄 pr_top_ioring_delays_C2_850mV_n40C_fast.sdc (fast, 0.85V, -40C)    | junction remperature                      | ·            |                                                                                                                                                                                                   |     |  |  |
| pr_top_ioring_delays_C2_850mV_n40C_slow.sdc (slow, 0.85V, -40C)      | Flow Mode                                 | Normal       | •                                                                                                                                                                                                 |     |  |  |
| pr_top_ioring_power.xml                                              | Incremental Compile                       |              |                                                                                                                                                                                                   |     |  |  |
| pr_top_ioring_util.xml                                               | Enable Incremen                           |              |                                                                                                                                                                                                   |     |  |  |
| ) ⊜ip<br>) ∰impl_1                                                   |                                           |              |                                                                                                                                                                                                   |     |  |  |
| > @impi_1                                                            | Incremental Compile                       | e Mode Smart | •                                                                                                                                                                                                 |     |  |  |
|                                                                      | Export All Partitio                       | ns           |                                                                                                                                                                                                   |     |  |  |
| ۍ Flow 🗱 🕨 🕷 🕴 🕯                                                     | Auto-Select Top M                         | Iodule       |                                                                                                                                                                                                   |     |  |  |
| 🛩 🚍 😆 Prepare                                                        |                                           |              |                                                                                                                                                                                                   |     |  |  |
| 📼 🛦 Run Prepare                                                      | Constraint Files                          |              |                                                                                                                                                                                                   |     |  |  |
| 📃 🛦 Run Estimated Timing Analysis                                    | File                                      | Full Path    |                                                                                                                                                                                                   |     |  |  |
| 📃 🛦 Generate Pre-Placed Simulation Netlist                           | ✓ pr_top_ioring.pd                        |              | /tutorial/AC7t1500ES0/pr_flow_2/pr_top/src/ioring_design/pr_top_ioring.pdc                                                                                                                        |     |  |  |
| Place and Route                                                      | ✓ pr_top_ioring.sde                       |              | /tutorial/AC7t1500ES0/pr_flow_2/pr_top/src/ioring_design/pr_top_ioring.sdc                                                                                                                        |     |  |  |
| 💻 📥 Run Place                                                        | ✓ pr_top_ioring_bit                       |              | /tutorial/AC7t1500E50/pr_flow_2/pr_top/src/ioring_design/pr_top_ioring_bitstream0.hex<br>/tutorial/AC7t1500E50/pr_flow_2/pr_top/src/ioring_design/pr_top_ioring_bitstream1.hex                    |     |  |  |
| A Run Post-Placement Timing Analysis                                 | ✓ pr_top_ioring_bit<br>✓ pr top ioring de |              | /tutorial/AC/t1S00ES0/pr_flow_2/pr_top/src/ioring_design/pr_top_ioring_bitstream1.nex<br>/tutorial/AC7t1S00ES0/pr_flow_2/pr_top/src/ioring_design/pr_top_ioring_delays_C2_850mV_0C_fast           |     |  |  |
| A Run Route                                                          | ✓ pr_top_ioring_de                        |              | /tutorial/AC7t1500E50/pr_flow_2/pr_top/src/ioring_design/pr_top_ioring_delays_C2_850mV_0C_flast<br>/tutorial/AC7t1500E50/pr_flow_2/pr_top/src/ioring_design/pr_top_ioring_delays_C2_850mV_0C_slow |     |  |  |
| 🗹 🛦 Run Post-Route Timing Analysis<br>🔎 🗉 Design Completion          | ✓ pr_top_ioring_de                        |              | /tutorial/AC7t1500E50/pr_flow_2/pr_top/src/ioring_design/pr_top_ioring_desays_22_550HV_6C_stor                                                                                                    |     |  |  |
| A Post-Process Design                                                | ✓ pr_top_ioring_de                        |              | /tutorial/AC7t1500ES0/pr_flow_2/pr_top/src/ioring_design/pr_top_ioring_delays_C2_850mV_125C_sl                                                                                                    |     |  |  |
| A Run Final DRC Checks                                               | ✓ pr_top_ioring_de                        |              | /tutorial/AC7t1500E50/pr flow 2/pr top/src/ioring design/pr top ioring delays C2 850mV n40C fa                                                                                                    |     |  |  |
| A Run Sign-off Timing Analysis                                       | ✓ pr top ioring de                        |              | /tutorial/AC7t1500E50/pr_flow_2/pr_top/src/ioring_design/pr_top_ioring_delays_C2_850mV_n40C_sl                                                                                                    |     |  |  |
|                                                                      |                                           |              | 72M of 512M                                                                                                                                                                                       |     |  |  |

Figure 305 • Design Preparation Options Example

7. In the Flow view, right-click the Run Prepare step and select Run Selected Flow Step.

#### Set Up Keep Out Regions and Placement Region Constraints for Static Logic

Keep out regions must be created in order to define "holes" in the core fabric that the top-level logic should not enter. These holes are later filled by partial reconfiguration bitstreams.

- 1. Ensure that the Run Prepare flow step has completed successfully.
- 2. In the Floorplanner view, click the ( ) Placement Region Tool button.
- 3. Click and drag in the Floorplanner to draw a PR Zone for the PR Core.

#### (i) Note

The bounding box of this keep out region must be the same as the one set for PR core 1A in section 1d.



#### Figure 306 • Creating a Placement Region Zone Example

- 4. After releasing the left mouse button, the **Create Placement Region** dialog appears.
- 5. Set Region Alignment to Snap to Fabric Clusters.
- 6. Set Region Type to Keepout.

#### (i) Note

The bounding box of this region has to match that of the PR Zone for PR Core 1A created in step 1c.

| -                                | Create Placement Region                                                                                |
|----------------------------------|--------------------------------------------------------------------------------------------------------|
| Create Placem                    | ient Region                                                                                            |
| You can create p                 | placement regions in the Core and constrain instances to them later via drag and drop or TCL commands. |
|                                  |                                                                                                        |
| Region Name                      | PR_ZONE_2_7                                                                                            |
| Region Alignme                   | nt                                                                                                     |
| None                             |                                                                                                        |
| <ul> <li>Snap to Tile</li> </ul> |                                                                                                        |
| <ul> <li>Snap to Fab</li> </ul>  |                                                                                                        |
| Snap to Clo                      | ock Region Boundaries                                                                                  |
| Region Type                      |                                                                                                        |
| <ul> <li>Inclusive</li> </ul>    |                                                                                                        |
| <ul> <li>Keep out</li> </ul>     |                                                                                                        |
| ◯ Soft                           |                                                                                                        |
| 🗌 Include Rout                   | ting                                                                                                   |
| 🗌 Is Partial Red                 | configuration Zone                                                                                     |
| Subtile Grid Cod                 | rdinates                                                                                               |
| X1 Coordinate                    | 29                                                                                                     |
| Y1 Coordinate                    | 43                                                                                                     |
| X2 Coordinate                    | 53                                                                                                     |
| Y2 Coordinate                    | 76                                                                                                     |
|                                  |                                                                                                        |
|                                  |                                                                                                        |
|                                  |                                                                                                        |
|                                  |                                                                                                        |
| 0                                | Cancel Finish                                                                                          |

Figure 307 • Create Placement Region Dialog Example

- 7. Repeat steps 2 through 6 to create a keep out region for the PR zone for PR core 2A.
- 8. Optionally, create a region for the top-level logic. The foorplanner view should resemble the following example after performing these steps:

Red region - keep out region for PR core 1A.

Light blue region - keep out region for PR core 2A.

Yellow region - region for top-level logic.



Figure 308 • Floor Planner Regions Example

#### Set Up Clock Pre-Routing Constraints

1. In the **Placement Regions** view, right-click the box below the **Clock Pre-Routes** heading and select **Configure Clock Pre-Routes**:

| 📲 Placen   | nent Regions 🛿      |   |                  |                                  |                  |              |         |       |       |       |       |        |       |      |       |       |
|------------|---------------------|---|------------------|----------------------------------|------------------|--------------|---------|-------|-------|-------|-------|--------|-------|------|-------|-------|
| Visibility | Name                | O | Clock Pre-Routes | Soft Ke In                       |                  | Flops        |         | LRAMs | BRAMs | IPINs | OPINS | CLK_IP | CLK_O | MLPs | NAP_M | NAP_S |
|            | PR_ZONE_2_7_KEEPOUT |   |                  | ~                                |                  | 0/16 /16     | 0/2 052 | 0/32  |       |       |       |        |       |      |       | 0/1   |
|            | PR_ZONE_7_6_KEEPOUT |   |                  | de overlay: PR_Z                 |                  | POUT         |         | 32    | 0/32  | 0/0   | 0/0   | 0/0    | 0/0   | 0/32 | 0/1   | 0/1   |
|            | shell_region        |   | 💠 Se             | lect Constrained                 | Instances        |              |         | 32    | 0/32  | 0/0   | 0/0   | 0/0    | 0/0   | 0/32 | 0/1   | 0/1   |
|            |                     |   | 2 D              | X Deselect Constrained Instances |                  |              |         |       |       |       |       |        |       |      |       |       |
|            |                     |   | Cł               | ange Overlay Co                  | lor              |              |         |       |       |       |       |        |       |      |       |       |
|            |                     |   | Reset            | Overlay Color                    |                  |              |         |       |       |       |       |        |       |      |       |       |
|            |                     |   | 🥖 Hi             | ghlight Constrain                | ed Instances     |              |         |       |       |       |       |        |       |      |       |       |
|            |                     |   | 💉 Ui             | nhighlight Constra               | ained Instanc    | es           |         |       |       |       |       |        |       |      |       |       |
|            |                     |   | Cł               | noose Highlight C                | olor for next    | Highlight co | ommand  |       |       |       |       |        |       |      |       |       |
|            |                     |   | Q Zo             | oom To: PR_ZONE                  | _2_7_KEEPO       | JT           |         |       |       |       |       |        |       |      |       |       |
|            |                     |   | Print            | Instances: PR_ZO                 | NE_2_7_KEE       | POUT         |         |       |       |       |       |        |       |      |       |       |
|            |                     |   | 🙀 Re             | move All Instanc                 | es               |              |         |       |       |       |       |        |       |      | _     |       |
|            |                     |   | × De             | elete Placement P                | Region           |              |         |       |       |       |       |        |       |      |       |       |
|            |                     |   | 🔷 🗘 Co           | onfigure Clock Pre               | e- <b>X</b> ites |              |         |       |       |       |       |        |       |      |       |       |
|            |                     |   |                  | ow/H<br>Configure                | Clock Pre-Ro     | utes         |         |       |       |       |       |        |       |      |       |       |
|            |                     |   | Reset            | All o                            | crock Pro-ric    |              |         |       |       |       |       |        |       |      |       |       |

#### Figure 309 • Configure Clock Pre-Routes Example

2. The Configure Clock Pre-Routes dialog appears.

| -             | Configure Clock Pr  | e-Routes            |
|---------------|---------------------|---------------------|
| Net Name:     | i_clk_pr_1_ipin_net | Placement Regions:  |
| Clock Tracks: | 0                   | PR_ZONE_2_7_KEEPOUT |
|               | 1                   |                     |
|               | 2                   |                     |
|               | 3                   |                     |
|               | 4                   |                     |
|               | 5                   |                     |
|               | 6                   |                     |
|               | 7<br>8              |                     |
|               | 9                   |                     |
|               | 10                  |                     |
|               | 11                  |                     |
|               | 12                  |                     |
|               | 13                  |                     |
|               | 14                  |                     |
|               | 15                  |                     |
|               |                     |                     |
|               |                     | Cancel OK           |
|               |                     |                     |

3. Ensure that the clock net is pre-routed into the same track specified in step 1d.

Figure 310 • Configure Clock Pre Routes Dialog Example

4. Click **OK**. The Tcl Console displays the following:

```
add_clock_preroute i_clk_pr_1_ipin_net { 1 } -placement_regions { PR_ZONE_2_7 }
```

- 5. Repeat steps 1 and 2 above to route the clock net for PR core 2 to the PR core 2A keep out region.
- 6. The Tcl Console displays the following:

```
add_clock_preroute i_clk_pr_2_ipin_net { 2 } -placement_regions { PR_ZONE_7_6 }
```

#### Run Place-and-Route in ACE for Top-Level Design

1. In the Flow view, right-click the Place and Route step and select Run Selected Flow Step.

10.1

|                                                                                                                                                                                                                          | - Achronix CAD Environment - Version 0.X (Main) - pr_top->impl_1 (AC7t1500ES0) |     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|-----|
| File Edit Actions Window Help                                                                                                                                                                                            |                                                                                |     |
| 🗉 🖬 🖕 🖈 🖻 🖄 🕐 😰 🖪 🗗 🗗 🖉                                                                                                                                                                                                  |                                                                                | ۹   |
| C Projects 🛛 🗌 🗌                                                                                                                                                                                                         | E Options 🛛                                                                    | 3 # |
|                                                                                                                                                                                                                          |                                                                                |     |
| A Run Hnal DRC. Checce     A Run Hnal DRC. Checce     A Run SignedT mining grandyais     Generate Final Reports     A Generate Final Simulation Netlist     PEGA Programming     A Generate Bistream     A FPGA Download |                                                                                |     |
|                                                                                                                                                                                                                          | 1295M of 1432M                                                                 |     |

Figure 311 • Run Place and Route Flow Step Example

Run Final Sign-Off Timing Analysis in ACE for Top-Level Design

- 1. Ensure that the Place and Route flow step completed successfully.
- 2. In the Flow view, right-click the Design Completion step and select Run Selected Flow Step.

|                                                                                 | ACE - Achronix CAD Environment - Version 0.X (Main) - pr_top->impl_1 (AC7t1500ES0) |     | · 🗆 |
|---------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-----|-----|
| File Edit Actions Window Help                                                   |                                                                                    |     |     |
| 😕  🗠 🖂 🗈 🗂 🕐 😕 🖪 🖗 🔳 🤅                                                          | e <sup>n</sup> 🥔 🖗 🐁 🕴 😯                                                           |     | Q   |
| C Projects 33                                                                   | Coptions 🛙 🗄 Options 🖾                                                             | - 0 | 8   |
| 🖀 😂 🗟 👔 🔡 💭 🚱 🤣 🛪                                                               | Project: pr_top                                                                    |     | •   |
| ▼ ≝ pr_top                                                                      | Implementation: impl_1                                                             |     |     |
| 🕨 🗁 Netlists                                                                    | ▶ Design Preparation                                                               |     |     |
| Constraints                                                                     | Advanced Design Preparation                                                        |     |     |
| ≥IP<br>▶∰impl_1                                                                 | > Place and Route                                                                  |     |     |
| ▶ ∰ Impi_1                                                                      | Report Generation                                                                  |     | 1   |
|                                                                                 | Timing Analysis                                                                    |     |     |
| 5a Flow 33 ► 🕩 🖷 🖇 🖤                                                            | Bitstream Generation                                                               |     |     |
|                                                                                 | FPGA Download                                                                      |     |     |
| ▼ ■ ⊕ Prepare                                                                   | r Fraz Dominau                                                                     |     |     |
| ■ ✓ Run Prepare ▲ Run Estimated Timing Analysis                                 |                                                                                    |     |     |
| A Generate Pre-Placed Simulation Netlist                                        |                                                                                    |     |     |
| ▼ ■ @ Place and Route                                                           |                                                                                    |     |     |
| ■ ✓ Run Place                                                                   |                                                                                    |     |     |
| 🗌 🛦 Run Post-Placement Timing Analysis                                          |                                                                                    |     |     |
| ■ 🖋 Run Route                                                                   |                                                                                    |     |     |
| 🗹 🛦 Run Post-Route Timing Analysis                                              |                                                                                    |     |     |
| Design Completion     Run Sel Xted Flow                                         | Stan                                                                               |     |     |
| E a Posceriocess Design                                                         |                                                                                    |     |     |
| A Run Final DRC Checks     Run Selected Flow St     A Run Sign-off Timing Analy | tep                                                                                |     |     |
| ✓ ▲ Generate Final Reports Clear Flow                                           |                                                                                    |     |     |
| A Generate Final Simulation     A Create Flow Step                              |                                                                                    |     |     |
| FPGA Programming     A Remove Flow Step                                         |                                                                                    |     |     |
| 🗹 🛦 Generate Bitstream                                                          |                                                                                    |     |     |
| 🔲 🛦 FPGA Download                                                               |                                                                                    |     |     |
|                                                                                 |                                                                                    |     |     |
|                                                                                 |                                                                                    |     |     |
|                                                                                 |                                                                                    |     |     |
|                                                                                 | 1844M of 4272M                                                                     |     |     |
| 4                                                                               |                                                                                    | _   | _   |

Figure 312 • Run Design Completion Flow Step Example

#### Generate Base Bitstream for Top-Level Design

- 1. Ensure that the Design Completion flow step completed successfully.
- 2. In the Flow view, right-click the FPGA Programming step and select Run Selected Flow Step.
- 3. Ensure that the Enable Partial Reconfiguration option is <u>NOT</u> selected in order to create a base bitstream.

|                                                                                                                 | CE - Achronix CAD Environment - Version 0.X (Main) - pr_top->impl_1 (AC7t1500ES0) | · 🗆 |
|-----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|-----|
| File Edit Actions Window Help                                                                                   |                                                                                   |     |
| 🧀 🔛 🗠 🖂 🐑 🛍 🛛 🕫 🖿 🛤 🖬 🗗                                                                                         | 🐖 🛉 🐜 🐁 🕴 🗘                                                                       | ۹   |
| C Projects 22                                                                                                   | E Deptions 32 .                                                                   | - e |
| 2 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                         | Project: pr_top                                                                   | ۵   |
| ▼ ≝ pr_top                                                                                                      | Implementation: impl_1                                                            |     |
| Netlists                                                                                                        | Design Preparation                                                                |     |
| Constraints                                                                                                     | Advanced Design Preparation                                                       |     |
| 🗁 IP                                                                                                            | Harrise Bong, Peptiden                                                            | _   |
| ▶ ∰ impl_1                                                                                                      |                                                                                   |     |
|                                                                                                                 | Report Generation                                                                 |     |
|                                                                                                                 | Timing Analysis                                                                   |     |
| 🗞 Flow 🕱 🕨 🗎 🖗 👘                                                                                                | Bitstream Generation                                                              |     |
| ▼ ■ 🚯 Prepare                                                                                                   | > FPGA Download                                                                   |     |
| ■ ✓ Run Prepare                                                                                                 |                                                                                   |     |
| A Run Estimated Timing Analysis                                                                                 |                                                                                   |     |
| 🗌 🛦 Generate Pre-Placed Simulation Netlist                                                                      |                                                                                   |     |
| 👻 🖃 😔 Place and Route                                                                                           |                                                                                   |     |
| ■                                                                                                               |                                                                                   |     |
| 📃 🛦 Run Post-Placement Timing Analysis                                                                          |                                                                                   |     |
| 🖃 🖋 Run Route                                                                                                   |                                                                                   |     |
| 🗹 🖋 Run Post-Route Timing Analysis                                                                              |                                                                                   |     |
| ▼ ■                                                                                                             |                                                                                   |     |
| ● ✓ Post-Process Design                                                                                         |                                                                                   |     |
| ■ ✓ Run Final DRC Checks ✓ V Run Sign-off Timing Analysis                                                       |                                                                                   |     |
| Generate Final Reports                                                                                          |                                                                                   |     |
| Generate Final Simulation Netlist                                                                               |                                                                                   |     |
| Generate mail simulation wetrist     Generate mail simulation wetrist                                           |                                                                                   |     |
| Generate Bitstream                                                                                              | 99                                                                                |     |
| A FPGA Download Run Selected Flow Ste                                                                           |                                                                                   |     |
| Clear Flow                                                                                                      |                                                                                   |     |
| A. Create Flow Step                                                                                             |                                                                                   |     |
| A Remove Flow Step                                                                                              |                                                                                   |     |
| ar withove How Step                                                                                             | 533M of 624M                                                                      |     |
| the second se |                                                                                   |     |

#### Figure 313 • Run FPGA Programming Flow Step Example

- 4. In the Options view, click the Bitstream Generation tab.
- 5. Scroll down to the **Partial Reconfiguration** section and ensure that the **Lock FCU After Programming** item is checked.

| FCU Configuration                 | 2U Configuration             |  |  |  |  |  |  |
|-----------------------------------|------------------------------|--|--|--|--|--|--|
| 4-bit Speedcore Instance ID (hex) | 0                            |  |  |  |  |  |  |
| Memory Scrubbing Mode             | Background Scan and Repair 🗸 |  |  |  |  |  |  |
| CRC Checking Mode                 | Fully Enabled                |  |  |  |  |  |  |
| ✓ Lock FCU After Programming      |                              |  |  |  |  |  |  |

#### Figure 314 · Lock FCU After Programming Option Example

#### Save Placement Region and Clock Pre-Routing Constraints to PDC File

1. Repeat the steps in section 1 to save the region and clock pre-routing and placement region constraints to a .pdc file.

#### Bitstream Programming Sequence

#### Apply Power to Board

1. Apply power to the board and ensure cables are properly connected.

#### Program Top-Level Design Full Bitstream

1. Run the following commands.

```
set jtag_id [jtag::get_connected_devices]
jtag::open $jtag_id
jtag::configure_scan_chain $jtag_id AC7t1500ES0 0 0 0 -single_device
jtag::ac7t1500_initialize_fcu $jtag_id -reset
jtag::ac7t1500_program_bitstream $jtag_id <ace_install_dir>/examples/
partial_reconfiguration/tutorial/AC7t1500ES0/pr_flow_2/pr_top/ace/impl_1/output/
pr_top.hex
```

#### Program PR Core 1A Partial Bitstream

1. Run the following commands.

```
#Program partial bitstream
jtag::ac7t1500_initialize_fcu $jtag_id
jtag::ac7t1500_program_bitstream $jtag_id <ace_install_dir>/examples/
partial_reconfiguration/tutorial/AC7t1500ES0/pr_flow_2/pr_core_1a/ace/impl_1/output/
pr_core_1a.hex
```

#### **Run PR Core 1A Test Scripts**

1. Run the following command.

The script contains NAP reads from PR core 1A.

```
source <ace_install_dir>/examples/partial_reconfiguration/tutorial/AC7t1500ES0/
pr_flow_2/test_scripts/read_pr_core_1a.tcl
```

#### Program PR Core 2A Partial Bitstream

1. Run the following commands.

```
#Program partial bitstream
jtag::ac7t1500_initialize_fcu $jtag_id
jtag::ac7t1500_program_bitstream $jtag_id <ace_install_dir>/examples/
partial_reconfiguration/tutorial/AC7t1500ES0/pr_flow_2/pr_core_2a/ace/impl_1/output/
pr_core_2a.hex
```

## Run PR Core 2A Test Scripts

- 1. Run the following command.
  - The script contains NAP reads from PR core 2A.

```
source <ace_install_dir>/examples/partial_reconfiguration/tutorial/AC7t1500ES0/
pr_flow_2/test_scripts/read_pr_core_2a.tcl
```

#### Program PR Core 1B Partial Bitstream

1. Run the following commands.

```
#Program partial bitstream
jtag::ac7t1500_initialize_fcu $jtag_id
jtag::ac7t1500_program_bitstream $jtag_id <ace_install_dir>/examples/
partial_reconfiguration/tutorial/AC7t1500ES0/pr_flow_2/pr_core_1b/ace/impl_1/output/
pr_core_1b.hex
```

#### Run PR Core 1B Test Scripts

1. Run the following command.

The script contains NAP reads from PR core 1B.

```
source <ace_install_dir>/examples/partial_reconfiguration/tutorial/AC7t1500ES0/
pr_flow_2/test_scripts/read_pr_core_1b.tcl
```

#### Program PR Core 2B Partial Bitstream

1. Run the following commands.

```
#Program partial bitstream
jtag::ac7t1500_initialize_fcu $jtag_id
jtag::ac7t1500_program_bitstream $jtag_id <ace_install_dir>/examples/
partial_reconfiguration/tutorial/AC7t1500ES0/pr_flow_2/pr_core_2a/ace/impl_1/output/
pr_core_2b.hex
```

#### Run PR Core 2B Test Scripts

1. Run the following command.

The script contains NAP reads from PR core 2B.

```
source <ace_install_dir>/examples/partial_reconfiguration/tutorial/AC7t1500ES0/
pr_flow_2/test_scripts/read_pr_core_2b.tcl
```

# Updating ROM, BRAM, or LRAM Memory Initialization Contents in the Bitstream

**QUESTION:** Once we've synthesized a design with ROMs and run through ACE P&R, is there a way to generate a new bitstream with updated contents for the ROMs without having to go through resynthesize or ACE P&R again?

**ANSWER:** Yes. There are 2 ways, depending on the method you used to initialize the ROM memory contents.

## Initialized using a mem\_init file

If you used a mem\_init\_file, then:

- 1. Launch ACE.
- 2. Load your ACE project (restore\_project).
- 3. Load your post-route ACXDB database (restore\_impl). In the GUI, this can be done using the 'Restore Implementation' action.
  - a. Select the <design>\_routed.acxdb file. This will load the design and all the place and route information.

| Restore Implementation                                                                              |       | ×    |
|-----------------------------------------------------------------------------------------------------|-------|------|
| Restore Implementation: MyProject->impl_1                                                           |       |      |
| The state of the database for the Active Implementation may be restored from an Acxdb Archive File. |       |      |
| Acxdb file                                                                                          |       |      |
| C:/code/projects/MyProject/impl_1/pnr/quickstart_routed.acxdb                                       | ▼ Bro | owse |
|                                                                                                     |       |      |
|                                                                                                     |       |      |
|                                                                                                     | <br>  |      |
| ⑦ Einish                                                                                            | Cano  | cel  |
|                                                                                                     |       |      |

You will see the green checkboxes on the Run Prepare, Run Place, and Run Route flow steps in the Flow View in the GUI.



- 4. Now, you can keep your ACE session open and update the mem\_init\_file contents on disk as many times as you want, and generate new bitstreams using the 2 steps below:
  - a. Update the mem\_init\_file and save to disk.
  - b. Double-click the 'Generate Bitstream' flow step in the Flow View (or call "run -step write\_bitstream) to generate the new bitstream with only the ROM contents updated.



## Initialized using initd\* parameters

If you used the initd\* parameters on the BRAM/LRAM instance, then:

- 1. Launch ACE.
- 2. Load your ACE project (restore\_project).
- 3. Load your post-route ACXDB database (restore\_impl).

In the GUI, this can be done using the 'Restore Implementation' action. Select the <design>\_routed.acxdb file. This will load the design and all the place and route information.

| Restore Implementation                                                                              | — |        | ×   |
|-----------------------------------------------------------------------------------------------------|---|--------|-----|
| Restore Implementation: MyProject->impl_1                                                           |   |        |     |
| The state of the database for the Active Implementation may be restored from an Acxdb Archive File. |   |        |     |
| Acxdb file<br>C:/code/projects/MyProject/impl_1/pnr/quickstart_routed.acxdb                         |   | ▼ Brov | wse |
| 7 <u><u>Finish</u></u>                                                                              |   | Cance  | el  |

You will see the green checkboxes on the Run Prepare, Run Place, and Run Route flow steps in the Flow View in the GUI.



- 4. Now, you can keep your ACE session open and use ECO commands to update the initd\* parameters as many times as you want, and generate new bitstreams using the 2 steps below:
  - a. Use the set\_property command to override the initd\* parameters on the BRAM/LRAM instance.

Example: set\_property {initd\_12} {72'hABCD1234ABCD12345} {i:design.hierarchy.path.to<sup>1</sup>.ram.instance}.

In the GUI, you can also go to the menu **Window | Preferences**, and go to **User Advanced Preferences**, and check the box to 'Enable ECO Functionality'.

<sup>1</sup> http://design.hierarchy.path.to

| Preferences                                                                                                                                                                                                                                                                                                                                        | — D X                                                                               |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|
| type filter text                                                                                                                                                                                                                                                                                                                                   | User Advanced Preferences $ ightarrow  ightarrow  ightarrow  ightarrow$             |
| Configure DCC Connection<br>Configure JTAG Connection<br>Critical Path Diagram View<br>Floorplanner View Colors and Layers<br>Floorplanner View Optimizations<br>General<br>Help<br>I/O Designer<br>Multiprocess<br>Netlist Browser<br>NoC Performance<br>Placement Regions<br>Project Management<br>Tcl Console View<br>User Advanced Preferences | <ul> <li>Enable ECO Functionality</li> <li>Display Advanced Impl Options</li> </ul> |
|                                                                                                                                                                                                                                                                                                                                                    | Restore <u>D</u> efaults <u>A</u> pply                                              |
|                                                                                                                                                                                                                                                                                                                                                    | Apply and Close Cancel                                                              |

Right-click on the ROM instance in the Floorplanner, Search, Selection, or Netlist Browser views, and select 'Display Properties'. This updates the contents of the Properties view. You can now edit the initd\* parameters on the Parameters tab of the wizard.

| Properties              | 5 X                                              |                                          |  | 000 | Ē |
|-------------------------|--------------------------------------------------|------------------------------------------|--|-----|---|
| Instance: rd_data_2_0_0 |                                                  |                                          |  |     |   |
| Туре                    | Name                                             | Value                                    |  |     |   |
| Parameter               | acx_memtest                                      | 1'b0                                     |  |     |   |
| Parameter               | byte_width                                       | 9                                        |  |     |   |
| Parameter               | cfgbram_assist                                   | 6'h5                                     |  |     |   |
| Parameter               | cfgbram_clkpwma                                  | 3'h0                                     |  |     |   |
| Parameter               | cfgbram_clkpwmb                                  | 3'h0                                     |  |     |   |
| Parameter               | cfgbram_clock_pulse_widtha_first                 | 15'h0007                                 |  |     |   |
| Parameter               | cfgbram_clock_pulse_widtha_second                | 15'h0007                                 |  |     |   |
| Parameter               | cfgbram_clock_pulse_widthb_first                 | 15'h0007                                 |  |     |   |
| Parameter               | meter cfgbram_clock_pulse_widthb_second 15'h0007 |                                          |  |     |   |
| Parameter               | cfgbram_rda                                      | 3'h2                                     |  |     |   |
| Parameter               | ecc_decoder_enable                               | 0                                        |  |     |   |
| Parameter               | ecc_encoder_enable                               | 0                                        |  |     |   |
| Parameter               | initd_0                                          | 72'h00000000000000000000                 |  |     |   |
| Parameter               | initd_1                                          | 72'h000000000000000000000000000000000000 |  |     |   |
| Parameter               | initd_2                                          | 72'h000000000000000000000000000000000000 |  |     |   |
| Parameter               | initd_3                                          | 72'h000000000000000000000000000000000000 |  |     |   |
| Parameter               | initd_4                                          | 72'h000000000000000000000000000000000000 |  |     |   |
| Parameter               | initd_5                                          | 72'h000000000000000000000000000000000000 |  |     |   |
| Parameter               | initd_6                                          | 72'h000000000000000000000000000000000000 |  |     |   |
| Parameter               | initd_7                                          | 72'h000000000000000000000000000000000000 |  |     |   |
| Parameter               | initd_8                                          | 72'h000000000000000000000000000000000000 |  |     |   |
| Parameter               | initd_9                                          | 72'h000000000000000000000000000000000000 |  |     |   |
| Parameter<br>General Pa | initd 10<br>rameters Pins                        | 72'h000000000000000000000000000000000000 |  |     |   |

b. Double-click the Generate Bitstream flow step in the Flow View (or call "run -step write\_bitstream) to generate the new bitstream with only the ROM contents updated



## Plugging in Custom IP Generator Tools

The IP Generator Plugin Framework is a powerful feature that facilitates the development of IP generation tools within the ACE GUI. It provides a structured approach to define the specifications for IP properties, GUI controls, and callbacks. These callbacks are designed for property updates, checks, and output file generation, all implemented in Tcl.

This framework is especially beneficial for Speedcore eFPGA customers who aim to offer custom IP or ASIC configuration tools to their end users. A key benefit of this framework is the complete integration of these tools into ACE, including its GUI, providing a consistent and intuitive user experience.

This section of the document provides a comprehensive overview of the features, usage, and setup process for the IP Generator Plugin Framework.

- File Location and Directory Organization (page 553)
- IP Generator Plugin Development (page 554)



Figure 315 • Custom IP Generator Tool Showcasing the Different Features Supported by the IP Generator Plugin Framework

## File Location and Directory Organization

## Loading User-defined Directory Paths Using Environment Variables

IP Generator Plugin definitions can also be loaded by specifying base directory paths using environment variables. The user-defined search paths are defined in ACE\_IPGEN\_PLUGIN\_PATH environment variable. Multiple base directories are separated by by a semi-colon (;).

For each base directory, the file <base\_dir>/src/gui/ip\_plugin.tcl will be sourced.

For example, for following file paths:

- /home/\$USER/my\_ip\_1/src/gui/ip\_plugin.tcl
- /home/\$USER/my\_ip\_2/src/gui/ip\_plugin.tcl

#### Loading user-defined directory paths using environment variable

export ACE\_IPGEN\_PLUGIN\_PATH=/home/\$USER/my\_ip\_1;/home/\$USER/my\_ip\_2

#### Notes

As a reference, an example script is provided as part of the ACE installation located under <ACE installation directory>/examples/ip\_generator\_plugin/TEST\_IP\_1/src/gui/ ip\_plugin.tcl

To view this example IP in ACE, ensure that ACE\_IPGEN\_PLUGIN\_PATH is set to <ACE installation directory>/examples/ip\_generator\_plugin/TEST\_IP\_1

#### A Caution!

The current version of ACE expects the ip\_plugin.tcl file to be located inside src/gui directory under the base directory. All IP Generator Plugin definitions should, therefore, use the following file path structure: <br/>
<br/>
structure: <br/>
<br/>
base\_dir>/src/gui/ip\_plugin.tcl

## IP Generator Plugin Development

This section is dedicated to explaining how to define an IP using the IP Generator Plugin Framework. This framework is designed to facilitate the development of custom IP using Tcl. It provides a comprehensive set of supporting Tcl commands, making the process of IP development more streamlined and efficient. For detailed information on these Tcl commands, please refer to the section, Tcl Commands for IP Generator Plugin Framework (page 723).

The framework adheres to the model-view-controller (MVC) architecture, which is crucial to understand when defining an IP:

- **Model –** The model is defined by the IP creation and property definitions. These elements form the backbone of the IP and dictate its fundamental characteristics.
- View The vew is defined by the IP GUI layout definition, which determines how the IP will be presented in the GUI.
- **Controller –** The controller is represented by the callback functions. These functions manage the interactions between the model and the view, ensuring they work together seamlessly.

Each IP must be defined in a file named ip\_plugin.tcl. It is important to adhere to the MVC order when defining the IP in this file to ensure that the IP is structured correctly and can function as intended within the framework.

This section covers the process of developing an IP using the IP Generator Plugin Framework, ensuring that its features and capabilities can be effectively leverage .

#### (i) Note

As a reference, this section uses the example script under <ACE installation directory>/ examples/ip\_generator\_plugin/TEST\_IP\_1/src/gui/ip\_plugin.tcl

#### **Model Definition**

The first step in IP Generator Plugin Development is the model definition. This phase involves the use of the framework's supporting Tcl commands to create the IP. It sets the foundation for the IP by defining its properties for IP configuration and output file generation. The Model Definition includes the following:

#### **IP Creation**

First phase is creating a new IP definition.

1. Create the top-level IP generator tool definition using ace\_ip::create\_ip command.

```
Command to create a new IP Generator Tool
```

ace\_ip::create\_ip "TEST IP 1" "Speedster7t" "1.0"

#### (i) Note

Each IP name *must* be unique. Therefore, invoking this command again will erase the current definition of the IP generator tool. This behavior allows a user to 'source' this Tcl script repeatedly in an ACE session while working on the IP generator tool.

2. Set the IP category as follows:

```
Command to set IP Category
```

```
ace_ip::set_ip_category { "Core" "Test IP" "TEST IP 1" }
```

This command sets where the IP appears in the IP Libraries View tree structure, and possibly in documentation structure.



Figure 316 • The IP Library View in ACE Containing the IP Category for TEST IP 1

#### (i) Note

The IP Libraries View can only be updated once when ACE loads the IP definition at ACE start up. Any chnage to the IP category will not be reflected until this Tcl script is sourced agaon in the ACE session.

3. Provide a top-level description for the IP. This will show up in tool-tip in IP Libraries View, and as overview text in the documentation.

| Command to set top-level description for the IP                                                |       |  |
|------------------------------------------------------------------------------------------------|-------|--|
| ace_ip::set_ip_description "This page contain<br>govern the structure and base configuration o |       |  |
| ➡ IP Libraries ×                                                                               | ø - c |  |
| ▼ ➡ Speedster7t (AC7t1500)                                                                     |       |  |
| ✓ ➡ Core                                                                                       |       |  |
| 🕨 🛋 Device Management                                                                          |       |  |
| 🕨 🛋 Logic                                                                                      |       |  |
| ▶ 📸 MLPs                                                                                       |       |  |
| Memories                                                                                       |       |  |
| ▶ 🛋 Misc                                                                                       |       |  |
| NAP and AXI                                                                                    |       |  |
| 🕶 📑 Test IP                                                                                    |       |  |
| TEST IP 1 .                                                                                    |       |  |

Figure 317 • The IP Library View in ACE displaying the tool-tip description for TEST IP 1

and base configuration of the Test Soft IP wrapper.

This page contains the top-level, global properties that govern the structure

4. Define resource types needed by this IP as follows:

▶ 🛋 IO Ring



The resource types determine which devices support this IP. ACE looks at the primitive resource types supported by a given device to determine if that device can support this IP. It is important to specify at least one resource type. The following table shows the supported resource types:

| #  | Resource Type Value |
|----|---------------------|
| 1  | AESX_GCM_K          |
| 2  | ALU4                |
| 3  | ALU8                |
| 4  | BRAM                |
| 5  | BRAM72K             |
| 6  | DEVICE_MGR          |
| 7  | DFF                 |
| 8  | DSP64               |
| 9  | LRAM                |
| 10 | LRAM2K              |
| 11 | LUT4                |
| 12 | LUT6                |
| 13 | LUTRAM              |
| 14 | MLP                 |
| 15 | MUX4                |
| 16 | MUX8                |
| 17 | NAP_I               |
| 18 | NAP_HS              |
| 19 | NAP_R               |
| 20 | NAP_VS              |
| 21 | WIDTH_ADAPTER       |

#### 5. Table 150 • Valid Values for IP Resource Types

#### (i) Note

The resource types are library and device-specific. Therefore, an IP definition may not be available if the device does not support it.

#### **IP Property Definitions**

The IP property definitions phase is a critical step in the IP Generator Plugin Development process. During this phase, the various properties that characterize the IP are defined. Utilizing the framework's Tcl commands, a wide range of property types, basic validation rules and default values can be specified, ensuring that the IP is both robust and flexible. Configurable properties allow users to tailor the IP to their specific needs, while read-only properties, known as labels, provide essential fixed information.

Users also have the option to create an IP without defining any properties if configurability is not required. This section covers the steps necessary to accurately and effectively define these properties, laying a solid foundation for an IP's configuration and functionality.

#### IP Property Definitions for Configuring the IP

The following code blocks show the different types of properties that are supported by the framework for IP configuration. For detailed information on these Tcl commands, refer to Tcl Commands for IP Generator Plugin Framework (page 723).

#### **Enum IP Property Definitions**

```
ace_ip::add_ip_enum_property "enumParam1" "Enum Param 1" "256" {"32" "64" "128" "256"}
-description "Enum Param 1 description." -enabled "true"
ace_ip::set_ip_property_verilog_param_attributes "enumParam1" -verilog_param "false"
ace_ip::add_ip_enum_property "enumParam2" "Enum Param 2" "X" {"X" "1" "2" "3" "4" "5"
"6" "7" "8"} -description "Enum Param 2 description." -enabled "true"
ace_ip::set_ip_property_verilog_param_attributes "enumParam2" -verilog_param "true"
-format "sized_hex" -to_upper "false" -num_bits 4
ace_ip::add_ip_enum_property "enumParam3" "Enum Param 3" "X" {"X" "ONE" "TWO" "THREE"
"FOUR" "FIVE" "SIX" "SEVEN" "EIGHT" "NINE" "TEN"} -description "Enum Param 3
description." -enabled "true"
# No mapping for "X" so it will pass the label.
ace_ip::set_ip_property_verilog_param_attributes "enumParam3" -verilog_param "true"
-format "sized_hex" -to_upper "false" -num_bits 4 -enum_map {{"ONE" "1"} {"TWO" "2"} {"
THREE" "3"} {"FOUR" "4"} {"FIVE" "5"} {"SIX" "6"} {"SEVEN" "7"} {"EIGHT" "8"} {"NINE"
"9"} {"TEN" "10"}}
ace_ip::add_ip_enum_property "enumParam4" "Enum Param 4" "1/2" {"0" "1/2" "1/3" "1/4"
"1/5" "1/6" "1/7" "1/8" "1/9" "1/10" "1" "CUSTOM"} -description "Enum Param 4
description." -enabled "true"
ace_ip::set_ip_property_verilog_param_attributes "enumParam4" -verilog_param "true"
-format "quoted_string" -to_upper "false"
```

```
ace_ip::add_ip_enum_property "enumParam5" "Enum Param 5" "1/2" {"0" "1/2" "1/3" "1/4"
"1/5" "1/6" "1/7" "1/8" "1/9" "1/10" "1" "CUSTOM"} -description "Enum Param 5
description." -enabled "true"
ace_ip::set_ip_property_verilog_param_attributes "enumParam5" -verilog_param "true"
    -format "quoted_string" -to_upper "false"
```

#### **Binary IP Property Definitions**

#### **Hexadecimal IP Property Definitions**

```
ace_ip::add_ip_hex_property "hexParam1" "Hex Param 1" "155555555" 32 -min "000000000" -max
"FFFFFFF" -description "Hex Param 1 description." -enabled "false"
ace_ip::set_ip_property_verilog_param_attributes "hexParam1" -verilog_param "false"
-to_upper "false" -num_bits 32
```

#### **String IP Property Definitions**

```
ace_ip::add_ip_string_property "stringParam1" "String Param 1" "my Default"
    -min_characters "2" -max_characters "32" -valid_characters_regex "\[a-zA-Z0-9\]\.\*"
    -description "string param 1 description" -enabled "true"
    ace_ip::set_ip_property_verilog_param_attributes "stringParam1" -verilog_param "true"
    -to_upper "true"
```

#### **Integer IP Property Definitions**

```
ace_ip::add_ip_int_property "intParam1" "Integer Param 1" "3" -min "2" -max "32"
    -description "Integer param 1 description" -enabled "true"
    ace_ip::set_ip_property_verilog_param_attributes "intParam1" -verilog_param "true"
    -to_upper "true" -num_bits 5
```

```
ace_ip::add_ip_int_property "intParam2" "Integer Param 2" "0" -min "0" -max "16"
  -description "Integer param 2 description" -enabled "true"
```

```
UG070
```

```
ace_ip::set_ip_property_verilog_param_attributes "intParam2" -verilog_param "true"
    -to_upper "true" -num_bits 4
```

#### **Float IP Property Definitions**

```
ace_ip::add_ip_float_property "floatParam1" "Float Param 1" "3.1" -min "2.7" -max "32.4"
  -description "Float param description" -enabled "true"
ace_ip::set_ip_property_verilog_param_attributes "floatParam1" -verilog_param "true"
  -to_upper "true" -num_bits 6
```

#### **Boolean IP Property Definitions**

```
ace_ip::add_ip_bool_property "boolParam1" "Bool Param 1" "Yes" -description "Bool param
1 description" -enabled "true"
ace_ip::set_ip_property_verilog_param_attributes "boolParam1" -verilog_param "true"
-to_upper "true" -num_bits 1
ace_ip::add_ip_bool_property "boolParam2" "Bool Param 2" "Yes" -description "Bool param
2 description" -enabled "true"
ace_ip::set_ip_property_verilog_param_attributes "boolParam2" -verilog_param "true"
-to_upper "true" -num_bits 1
```

#### File Path IP Property Definitions

```
ace_ip::add_ip_file_path_property "filepathParam1" "Filepath Param 1" "" -description
"Filepath Param 1 description" -enabled "true" -file_must_exist "false" -is_directory
"false" -allow_blank_file "true"
ace_ip::add_ip_file_path_property "filepathParam2" "Filepath Param 2" "" -description
"Filepath Param 2 description" -enabled "true" -file_must_exist "false" -is_directory
"false" -allow_blank_file "true"
```

#### Signal Name IP Property Definitions

ace\_ip::add\_ip\_signal\_name\_property "signalNameParam1" "Signal Name Param 1"
"SignalName1" -description "Signal Name Param 1 description" -enabled "false"

#### **IP Label Definition**

```
ace_ip::add_ip_label "label1" "Ip Label 1" "my label" -description "Ip Label 1
description" -enabled "false"
```

#### Notes

- As part of the IP property definition, if Verilog/SystemVerilog file generation is desired, specify additional Verilog parameter attributes that will eventually appear in the generated output file.
- The ACE IP configuration file (or the ACXIP file) contains all the IP properties that are part of the IP property definitions.
- An IP label is a special property that does not show up in the ACE IP configuration file. However, it can be used to store read-only calculated values which can be displayed in the GUI.

#### **IP Property Definitions for IP Output File Generators**

Output file generator properties are special properties that are created automatically by the framework when an IP output file generator is defined. The following code block shows how to define an output file generator. For detailed information on these Tcl commands, please refer to Tcl Commands for IP Generator Plugin Framework (page 723).

#### Output file generator definitions

```
# This command adds two properties i.e. output file enable property:
"output.verilog_file_en" and output file path property: "output.verilog_file" to
property definitions automatically
ace_ip::add_ip_output_file "Verilog Model" "ace_ip::builtin_generate_ip_verilog_file"
"output.verilog_file_en" "output.verilog_file" "RTL Files" "Description text here..."
-enabled "true" -file_ext "*.v"
```

```
ace_ip::add_ip_output_file "VHDL Model" "ace_ip::builtin_generate_ip_vhdl_file"
"output.vhdl_f_en" "output.vhdl_f" "RTL Files" "Description text here..." -enabled
"false" -file_ext "*.vhd"
```

#### (i) Note

To be consistent with ACE IP definitions, it is recommended that the ACE naming convention be followed when defining output file properties. For example, output file enable property: "output.verilog\_file\_en" and output file path property: "output.verilog\_file". Here, ensure to use "output.<file\_type\_name>\_en" for output file enable property and "output.<file\_type\_name>" for output file property.

#### **Optional Setup for Built-in Output File Generator Functions**

#### Setup for built-in Verilog / SystemVerilog generator functions

# This is optional, and is used by any built-in output file generator TCL procs ace\_ip::set\_ip\_macro\_name "ACX\_EXAMPLE\_SOFT\_IP"

# This is optional, and is used by any built-in output file generator Tcl procs ace\_ip::add\_ip\_include\_path "speedster7t/macros/ACX\_EXAMPLE\_SOFT\_IP/src/rtl/ ACX\_EXAMPLE\_SOFT\_IP.sv" ace\_ip::add\_ip\_include\_path "speedster7t/macros/ACX\_EXAMPLE\_SOFT\_IP/src/include/ example\_include\_file.svh"

#### **View Definition**

The next step in IP Generator Plugin Development is the **View Definition**. This phase utilizes the framework's supporting Tcl commands to assign a view to the IP properties and labels. During this phase, the GUI page structure is defined as well as GUI controls and groups are assigned to the previously defined IP properties. These pages serve as editors, allowing end-users to configure the user-settable IP properties through the ACE GUI. For detailed information on the Tcl commands used, please refer to Tcl Commands for IP Generator Plugin Framework (page 723).

1. Define the page structure and hierarchy as follows:

#### IP GUI Page Structure and Hierarchy Definition

```
ace_ip::add_ip_gui_page "Overview" "" "Long description text for overview page
banner"
ace_ip::add_ip_gui_page "Sub-Page A" "Overview" "Long description text for page A
banner"
ace_ip::add_ip_gui_page "Sub-Page B" "Overview" "Long description text for page B
banner"
ace_ip::add_ip_gui_page "Sub-Page C" "Sub-Page B" "Long description text for page C
banner"
```

#### A Caution!

For the current release, the root page should always be named "Overview" to ensure that the framework works as expected.

This is how the page outline appears in ACE GUI, for the above code snippet:

| Be Outline ☎   |  |
|----------------|--|
| ✓ ✓ Overview   |  |
| ✓ Sub-Page A   |  |
| ▼ 🖋 Sub-Page B |  |
| ✓ Sub-Page C   |  |
|                |  |
|                |  |

Figure 318 • Page Outline in GUI

2. Create controls for any IP property to be displayed on the IP's GUI page. Optionally, create groups to group the IP property controls. As part of this group and control creation, assign appropriate GUI pages to them.

## Table 151 • Recommended GUI Controls to Use for Different IP Property Types for Better User Experience

| IP Property Type | Recommended GUI controls                                                             |
|------------------|--------------------------------------------------------------------------------------|
| enum             | combo                                                                                |
| integer          | combo (preferred when the range between min and max values is<br>less than 20), text |
| float            | text                                                                                 |
| boolean          | checkbox                                                                             |
| hexadecimal      | text                                                                                 |
| binary           | text                                                                                 |
| signal name      | text                                                                                 |
| filepath         | file                                                                                 |
| label            | text                                                                                 |

#### IP GUI Page Layout Definition

# Overview page:

```
# add_ip_gui_control <property_name> <page> [-parent <parent>] [-control_type
<type>] [-span <column_span>] [-ip_name <ip_name>]
ace_ip::add_ip_gui_control "enumParam1" "Overview" -control_type "combo"
ace_ip::add_ip_gui_control "floatParam1" "Overview" -control_type "text"
ace_ip::add_ip_gui_control "signalNameParam1" "Overview" -control_type "text"
# add_ip_gui_group <name> <label> <page> [-parent <parent_group>] [-columns
<layout_columns>] [-span <column_span>] [-ip_name <ip_name>]
ace_ip::add_ip_gui_group "int_group" "Int Group" "Overview" -columns 3 -span 3
ace_ip::add_ip_gui_control "intParam1" "Overview" -control_type "text" -parent
"int_group"
ace_ip::add_ip_gui_control "intParam2" "Overview" -control_type "combo" -parent
"int_group"
ace_ip::add_ip_gui_control "label1" "Overview" -control_type "text" -parent
"int_group"
ace_ip::add_ip_gui_group "filepath_group" "Filepath Group" "Overview" -columns 3
-span 3
ace_ip::add_ip_gui_control "filepathParam1" "Overview" -control_type "file" -parent
"filepath_group"
ace_ip::add_ip_gui_control "filepathParam2" "Overview" -control_type "file" -parent
"filepath_group"
# Sub-Page A:
ace_ip::add_ip_gui_control "enumParam2" "Sub-Page A" -control_type "combo"
ace_ip::add_ip_gui_group "group_1" "Group 1" "Sub-Page A" -columns 3 -span 3
ace_ip::add_ip_gui_control "enumParam4" "Sub-Page A" -control_type "combo" -parent
"group_1"
ace_ip::add_ip_gui_control "binaryParam1" "Sub-Page A" -control_type "text" -parent
"group_1"
# Sub-Page B:
ace_ip::add_ip_gui_control "enumParam3" "Sub-Page B" -control_type "combo"
ace_ip::add_ip_gui_group "group_1" "Group 1" "Sub-Page B" -columns 3 -span 3
ace_ip::add_ip_gui_control "enumParam5" "Sub-Page B" -control_type "text" -parent
"group_1"
ace_ip::add_ip_gui_control "hexParam1" "Sub-Page B" -control_type "text" -parent
"group_1"
# Sub-Page C:
ace_ip::add_ip_gui_group "bool_group" "Bool Group" "Sub-Page C" -columns 3 -span 3
ace_ip::add_ip_gui_control "boolParam1" "Sub-Page C" -control_type "checkbox"
-parent "bool_group"
ace_ip::add_ip_gui_control "boolParam2" "Sub-Page C" -control_type "checkbox"
-parent "bool_group"
```

The above code snippet generates the following page layout in ACE for the Overview page:

| 🏽 test_ip_1_1.acxip 🛛                                |                  |                          |
|------------------------------------------------------|------------------|--------------------------|
| Speedster7t<br>Overview<br>Long description text for |                  |                          |
| ✓ Target Device                                      | AC7t1500ES0      | <b>•</b>                 |
| 🖋 Enum Param 1                                       | 256              | •                        |
| 🖋 🛛 Float Param 1                                    | 3.100000         |                          |
| 🖌 Signal Name Parar                                  | n 1 SignalName1  |                          |
| Int Group                                            |                  |                          |
| 🖋 Integer Param 1                                    | 3                |                          |
| 🖋 Integer Param 2                                    | 0                | <b>•</b>                 |
| Ip Label 1 n                                         | ny label         |                          |
| Filepath Group                                       |                  |                          |
| 🖌 Filepath Param 1                                   |                  | Browse                   |
| 🖋 🛛 Filepath Param 2                                 |                  | Browse                   |
| ?                                                    | Ø <sub>0</sub> ( | Generate << Back Next >> |

Figure 319 • Overview Page in ACE

## **Control Definition**

This phase utilizes uses Tcl callbacks and the framework's supporting Tcl commands for instance-level updates to properties based on conditions, add custom checks, define ports and also generate output files. For detailed information on the Tcl commands used, please refer to Tcl Commands for IP Generator Plugin Framework (page 723).

#### 👍 Caution!

Each IP must use unique callback names for procedures that are defined inside its ip\_plugin.tcl file. Since the IP name is unique per IP definition, it is, therefore, a good practice to prefix its Tcl procedures with the IP name.

#### Update Callback

Each IP definition must contain one update callback function to define instance-level property updates, add custom checks and define ports. Properties can be enabled/disabled but cannot be added/removed at the instance-level dynamically.

#### A Caution!

- Every IP project (ACXIP file) created by user in ACE is an instance-level IP which has a unique ACXIP file path.
- Properties that are added/removed inside update callback are dynamic properties. GUI support for dynamic properties is not yet added to the current release of ACE.

Update callback can be used to perform the following actions:

1. Add custom rule checks

```
Rule check example in Update Callback
```

```
if {[ace_ip::get_ip_property_value "intParam1"] <= [ace_ip::get_ip_property_value
"intParam2"]} {
    ace_ip::add_ip_rule_message "intParam1" "Rule check example" "Error" "Integer
Param 1 must be greater than Integer Param 2. Please fix this."
}
```

2. Update property attributes

```
Example for Enabling/Disabling IP properties based on other property value in Update Callback
```

```
set binaryParam1 "0001010101010101010101010101010101"
set enumParam4 [ace_ip::get_ip_property_value "enumParam4"]
   switch $enumParam4 {
      "0" {
         }
      "1/2" {
         }
      "1/3" {
         set binaryParam1 "00001001001001001001001001001"
      }
      "1/4" {
         set binaryParam1 "01000000100010001000100010001"
      }
      "1/5" {
         set binaryParam1 "000000100001000010000100001"
      }
      "1/6" {
         set binaryParam1 "00000001000001000001000001"
      }
      "1/7" {
```

```
}
    "1/8" {
      }
    "1/9" {
      }
    "1/10" {
      }
    "1" {
      }
    default {
      }
  }
ace_ip::set_ip_property_value "binaryParam1" $binaryParam1
if { [ace_ip::get_ip_property_value "enumParam4"] == "CUSTOM" } {
 ace_ip::update_ip_binary_property "binaryParam1" -enabled "true"
} else {
 ace_ip::update_ip_binary_property "binaryParam1" -enabled "false"
}
```

Example for Updating IP property valid values based on other property value in Update Callback

```
set enumParam1 [ace_ip::get_ip_property_value "enumParam1"]
if {$enumParam1 <= 64} {
    ace_ip::update_ip_enum_property "enumParam2" -items {"X" "1" "2" "3" "4"}
    ace_ip::update_ip_enum_property "enumParam3" -items {"X" "1" "2" "3" "4"}
} else {
    # do not forget the else conditions for updates as the GUI does not reset
    automatically when conditions are not met
    ace_ip::update_ip_enum_property "enumParam2" -items {"X" "1" "2" "3" "4" "5" "6"
    "7" "8"}
    ace_ip::update_ip_enum_property "enumParam3" -items {"X" "1" "2" "3" "4" "5" "6"
    "7" "8" "9" "10"}
}</pre>
```

3. Update calculated value for IP labels

Example for Updating IP labels based on other property value in Update Callback

set label1 [expr {\$enumParam1 \* [ace\_ip::get\_ip\_property\_value "intParam1"] / 64}]

```
ace_ip::update_ip_label "label1" -value $label1
```

4. Define ports for generated Verilog/VHDL and interactive diagram

Example for adding IP ports and updating their widths based on other property values in Update Callback

```
ace_ip::add_ip_port "ref_clk" "Clocks and Resets" "in" 1 "West" "ref_clk description
Text for tooltip and documentation..."
ace_ip::add_ip_port "rstn" "Clocks and Resets" "in" 1 "West" "rstn description Text
for tooltip and documentation..."
ace_ip::add_ip_port "data_in" "Data Interface" "in" 32 "West" "data_in description
Text for tooltip and documentation..."
ace ip::add ip port "data out" "Data Interface" "out" 32 "West" "data out
description Text for tooltip and documentation..."
set w O
if {[ace_ip::get_ip_property_value "boolParam1"] == "No"} {
   set w [expr {$enumParam1 / 32}]
}
if {$w > 0} {
   ace_ip::add_ip_port "port_a" "Bidi Interface" "inout" $w "East" "port_a
description Text for tooltip and documentation..."
   ace_ip::add_ip_port "port_b" "Bidi Interface" "inout" $w "East" "port_b
description Text for tooltip and documentation..."
}
```

#### **Output File Generation Callback**

The output file generation callback can be used to add callback functions for output file generation. Each of the output files generator must contain Tcl procedure that is used as a callback to generate output file. There are three arguments to this callback which ACE passes internally when running them during output file generation:

- output\_file\_path Path to the output file which is specified by user during generation.
- acxip\_file\_path Path to ACXIP file. This can be passed to the output file handler to be printed in the generated output file.
- output\_file Output file handler. All data passed to this handler is passed to the generated output file whose path is the output\_file\_path.

No properties can be added or updated in these callbacks. Output file generators can be grouped using an output file group.

The following wizard is generated for the output file generators that are defined for our test IP example. The filenames are set by default and the path is relative to the ACXIP file path.

| Speedster7t TEST IP 1 Output File Generation         The following output files can be generated for the         Speedster7t TEST IP 1         Constraints         ✓       PDC Constraints         ✓       /test_ip_1_l.pdc         Ø       SDC Constraints         ✓       /test_ip_1_l.sdc         Documentation       Ø         ✓       /test_ip_1_l.txt         Brows       /test_ip_1_l.txt         Example Testbench       Ø         ✓       /test_ip_1_l.sv         RTL Files       Ø         ✓       /test_ip_1_l.vhd         Ø       Verilog Model         ✓       /test_ip_1_l.v | □× |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| Speedster7t TEST IP 1   Constraints   ✓   PDC Constraints   ✓   SDC Constraints   ✓   SDC Constraints   ✓   /test_ip_1_1.sdc   Brows   Documentation   ✓   User Guide Markup   ✓   /test_ip_1_1.txt   Brows   Example Testbench   ✓   ✓   Testbench SystemVerilog   ✓   /test_ip_1_1.sv   RTL Files   ✓   ✓   VHDL Model   ✓   ✓   Verilog Model   ✓   ✓   Verilog Model   ✓   ✓   /test_ip_1_1.v                                                                                                                                                                                          |    |
| ✓       PDC Constraints         ✓       ./test_ip_1_1.pdc         ✓       SDC Constraints         ✓       ./test_ip_1_1.sdc         Documentation          ✓       User Guide Markup         ✓       ./test_ip_1_1.txt         Brows          ✓       ./test_ip_1_1.txt         Example Testbench          ✓       ./test_ip_1_1.sv         RTL Files          ✓       ./test_ip_1_1.vd         Ørows       ./test_ip_1_1.v                                                                                                                                                                |    |
| ✓       ./test_ip_1_1.pdc       Brows         ✓       SDC Constraints       Brows         ✓       ./test_ip_1_1.sdc       Brows         Documentation       ✓       User Guide Markup         ✓       ./test_ip_1_1.txt       Brows         Example Testbench       ✓       ./test_ip_1_1.sv         ✓       ./test_ip_1_1.sv       Brows         RTL Files       ✓       ./test_ip_1_1.vhd         ✓       ./test_ip_1_1.vhd       Brows         ✓       VHDL Model       ✓         ✓       ./test_ip_1_1.vhd       Brows                                                                 |    |
| ✓       SDC Constraints         ✓       ./test_ip_1_1.sdc         Documentation         ✓       User Guide Markup         ✓       ./test_ip_1_1.txt         Brows         Example Testbench         ✓       ./test_ip_1_1.sv         RTL Files         ✓       ./test_ip_1_1.vhd         ✓       ./test_ip_1_1.vhd         Ø       VHDL Model         ✓       ./test_ip_1_1.vhd         Ø       ./test_ip_1_1.vhd                                                                                                                                                                          |    |
| <ul> <li>✓ ./test_ip_1_1.sdc</li> <li>Documentation</li> <li>✓ User Guide Markup</li> <li>✓ ./test_ip_1_1.txt</li> <li>Brows</li> <li>Example Testbench</li> <li>✓ Testbench SystemVerilog</li> <li>✓ ./test_ip_1_1.sv</li> <li>Brows</li> <li>RTL Files</li> <li>✓ VHDL Model</li> <li>✓ ./test_ip_1_1.vhd</li> <li>Brows</li> <li>✓ Verilog Model</li> <li>✓ ./test_ip_1_1.v</li> <li>Brows</li> </ul>                                                                                                                                                                                   | se |
| Documentation   ✓   User Guide Markup   ✓   ./test_ip_1_1.txt   Brows   Example Testbench   ✓   Testbench SystemVerilog   ✓   ./test_ip_1_1.sv   Brows   RTL Files   ✓   VHDL Model   ✓   ./test_ip_1_1.vhd   Brows                                                                                                                                                                                                                                                                                                                                                                        |    |
| <ul> <li>✓ User Guide Markup</li> <li>✓ ./test_ip_1_1.txt</li> <li>Brows</li> <li>Example Testbench</li> <li>✓ Testbench SystemVerilog</li> <li>✓ ./test_ip_1_1.sv</li> <li>Brows</li> <li>RTL Files</li> <li>✓ VHDL Model</li> <li>✓ ./test_ip_1_1.vhd</li> <li>Brows</li> <li>✓ Verilog Model</li> <li>✓ ./test_ip_1_1.v</li> </ul>                                                                                                                                                                                                                                                      | se |
| <ul> <li>✓ ./test_ip_1_1.txt</li> <li>Brows</li> <li>Example Testbench</li> <li>✓ Testbench SystemVerilog</li> <li>✓ ./test_ip_1_1.sv</li> <li>Brows</li> <li>RTL Files</li> <li>✓ VHDL Model</li> <li>✓ ./test_ip_1_1.vhd</li> <li>Brows</li> <li>✓ Verilog Model</li> <li>✓ ./test_ip_1_1.v</li> <li>Brows</li> </ul>                                                                                                                                                                                                                                                                    |    |
| Example Testbench                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |    |
| <ul> <li>✓ Testbench SystemVerilog</li> <li>✓ ./test_ip_1_1.sv</li> <li>Brows</li> <li>RTL Files</li> <li>✓ VHDL Model</li> <li>✓ ./test_ip_1_1.vhd</li> <li>Brows</li> <li>✓ Verilog Model</li> <li>✓ ./test_ip_1_1.v</li> </ul>                                                                                                                                                                                                                                                                                                                                                          | se |
| <ul> <li>✓ ./test_ip_1_1.sv</li> <li>Brows</li> <li>RTL Files</li> <li>✓ VHDL Model</li> <li>✓ ./test_ip_1_1.vhd</li> <li>Ørows</li> <li>✓ Verilog Model</li> <li>✓ ./test_ip_1_1.v</li> <li>Brows</li> </ul>                                                                                                                                                                                                                                                                                                                                                                              |    |
| RTL Files                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |    |
| ✓       VHDL Model         ✓       ./test_ip_1_1.vhd         ✓       ✓ Verilog Model         ✓       ./test_ip_1_1.v                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | se |
| <ul> <li>✓ ./test_ip_1_1.vhd</li> <li>✓ ✓ Verilog Model</li> <li>✓ ./test_ip_1_1.v</li> <li>Brows</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |
| ✓     ✓     Verilog Model       ✓     ./test_ip_1_1.v     Brows                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |    |
| ✓ ./test_ip_1_1.v Brows                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | se |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | se |
| Relative File Paths                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |    |
| ✓ Output File paths Relative To ACXIP File                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | •  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |    |
| ⑦ Cancel Finish                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |    |

#### Figure 320 • Generate IP Design Files Wizard Page Containing Output File Generators

#### **Built-in Output File Generation**

The current framework supports built-in output file generation for Verilog / SystemVerilog and VHDL only. The builtin callback name must be specified as part of the output file. Both these built-in file generators are constructed using helper Tcl functions.

#### 🔥 Caution!

All these built-in file generators and helper functions is defined in a Tcl package "ipgen". It is therefore important to require this package in the ip\_plugin.tcl as follows:

package require ipgen

#### **Built-in Output File generation**

ace\_ip::add\_ip\_output\_file "VHDL Model" "ace\_ip::builtin\_generate\_ip\_vhdl\_file"
"output.vhdl\_f\_en" "output.vhdl\_f" "RTL Files" "Description text here..." -enabled
"false" -file\_ext "\*.vhd"

#### (i) Note

The output generated by ace\_ip::builtin\_generate\_ip\_verilog\_file can also considered SystemVerilog.

#### **Built-In Tcl Helper Fucntions**

Verilog built-in and helper functions

- ace\_ip::builtin\_generate\_ip\_verilog\_file {output\_file\_path acxip\_file\_path output\_file}
- ace\_ip::outputVerilogIpPorts {output\_file}

ace\_ip::getEnumPropertyValueForLabel {propName}

• ace\_ip::outputVerilogMacroParameterList {output\_file}

```
ace_ip::outputModuleDirectives {output_file}
```

```
ace_ip::writeVerilogParam {output_file val name label includeComma}
```

ace\_ip::outputVerilogModulePortMapBlock {output\_file moduleName}

VHDL built-in and helper functions

- ace\_ip::builtin\_generate\_ip\_vhdl\_file {output\_file\_path acxip\_file\_path output\_file}
- ace\_ip::outputVhdlIpPorts {output\_file}
- ace\_ip::outputVhdlPortMapBlock {output\_file moduleName}

Miscellaneous

- ace\_ip::get\_common\_header\_comment {output\_file acxip\_file\_path file\_type}
- ace\_ip::getFileNameWithoutExtension {output\_file\_path}

The builtin Verilog callback procedure generates the following output for our example Test IP 1 example:

10.1

```
input ref_clk, // ref_clk description Text for tooltip and documentation...
  input rstn,
                        // rstn description Text for tooltip and documentation...
// Data Interface
  input [31:0] data_in, // data_in description Text for tooltip and documentation...
  output [31:0] data_out // data_out description Text for tooltip and documentation...
);
ACX_EXAMPLE_SOFT_IP #
(
  .enumParam2 (4'hX), //Enum Param 2
  .enumParam3 (4'hX), //Enum Param 3
  .enumParam4 ("1/2"), //Enum Param 4
  .INTPARAM1 (3), //Integer Param 1
  .INTPARAM2 (0), //Integer Param 2
  .FLOATPARAM1 (3.100000), //Float Param 1
  .STRINGPARAM1 (my Default), //String Param 1
  .BOOLPARAM1 (1'h1), //Bool Param 1
  .binaryParam1 (32'b0001010101010101010101010101010), //Binary Param 1
  .BOOLPARAM2 (1'h1) //Bool Param 2
)
i_test_ip_1_1
(
// Clocks and Resets
  .ref_clk (ref_clk), // ref_clk description Text for tooltip and documentation...
                       // rstn description Text for tooltip and documentation...
  .rstn (rstn),
// Data Interface
   .data_in (data_in), // data_in description Text for tooltip and documentation...
   .data_out (data_out) // data_out description Text for tooltip and documentation...
);
endmodule // test_ip_1_1
```

The builtin VHDL callback procedure generates the following output for our example Test IP 1 example:

```
library IEEE ;
use IEEE.STD_LOGIC_1164.all ;
entity acx_test_ip_1_1_wrapper is
port (
 data_in : in std_logic_vector(31 downto 0); --data_in description Text for tooltip and
documentation...
 data_out : out std_logic_vector(31 downto 0); --data_out description Text for tooltip
and documentation...
 ref_clk : in std_logic; --ref_clk description Text for tooltip and documentation...
 rstn : in std_logic --rstn description Text for tooltip and documentation...
);
end entity acx_test_ip_1_1_wrapper ;
architecture acx_test_ip_1_1_wrapper_arch of acx_test_ip_1_1_wrapper is
component test_ip_1_1 is
port (
 data_in : in std_logic_vector(31 downto 0); --data_in description Text for tooltip and
documentation...
 data_out : out std_logic_vector(31 downto 0); --data_out description Text for tooltip
and documentation...
 ref_clk : in std_logic; --ref_clk description Text for tooltip and documentation...
 rstn : in std_logic --rstn description Text for tooltip and documentation...
);
end component test_ip_1_1 ;
begin
test_ip_1_1_inst : test_ip_1_1
port map (
   data_in => data_in,
   data_out => data_out,
   ref_clk => ref_clk,
   rstn => rstn
);
end architecture acx_test_ip_1_1_wrapper_arch ;
```

#### **Custom Output File Generation**

#### Custom output file generation

```
ace_ip::add_ip_output_file_group "Constraints" "Some description text for tool-tip and
docs"
ace_ip::add_ip_output_file "PDC Constraints" "ip1_custom_generate_ip_pdc_file"
"output.pdc_file_en" "output.pdc_file" "Constraints" "Description text here..." -enabled
"false" -file_ext "*.pdc"
proc ip1_custom_generate_ip_pdc_file {output_file_path acxip_file_path output_file} {
   upvar $output_file out_file
   set name [ace_ip::get_ip_property_value "name"]
    set library [ace_ip::get_ip_property_value "library"]
    set version [ace_ip::get_ip_property_value "acxip_version"]
   puts $out_file "# Generated PDC output file"
   puts $out_file "# IP Generator Tool: $name"
   puts $out_file "# IP Generator Library: $library"
   puts $out file "# IP Generator Version: $version"
   puts $out_file "# Source ACXIP File: $acxip_file_path\n"
}
ace_ip::add_ip_output_file "SDC Constraints" "ip1_custom_generate_ip_sdc_file"
"output.sdc_file_en" "output.sdc_file" "Constraints" "Description text here..." -enabled
"false" -file_ext "*.sdc"
proc ip1_custom_generate_ip_sdc_file {output_file_path acxip_file_path output_file} {
   upvar $output_file out_file
   ace_ip::get_common_header_comment out_file $acxip_file_path "SDC output"
}
ace_ip::add_ip_output_file_group "Example Testbench" "Some description text for tooltip
and docs"
ace_ip::add_ip_output_file "Testbench SystemVerilog"
"ip1_custom_generate_ip_testbench_sv_file" "output.testbench_sv_file_en"
"output.testbench_sv_file" "Example Testbench" "Description text here..." -enabled
"false" -file_ext "*.sv"
proc ip1_custom_generate_ip_testbench_sv_file {output_file_path acxip_file_path
output_file} {
   upvar $output_file out_file
   ace_ip::get_common_header_comment out_file $acxip_file_path "Testbench"
}
ace_ip::add_ip_output_file_group "Documentation" "Some description text for tooltip and
docs"
```

```
ace_ip::add_ip_output_file "User Guide Markup" "ip1_custom_generate_ip_ug_docs_file"
"output.ug_docs_file_en" "output.ug_docs_file" "Documentation" "Description text
here..." -enabled "false" -file_ext "*.txt"
proc ip1_custom_generate_ip_ug_docs_file {output_file_path acxip_file_path output_file}
{
    upvar $output_file out_file
    ace_ip::get_common_header_comment out_file $acxip_file_path "UG Doc"
}
```

#### Add IP to GUI

Setup for built-in Verilog generator functions

```
# Finally send this definition to the GUI
ace_ip::add_ip_to_gui "TEST IP 1"
```

# Opening Synplify in ACE

ACE users can now launch Synplify GUI for opening Synplify project files that are referenced within ACE.

```
(i) Note
```

Ensure that the environment variable ACX\_SYNPLIFY\_TOOL\_PATH is set to a valid Synplify Pro path.

#### A Caution!

If the user opens Synplify in ACE, the Synplify Pro session is not automatically closed when ACE closes or crashes. It is the user's responsibility to close the Synplify Pro GUI session if they do not wish keep it running.

#### Caution!

The Synplify Pro GUI, by default shows the following popup which blocks the ACE from connecting with Synplify Pro. The popup blocks ACE from successfully connecting with Synplify Pro. ACE retries five times at regular intervals of 5 seconds by default to establish a connection before killing the Synplify Pro process. It is therefore, important to close this popup immediately so that a connection is established within the five attempts. The interval can be increased by updating the setting in **Cross Probe Preference Page** (page 197).

| You can specify the top-level Verilog<br>module or VHDL entity either on the<br>Implementation Options dialog box<br>making sure that the top-level modu | or by |
|----------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| entity is the last file in the project so<br>file list.                                                                                                  |       |

## ACE-Driven Integrated Synthesis

In ACE-Driven Integrated Synthesis, the Synplify Pro project file is created as part of the Synthesis flow step in ACE. To open this file in Synplify, in the Projects View tree, right-click on the ACE-generated Synplify Pro project file, i.e., **Output**  $\rightarrow$  **syn**  $\rightarrow$ 



Figure 321 • Open Project in Synplify for ACE-Driven Integrated Synthesis

This action will launch Synplify Pro GUI and the selected project file loaded.

#### A Caution!

Users should not make changes to the ACE-generated Synplify Pro project file in Synplify Pro in this flow, because ACE will re-generate the Synplify Pro project file from the ACE project file settings each time synthesis is run, and any changes made in Synplify Pro will be lost. To manage a Synplify project file using Synplify Pro, refer to section. Synplify-Pro-Driven Integrated Synthesis.

# Synplify-Pro-Driven Integrated Synthesis

In Synplify-Pro-Driven Integrated Synthesis, since the user can point to an existing Synplify Pro project file, ACE provides an option to open this project in Synplify Pro GUI.

| E Options ×                                   |                                                 |
|-----------------------------------------------|-------------------------------------------------|
| Project: quickstart<br>Implementation: impl_1 |                                                 |
| Project Options                               |                                                 |
| Simulation                                    |                                                 |
| - Synthesis                                   |                                                 |
| Generate Project File                         |                                                 |
| Project Override Path                         | D:/test/quickstart.prj Open Project in Synplify |
| Route Delay Model                             | acx_custom_route_delay_1                        |
| Fanout Limit                                  | 200                                             |
| Enable Retiming                               |                                                 |
| Advanced Synplify Options                     |                                                 |
| Default Frequency (MHz)                       | 200                                             |

#### Figure 322 • Open Project in Synplify for Synplify-Pro-Driven Integrated Synthesis

This will launch Synplify Pro GUI and the selected project file loaded.

# **Opening Project from ACE File Menu**

The ACE file menu also provides an option to open Synplify Pro project for the active implementation.



Figure 323 • Open Project in Synplify Pro from File Menu

For ACE-Driven Integrated Synthesis, the ACE-generated Synplify project file is loaded automatically.

For Synplify-Pro-Driven Integrated Synthesis, if the Synthesis flow step is run, a wizard pops up allowing the user to choose a project file path. If the Synthesis flow step is not run, then the path specified for the synthesis implementation option, "syn\_project\_override\_path" is loaded.

If there is no Synplify Pro project file path, then Synplify Pro GUI is launched optionally a project from its previous session (if any) is loaded.

# **Opening Project from ACE Actions Menu**

The same behavior of opening project from ACE file menu can be achieved by selecting Actions menu: Actions  $\rightarrow$  Synthesis  $\rightarrow$  Open Project in Synplify.

| Actions Window Help   |                         |            |
|-----------------------|-------------------------|------------|
| Bitstream             | 🕨 😰 🏢 🗗 💭 i 🕺 🤇         | Ro I 🖓 I 🗇 |
| Console               |                         | E Options  |
| Critical Paths        | •                       |            |
| Critical Path Diagram | <b>, 🛱 🕼 🔅 🛪</b> 🖇      | Project:   |
| Floorplanner          | •                       | Implement  |
| Flow                  | •                       | Project    |
| t IP                  | •                       | > Simulat  |
| Placement             | •                       | - Synthe   |
| Projects              | •                       | Gene       |
| Routing               | •                       | Project (  |
| Search                | •                       | Projecti   |
| Selection             | •                       | Route D    |
| Simulation            | •                       |            |
| Snapshot              | •                       | Fanout I   |
| Synthesis             | 🕨 👌 Import Synplify Pro | oject      |
| Timing                | Open Project in Sy      | nplify     |

Figure 324 • Open Project in Synplify from Actions Menu

# Chapter 5 : Tcl Command Reference

The Tcl commands supported by ACE are broken into three subsets in this document:

- The SDC Commands (page 580), timing constraints which are also supported by upstream tools like Synplify, These commands are used in the SDC project constraints files.
- The Interactive Timing Commands (page 603), which are used to interact with the ACE STA timer. The commands are not constraints and can be used interactively in the ACE Tcl console.
- The ACE Tcl Commands (page 610), which are unique to ACE.

Additionally, ACE ships with a Tcl version 8.6 interpreter; the commands supported by Tcl itself are documented at: https://www.tcl-lang.org/man/tcl8.6/TclCmd/contents.htm

# SDC Commands

The following are the Tcl commands which are used to define timing constraints in both ACE and upstream tools like Synplify.

## all\_clocks

#### all\_clocks

Returns a collection of all clocks in the design.

#### Description

The all\_clocks command will return a list of all of the clocks that have already been defined using either create\_clock or create\_generated\_clock. It is often used in SDC files as an argument to commands that need a list of all of the clocks.

#### Example

To set all of the clocks to have the same setup timing uncertainty value, enter:

```
cmd> set_clock_uncertainty -setup .05 [all_clocks]
```

```
create_clock (page 582)
create_generated_clock (page 583)
get_clocks (page 586)
set_clock_uncertainty (page 592)
```

## all\_inputs

```
all_inputs
```

Returns a collection of all input ports (ports marked "in" and "inout") at the top level of the design.

#### Description

The all\_inputs command returns a list of all of the input ports in the design. It is sometimes used as a command line argument to other SDC commands when a list of all of the input ports are needed.

## Example

To set all of the inputs to have the same minimum input delay from the same clock, enter:

```
cmd> set_input_delay -min .01 [all_inputs] -clock clk
```

#### Also See

```
set_input_delay (page 598)
```

## all\_outputs

```
all_outputs
```

Returns a collection of all output ports (ports marked "out" and "inout") at the top level of the design.

## Description

The all\_outputs command returns a list of all of the output ports in the design. It is sometimes used as a command line argument to other SDC commands when a list of all of the output ports are needed.

#### Example

To set output delay constraint to all outputs with respect to the same clock, enter:

```
cmd> set_output_delay -min .01 [all_outputs] -clock clk
```

#### Also See

set\_output\_delay (page 602)

## create\_clock

create\_clock [<clock>] [-period <string>] [-name <string>] [-waveform <list>]
Define a clock

| Argument                    | Optional | Description                                                 |
|-----------------------------|----------|-------------------------------------------------------------|
| [ <clock>]</clock>          | Y        | nets, ports or pins (as 'inst/pin')                         |
| [-period <string>]</string> | Y        | clock period in ns (required)                               |
| [-name <string>]</string>   | Y        | alternate name                                              |
| [-waveform <list>]</list>   | Υ        | list of edges for clock rise and fall timings in the period |

## Description

The create\_clock command is the main SDC constraint input to static timing analysis. In its simplest form it can define a clock and its associated period. This definition is used by the timer to start timing paths. The timing paths will take one of four possible paths:

- 1. Traverse from a create\_clock statement, through the clock IPIN, through the clock tree to a source DFF/LRAM/ BRAM clock pin, through the source device, through the whatever logic is between the source, to the capture logic or set\_output\_delay (page 602) constraint.
- 2. Traverse from the create\_clock statement, through a set\_input\_delay (page 598) constraint defined on a given port, through the path from that port to the DFF/LRAM/BRAM data input pin. These paths are often referred to as I/O timing paths, and specifically, input timing paths.
  - a. A create\_clock statement can also be used strictly for IO timing, and not actually be placed and routed in the design. These are often refereed to as "virtual clocks".
- 3. Sometimes a create\_clock statement will be assigned to an input port that will traverse to a data input pin of a DFF. If this is done, the arrival time of the rising and falling edges will be separated in time by the definitions of the first asserted edge and deasserted edge of the clock.

## Example

To define a clock on an input clock port and assign it a period of 2 ns, enter:

```
cmd> create_clock -period 2 [get_ports clock_in[0]]
```

To define a clock with a non-default (50/50) duty cycle, the create\_clock -waveform option can be used:

```
set clock_period 10
set clock_asserted_edge 0
set clock_deasserted_edge [expr $clock_period / 5]
create_clock -name my_clock_name -period $clock_period -waveform
"$clock_asserted_edge $clock_deasserted_edge" [get_ports my_clock_port_name]
```

To define a virtual clock you must use the -name option so that the clock name can be referenced by other SDC commands. Otherwise, the -name option is optional.

create\_clock -name virtual\_my\_clock -period 10

The virtual\_my\_clock can then be used in IO timing constraints to define the arrival time of data at input ports based on a clock that will not have any design specific latency:

set\_input\_delay 1 -clock virtual\_my\_clock [get\_ports i\_user\_data\*]

#### **Also See**

```
create_generated_clock (page 583)
```

get\_ports (page 588)

report\_clock\_properties (page 608)

report\_clocks (page 679)

report\_checks (page 606)

set\_clock\_latency (page 591)

set\_clock\_groups (page 589)

set\_clock\_uncertainty (page 592)

set\_input\_delay (page 598)

set\_output\_delay (page 602)

#### create\_generated\_clock

```
create_generated_clock <clock> [-source <string>] [-divide_by <int>] [-multiply_by
<int>] [-name <string>]
Define a generated clock
```

| Argument                    | Optional | Description                                 |
|-----------------------------|----------|---------------------------------------------|
| <clock></clock>             |          | nets or pins (as 'inst/pin')                |
| [-source <string>]</string> | Y        | (required argument) master clock source pin |
| [-divide_by <int>]</int>    | Y        | factor                                      |
| [-multiply_by <int>]</int>  | Y        | factor                                      |
| [-name <string>]</string>   | Y        | alternate name for the generated clock      |

## Description

The create\_generated\_clock defines a clock which is applied to an output pin of an instance, internal to the design, or an output port of the design. This SDC command must follow a previously defined create\_clock (page 582) definition, of which the port used to define that create\_clock (page 582) statement would be used as the argument to the -source option. There must be a valid timing path between the source clock node and the generated clock node, so that latency between these two nodes can be calculated. A generated clock can have one of three characteristics of the source clock:

- 1. The same period as the source clock (-divide\_by 1)
- 2. A period less than the source clock (-divide\_by integer value greater than 1)
- 3. A period greater than the source clock (-multiply\_by integer value greater than 1)

The generated clock will typically have a positive latency (delay) from the source clock as there is typically logic between the source clock and the generated clock. Therefore, the arrival time of a generated clock pin at a clock leaf node is calculated taking into account the latency from the source clock to the generated clock, plus the latency of the logic between the generated clock node and the generated clock leaf pin in the timing path. If frequency division is done (-divide\_by or -multiply\_by) than the deasserted edge and the second asserted edge of the generated clock's arrival times will be adjusted to the period calculated by the specified -multiply\_by or -divide\_by the respective values.

## Example

To create a generated clock on an top level output port in a design, which is derived from a top level input port where the path is non-inverting and not divided, the following can be used:

create\_generated\_clock [get\_ports o\_user\_clkout\_001\_003] -name out\_clk
-divide\_by 1 -source [get\_ports i\_user\_clkin\_001\_003]

```
create_clock (page 582)
get_ports (page 588)
```

```
report_clock_properties (page 608)
report_clocks (page 679)
report_checks (page 606)
set_clock_groups (page 589)
set_clock_latency (page 591)
set_clock_uncertainty (page 592)
```

## get\_cells

#### get\_cells pattern

Returns a collection of cells (instances) in the design. All cell names match the specified pattern. Wildcards may be used to select multiple cells at once.

| Argument | Optional | Description                                                                                                                         |
|----------|----------|-------------------------------------------------------------------------------------------------------------------------------------|
| pattern  |          | The required <pattern> option is used to filter returned node names (string pattern is matched using Tcl string matching)</pattern> |

#### Description

The get\_cells command can be use in conjunction with other SDC commands when those commands need a list of cell instance names as input. It accepts the use of the "\*" wildcard will return a list of all cell instance names that match.

#### Example

To get all cell instances with the string "reg" in their name, enter;

```
get_cells *reg*
```

The output of the get\_cells command can be passed to other commands, such as set\_multicycle\_path:

```
set_multicycle_path -from [get_cells top.*my_module.module_reg*] -setup -end 2
```

```
set_multicycle_path (page 600)
set_false_path (page 596)
```

## get\_clocks

#### get\_clocks patterns [-nocase]

Returns a collection of clocks in the design. All clock names in the collection match the specified pattern. Wildcards may be used to select multiple clocks at once.

| Argument  | Optional | Description                                                                                                                                     |
|-----------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| patterns  |          | The required <patterns> option is used to filter returned<br/>node names (string patterns are matched using Tcl string<br/>matching)</patterns> |
| [-nocase] | Υ        | The optional -nocase option specifies the matching of node names to the patterns should be case-insensitive                                     |

## Description

The get\_clocks command can be used after the create\_clock (page 582) command is used to define clocks. Additionally, if the create\_generated\_clock (page 583) command is used, the get\_clocks command will include them as well. The get\_clocks command is used to get a sub-set of what would be returned by the all\_clocks (page 580) command. Typically, this command is used in conjunction with other SDC commands when a specific clock or specific group of clocks is needed as a command line argument.

#### Example

To get all of the clocks with the string "in" in their name, enter:

```
get_clocks *in*
```

To define clock to clock relationships, such as an asynchronous relationships between two clocks the following can be done:

set\_clock\_groups -asynchronous -group [get\_clocks system\_clock] -group
[get\_clocks test\_clk]

```
create_clock (page 582)
create_generated_clock (page 583)
report_clock_properties (page 608)
report_clocks (page 679)
set_clock_groups (page 589)
```

# set\_clock\_latency (page 591) set\_clock\_uncertainty (page 592)

## get\_nets

get\_nets pattern

Returns a collection of nets in the design. All net names in the collection match the specified pattern. Wildcards may be used to select multiple nets at once.

| Argument | Optional | Description                                                                                                                         |
|----------|----------|-------------------------------------------------------------------------------------------------------------------------------------|
| pattern  |          | The required <pattern> option is used to filter returned node names (string pattern is matched using Tcl string matching)</pattern> |

## Description

The get\_nets command can be use in conjunction with other SDC commands when those commands need a list of net names as input. It accepts the use of the "\*" wildcard will return a list of all net names that match.

## Example

To get all nets that have a name containing the string "data" and ending with "[0]", enter:

```
get_nets *data*[0]
```

To define a false path through a net the following command style can be used:

```
set_multicycle_path 2 -setup -through [get_nets *reset_sync_n] -to [get_clocks
sys_clk]
```

## Also See

create\_generated\_clock (page 583)
get\_clocks (page 586)
set\_false\_path (page 596)
set\_multicycle\_path (page 600)

## get\_pins

get\_pins pattern

Returns a collection of pins in the design. All pin names match the specified pattern. Wildcards may be used to select multiple pins at once.

| Argument | Optional | Description                                                                                                                         |
|----------|----------|-------------------------------------------------------------------------------------------------------------------------------------|
| pattern  |          | The required <pattern> option is used to filter returned node names (string pattern is matched using Tcl string matching)</pattern> |

#### Description

The get\_pins command can be use in conjunction with other SDC commands when those commands need a list of cell instance pin names as input. It accepts the use of the "\*" wildcard will return a list of all net names that match.

## Example

In order to define a pin as an argument to another SDC command such as create\_generated\_clock, you can do the following, where the pin "clk\_out" of the CLKDIV instance "sub-module top.first\_sub\_module.second\_sub\_module" is the location of the generated clock:

create\_generated\_clock -divide\_by 2 [get\_pins
top.first\_sub\_module.second\_sub\_module/clk\_out]

Likewise, the same method can be used for any SDC command that takes a pin argument:

```
set_multicycle_path -from [get_pins top.first_sub_module/*reg*/q] -to [get_pins
top.second_sub_module/*reg*/d] -setup 4
```

#### Also See

```
create_generated_clock (page 583)
```

set\_false\_path (page 596)

set\_multicycle\_path (page 600)

## get\_ports

#### get\_ports pattern

Returns a collection of ports (design inputs and outputs) in the design. All port names match the specified pattern. Wildcards may be used to select multiple ports at once.

| Argument | Optional | Description                                                                                                                         |
|----------|----------|-------------------------------------------------------------------------------------------------------------------------------------|
| pattern  |          | The required <pattern> option is used to filter returned node names (string pattern is matched using Tcl string matching)</pattern> |

## Description

The get\_ports command can be use in conjunction with other SDC commands when those commands need a list of top level port names as input. It accepts the use of the "\*" wildcard will return a list of all ports names that match.

#### Example

To get all ports with the string "[0]" in their name, enter:

get\_ports \*[0]\*

This command can also be used in an argument of other SDC commands that take a port and input. One of the most common is in the definition of a clock as it comes into the design:

```
create_clock -period 0.9 [get_ports {sys_clk}]
```

#### Also See

create\_clock (page 582)
create\_generated\_clock (page 583)
set\_false\_path (page 596)
set\_input\_delay (page 598)
set\_multicycle\_path (page 600)
set\_output\_delay (page 602)

## set\_clock\_groups

set\_clock\_groups [-name <string>] [-group <list>] [-asynchronous]

Define clock groups. With one -group, the clocks in that group have a false\_path from/to all other clocks. With multiple -group options, the clocks in each group have a false\_path from/to the clocks in the other groups. The groups have no meaning outside this command.

| Argument                  | Optional | Description                    |
|---------------------------|----------|--------------------------------|
| [-name <string>]</string> | Y        | Name of clock group            |
| [-group <list>]</list>    | Y        | set of clocks                  |
| [-asynchronous]           | Y        | clocks are unrelated (default) |

#### Description

The set\_clock\_groups command is defined in the SDC files after the create\_clock (page 582) and create\_generated\_clock (page 583) statements have been defined. This command can be used to quickly define asynchronous relationships between clocks. This methodology replaced the older set\_false\_path (page 596) based STA/SDC description methodology and is more efficient to write the SDC as well as enabling the timer to be more efficient.

#### Example

To assume a design has clocks system\_clock and test\_clk are asynchronous to all other clocks, enter:

```
set_clock_groups -asynchronous -group [get_clocks system_clock] -group
[get_clocks test_clk]
```

This command specifies that A1 and B are unrelated to C. For instance, a path between A2 and C will not be timed. A path between A1 and A2, on the other hand, will be timed (unless there are other commands specifying a false path between them).

```
set_clock_groups -asynchronous -group [get_clocks {A B} -group [get_clocks C]
```

#### Also See

create\_clock (page 582)
create\_generated\_clock (page 583)
get\_clocks (page 586)
report\_checks (page 606)
set\_false\_path (page 596)

590

## set\_clock\_latency

set\_clock\_latency delay port\_pin\_list [-clock <string>] [-rise] [-fall] [-min] [max] [-late] [-early] [-source]

Set latency of clock network

| Argument                   | Optional | Description                       |
|----------------------------|----------|-----------------------------------|
| delay                      |          | delay_value                       |
| port_pin_list              |          | port_pin_list (one or more ports) |
| [-clock <string>]</string> | Y        | clock list                        |
| [-rise]                    | Y        | rise                              |
| [-fall]                    | Y        | fall                              |
| [-min]                     | Y        | min                               |
| [-max]                     | Y        | max                               |
| [-late]                    | Y        | late                              |
| [-early]                   | Y        | early                             |
| [-source]                  | Y        | source                            |

## Description

The set\_clock\_latency command is used to describe the arrival time of a clock at the top level port where it is defined using the create\_clock (page 582) command. The off-design latency of the clock will modify the timing of the IO logic. The impact of this can be seen in report\_checks (page 606) reports of IO timing where it will be reflected on both the reference clock path as well as the input data arrival times. It is common for there to be more than one set\_clock\_latency definitions for each clock in order to model the off design latency of the clock for both edges of the clock as well as the early and late arrival times of the clock. Care should be taken to ensure that early and late arrival times, which model the range of arrival times that can occur due to off design events such as crosstalk or varying paths to the clock input port, are not replicated (double counted) in the use of the set\_clock\_uncertainty (page 592) command.

## Example

In order to define off chip clock latency, which will impact clock to IO and clock to other clock timing, use the following command, for "late" arriving clock edges at the port where the acx\_sc\_i\_user\_clkin\_000\_001[0]\_1 clock is defined:

```
set_clock_latency -source -late -rise 0.169006 [get_clocks
acx_sc_i_user_clkin_000_001[0]_1]
```

#### Also See

```
create_clock (page 582)
get_clocks (page 586)
report_clock_properties (page 608)
report_clocks (page 679)
report_checks (page 606)
set_clock_uncertainty (page 592)
```

## set\_clock\_uncertainty

set\_clock\_uncertainty <uncertainty> [<objects>] [-from <string>] [-to <string>] [setup] [-hold]

Set uncertainty of clock network

| Argument                    | Optional | Description                        |
|-----------------------------|----------|------------------------------------|
| <uncertainty></uncertainty> |          | clock uncertainty in ns            |
| [ <objects>]</objects>      | Υ        | one or more clocks, ports, or pins |
| [-from <string>]</string>   | Y        | source clock                       |
| [-to <string>]</string>     | Y        | destination clock                  |
| [-setup]                    | Υ        | uncertainty applies to setup check |
| [-hold]                     | Υ        | uncertainty applies to hold check  |

#### Description

#### 👍 Caution!

The set\_clock\_uncertainty command must be used with either the <objects> option or a pair of -from and -to options.

The set\_clock\_uncertainty command is generally used to model off design PLL jitter. This jitter is typically defined as "cycle to cycle" jitter, meaning that for one asserted edge to the next asserted edge there is some amount of +/- "uncertainty" in the arrival time of the second asserted edge. This uncertainty is used to shorten (-) the clock

insertion delay to a capture device in setup paths, and to increase the clock insertion delay to a capture device in hold timing paths. Since setup timing is typically measured from the first asserted edge to the next asserted edge, this PLL jitter based clock uncertainty is directly applicable. However, typically hold timing is done with respect to the same clock edge. Therefore, the set\_clock\_uncertainty command has both -setup and -hold options to enable the user to use different constraint values as the -hold value is not modeling PLL jitter, but instead can be used to add general timing guard band, which is typically referred to as modeling "known unknowns" as well as "unknown unknowns". The values of these constraints work in conjunction with the values defined in both the create\_clock (page 582) definitions, as well as the set\_clock\_latency (page 591) values.

Care should be taken to ensure that uncertainty defined in those other constraint commands are not duplicated in the set\_clock\_uncertainty command. The effect that set\_clock\_uncertainty has on timing is global. All timing paths, both core and IO, will be impacted by this constraint and will be visible in the report\_checks (page 606) reports in the capture or "reference" clock timing path on the "clock uncertainty" line. For setup paths, the value will be subtracted from the clock arrival time, and for hold timing the value will be added to the clock arrival time.

#### Example

To model PLL cycle to cycle jitter specification of 0.02nS for all of the clocks, the following command can be used:

```
set_clock_uncertainty -setup .02 [all_clocks]
```

To define extra hold timing guard band the following command can be used:

```
set_clock_uncertainty -hold .005 [all_clocks]
```

#### Also See

```
all_clocks (page 580)
create_clock (page 582)
create_generated_clock (page 583)
report_clock_properties (page 608)
report_clocks (page 679)
report_checks (page 606)
set_clock_latency (page 591)
```

#### set\_data\_check

```
set_data_check value [-clock <string>] [-setup] [-hold] [-from <string>] [-to
<string>]
```

Set data-to-data check values of setup and hold

| Argument                   | Optional | Description                    |
|----------------------------|----------|--------------------------------|
| value                      |          | check value                    |
| [-clock <string>]</string> | Y        | clock                          |
| [-setup]                   | Y        | setup                          |
| [-hold]                    | Y        | hold                           |
| [-from <string>]</string>  | Y        | from_list (one or more clocks) |
| [-to <string>]</string>    | Y        | to_list (one or more clocks)   |

## Description

The set\_data\_check command can be used to add timing constraint between two data signals arriving to different pins/ports. This added timing constraint is analogous to the standard setup/hold timing constraints between a clock and data modeled for a DFF/LRAM/BRAM, but in this case the -from related pins is defined as the reference or clock pin, and the -to related pin is the data pin. The command supports unique -setup and -hold values, but if neither -setup nor -hold options are used, the values are applied only to setup. Often this command is used to define "data skew" which is typically defined as a +/- delta between data bus arrival times. Therefore, both the -setup and -hold options must be used, in different command instantiations, to define one data bit in a bus as the reference to N number of other data bits. Both the -from pin and the -to pin must be singular. For a bus that is 16 bits wide, there needs to be 15 constraints.

The -from and -to nodes defined in these commands must have existing valid timing paths to them for the set\_data\_check command to function. Therefore, if these constraints are applied to output ports, there must also be a set\_output\_delay (page 602) constraint applied to them. Additionally, if both -setup and -hold data checks are to be performed, there must be both -min and -max set\_output\_delay (page 602) constraints defined.

## Example

In order to constrain the delay between two or more data pins, such as a "data skew" constraint, the following command can be used. This will define both a setup and hold timing relationship between the reference\_pin\_name and all of the the other\_pin\_names.

set\_data\_check -from [get\_pins top.sub-module.instance1/reference\_pin\_name] -to
[get\_pins top.sub-module.instance1/another\_pin\_name] .1

If more than one clock can drive a signal to the -from related pin, than the command can be made more specific by using the -clock options

```
set_data_check -from [get_pins top.sub-module.instance1/pin_name] -to [get_pins
top.sub-module.instance1/another_pin_name] .1 -clock [get_clocks my_clock]
```

To model a data skew constraint, a Tcl loop such as this can be used:

```
set first_port 0
set plus_minus_constraint 0.05
foreach port_name [get_ports dout_gpio[*]] {
    if { $first_port == 0 } {incr first_port;set reference_port
    $port_name;continue}
        set_data_check -from $reference_port -to $port_name $plus_minus_constraint
    -hold
        set_data_check -from $reference_port -to $port_name $plus_minus_constraint
    -setup
}
```

#### Also See

get\_pins (page 587)
get\_clocks (page 586)
report\_checks (page 606)
set\_output\_delay (page 602)

## set\_disable\_timing

```
set_disable_timing <objects> [-from <string>] [-to <string>]
Disable timing arcs in a circuit
```

| Argument                  | Optional | Description                                   |
|---------------------------|----------|-----------------------------------------------|
| <objects></objects>       |          | one or more instances, ports, or pins         |
| [-from <string>]</string> | Y        | input pin name of instance <object></object>  |
| [-to <string>]</string>   | Y        | output pin name of instance <object></object> |

## Description

The set\_disable\_timing command is typically used to disable an existing timing arc. This is somewhat analogous to set\_false\_path (page 596), but with a much more limited scope. The set\_disable\_timing command requires a -from and a -to option to be used together, to bound the scope of its effect. Often, this

command is used to break timing loops from an input pin to an output pin of the same cell instance. The pin names used in the -from and -to options must be just the pin name, as found in the cell library.

#### Example

In order to break all of the timing arcs for an instance (top.sub-module.instance1), the following command can be used:

```
set_disable_timing [get_cells top.sub-module.instance1]
```

To break a given timing arc between two pins of a given cell instance, the following can be done:

```
set_disable_timing -from input_pin_name -to input_pin_name [get_cells top.sub-
module.instance1]
```

#### Also See

```
get_cells (page 585)
set_false_path (page 596)
```

## set\_false\_path

```
set_false_path [-from <list>] [-to <list>] [-through <list>]
```

Define a false path exception (this declares that the clocks are unrelated)

| Argument                 | Optional | Description                       |
|--------------------------|----------|-----------------------------------|
| [-from <list>]</list>    | Y        | from_list (one or more clocks)    |
| [-to <list>]</list>      | Y        | to_list (one or more clocks)      |
| [-through <list>]</list> | Y        | through_list (one or more clocks) |

## Description

The set\_false\_path command is used to create "timing exception" to the general STA paradigm that all timing paths are analyzed as a one cycle setup and zero cycle hold timing path. Another timing exception syntax is set\_multicycle\_path (page 600) and the user must be sure if a path is truly never used, or if it is a multicycle path. Timing paths that are analyzed by STA, but found to not be valid for whatever reason can be removed from the analysis by using the set\_false\_path statement. This command has several options, and can define very wide ranging paths so care should always be taken to limit the scope of the these commands in order to ensure that only the paths known to be false are affected by these commands. To enable users to focus these statements on a finite

number of paths there is syntax to define the path start point (-from), path intermediate points (-through) as well as path end points (-to). It is advisable to be as explicit in the timing path definition as possible to ensure that real or valid timing paths are not being suppressed. Often the process of defining timing exceptions is like "peeling an onion". The timing typically only shows the "worst case path", so as you eliminate that path, the next-worst path becomes the new worst case path. Therefore, the most effective timing exceptions are typically constructed after all of the timing paths have been validated and all of the resulting exceptions combined to minimize the number of exceptions.

The definition of the path can be very narrow or very broad depending on how it is constructed. Each statement can contain only one -from and one -to statement, but each of them can reference many "from" nodes and many "to" nodes. If there are more than one node for these, all combinations apply. All "from" nodes are applied to all "to" nodes. Additionally, the -through option can have multiple nodes defined in it. Each of the -through nodes apply independently so if a path goes through any of the matching nodes it applies. However, multiple -through statements can be used in series with each other. They are order dependent, so '-through a' and '-through b' implies that the path must first go through "a" and then go through "b". If the -through command has multiple nodes in it, than that one statement is define as an 'OR'; '-through a -through "b c" -through d' implies that the path must go through "a" and then go through either "b" or "c", and then go through "d".

#### Example

In order to remove a timing path between an "instance/clock\_pin\_name" to an "instance/input\_pin" from being analyzed by the timer, the following command can be used:

set\_false\_path -from [get\_pins top.module1.reg\_instance\_name/clock\_pin\_name]
-through [get\_nets some\_applicable\_net] -to [get\_pins
top.module2.instance\_name/input\_pin\_name]

In order to remove all timing from a given timing node such as an input port, the following can be done:

set\_false\_path -from [get\_ports my\_port\_which\_I\_do\_not\_want\_to\_time]

A false path can also be define -through a net, as well as instances and pins:

set\_false\_path -through [get\_nets my\_net\_of\_interest\_name]

#### Also See

```
get_pins (page 587)
get_ports (page 588)
get_nets (page 587)
set_multicycle_path (page 600)
```

597

## set\_input\_delay

set\_input\_delay delay port\_pin\_list [-clock <string>] [-rise] [-fall] [-max] [min] [-add\_delay] [-clock\_fall]

Specify an input delay constraint or clock

| Argument                   | Optional | Description                                   |
|----------------------------|----------|-----------------------------------------------|
| delay                      |          | delay_value                                   |
| port_pin_list              |          | port_pin_list (one or more ports)             |
| [-clock <string>]</string> | Y        | clock_name                                    |
| [-rise]                    | Y        | rise                                          |
| [-fall]                    | Y        | fall                                          |
| [-max]                     | Y        | max                                           |
| [-min]                     | Y        | min                                           |
| [-add_delay]               | Y        | add delay                                     |
| [-clock_fall]              | Y        | delay with reference to falling edge of clock |

## Description

The set\_input\_delay, as well as the set\_output\_delay (page 602) command, is fundamental to validating the correctness of a design's timing. It is defined after the clocks are define and it references the related clock using the -clock option. Typically, there will be four (4) definitions of set\_input\_delay for each data/clock combination, at each timing corner. The arrival time of the data at its design input port is relative to this clock's arrival time. Therefore, the set\_clock\_latency (page 591) constraint will impact the arrival time of data related to that clock. The value of the set\_input\_delay constraint is used in the timing path which receives the data signal. This value can be seen in a report\_checks (page 606) report in the data path section under "input external delay".

## Example

In order to constrain a design's input port, an arrival time for a signal at the input port, relative to the asserted edge of a specified clock, for both min and max data path timing, as well as having different values for rise and fall edges, can be defined using this command:

```
set_input_delay .1 -rise -max -clock [get_clocks my_clock_name] [get_ports
my_input_port_name]
set_input_delay .13 -fall -max -clock [get_clocks my_clock_name] [get_ports
```

```
my_input_port_name]
set_input_delay .05 -rise -min -clock [get_clocks my_clock_name] [get_ports
my_input_port_name]
set_input_delay .055 -fall -min -clock [get_clocks my_clock_name] [get_ports
my_input_port_name]
```

#### Also See

```
create_clock (page 582)
get_clocks (page 586)
get_ports (page 588)
report_checks (page 606)
set_clock_latency (page 591)
set_output_delay (page 602)
```

# set\_input\_transition

```
set_input_transition slew port_pin_list [-clock <string>]
Specify an input slew/transition constraint
```

| Argument                   | Optional | Description                       |
|----------------------------|----------|-----------------------------------|
| slew                       |          | slew_value                        |
| port_pin_list              |          | port_pin_list (one or more ports) |
| [-clock <string>]</string> | Y        | clock_name                        |

## set\_load

```
set_load load port_pin_list
```

Specify an output load/capacitance constraint

| Argument      | Optional | Description                       |
|---------------|----------|-----------------------------------|
| load          |          | cap_value                         |
| port_pin_list |          | port_pin_list (one or more ports) |

## set\_max\_delay

set\_max\_delay delay [-from <list>] [-to <list>] [-through <list>]
Set a maximum delay for a path

| Argument                 | Optional | Description                       |
|--------------------------|----------|-----------------------------------|
| delay                    |          | delay                             |
| [-from <list>]</list>    | Y        | from_list (one or more clocks)    |
| [-to <list>]</list>      | Y        | to_list (one or more clocks)      |
| [-through <list>]</list> | Y        | through_list (one or more clocks) |

## set\_min\_delay

set\_min\_delay delay [-from <list>] [-to <list>] [-through <list>]
Set a minimum delay for a path

| Argument                 | Optional | Description                       |
|--------------------------|----------|-----------------------------------|
| delay                    |          | delay                             |
| [-from <list>]</list>    | Y        | from_list (one or more clocks)    |
| [-to <list>]</list>      | Y        | to_list (one or more clocks)      |
| [-through <list>]</list> | Y        | through_list (one or more clocks) |

## set\_multicycle\_path

```
set_multicycle_path multiplier [-setup] [-hold] [-start] [-end] [-from <list>] [-
to <list>] [-through <list>]
```

Define multicycle path

| Argument   | Optional | Description                                                                                      |
|------------|----------|--------------------------------------------------------------------------------------------------|
| multiplier |          | integer path multiplier                                                                          |
| [-setup]   | Y        | Use the specified path multiplier for setup/max delay calculations. This is the default behavior |

| Argument                 | Optional | Description                                                                                                                                                                       |
|--------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-hold]                  | Y        | Use the specified path multiplier for hold/min delay calculations                                                                                                                 |
| [-start]                 | Y        | Use the start/source clock period in the calculations. This is the default behavior for hold checks                                                                               |
| [-end]                   | Y        | Use the end/target clock period in the calculations. This is the default behavior for setup checks                                                                                |
| [-from <list>]</list>    | Y        | list of path startpoints containing clock, primary input/<br>inout port, sequential-cell instance, clock pin of<br>sequential-cell instance, or pin with input delay constraint   |
| [-to <list>]</list>      | Y        | list of path endpoints containing clock, primary output/<br>inout port, sequential-cell instance, data pin of<br>sequential-cell instance, or pin with output delay<br>constraint |
| [-through <list>]</list> | Y        | list of pins, ports, nets that the path must pass through                                                                                                                         |

## Description

The set\_multicycle\_path command is used to create "timing exception" to the general STA paradigm that all timing paths are analyzed as a one cycle setup and zero cycle hold timing path. Another timing exception syntax is set\_false\_path and the user must be sure if a path is truly used but in more than one cycle, or never used. Timing paths that are analyzed by STA, but found to not be only valid on more than one cycle, for whatever reason, can have it's analysis adjusted by using the set\_multicycle\_path statement. This command has several options, and can define very wide ranging paths so care should always be taken to limit the scope of the these commands in order to ensure that only the paths known to be false are effected by these commands. To enable users to focus these statements on a finite number of paths there is syntax to define the path start point (-from), path intermediate points (-through) as well as path end points (-to). It is advisable to be as explicit in the timing path definition as possible to ensure that real or valid timing paths are not being suppressed. Often the process of defining timing exceptions is like "peeling an onion". The timing typically only shows the "worst case path", so as you eliminate that path, the next-worst path becomes the new worst case path. Therefore, the most effective timing exceptions are typically constructed after all of the timing paths have been validated and all of the resulting exceptions combined to minimize the number of exceptions.

The definition of the path can be very narrow or very broad depending on how it is constructed. Each statement can contain only one -from and one -to statement, but each of them can reference many "from" nodes and many "to" nodes. If there are more than one node for these, all combinations apply. All "from" nodes are applied to all "to" nodes. Additionally, the -through option can have multiple nodes defined in it. Each of the -through nodes apply independently so if a path goes through any of the matching nodes it applies. However, multiple -through statement can be used in series with each other. They are order dependent, so '-through a' and '-through b' implies that the path must first go through "a" and then go through "b". If the -through command has multiple nodes in it, than that one statement is define as an 'OR'; '-through a -through "b c" -through d' implies that the path must go through "a" and then go through either "b" or "c", and then go through "d".

#### Example

To change the default STA one cycle timing paradigm for all paths between two DFFs, to being a two cycle path, the following can be done:

```
set_multicycle_path 2 -from [get_pins top.sub_module_name.register_name/ck] -to
[get_pins top.some_module_name.some_register_name/q] -setup
```

It is important to understand, that the changing of the default one cycle path for setup, usually requires a modification from the default zero (0) cycle hold timing constraint (but not always). In this case, the hold timing is changed to be a one (1) cycle hold check:

```
set_multicycle_path 1 -from [get_pins top.sub_module_name.register_name/ck] -to
[get_pins top.some_module_name.some_register_name/q] -hold
```

#### Also See

get\_pins (page 587)

## set\_output\_delay

set\_output\_delay delay port\_pin\_list [-clock <string>] [-rise] [-fall] [-max] [min] [-add\_delay] [-clock\_fall]

Specify an output delay constraint or clock

| Argument                   | Optional | Description                       |
|----------------------------|----------|-----------------------------------|
| delay                      |          | delay_value                       |
| port_pin_list              |          | port_pin_list (one or more ports) |
| [-clock <string>]</string> | Y        | clock_name                        |
| [-rise]                    | Y        | rise                              |
| [-fall]                    | Y        | fall                              |
| [-max]                     | Y        | max                               |
| [-min]                     | Y        | min                               |
| [-add_delay]               | Y        | add delay                         |

| Argument      | Optional | Description                                   |
|---------------|----------|-----------------------------------------------|
| [-clock_fall] | Υ        | delay with reference to falling edge of clock |

#### Description

The set\_output\_delay, as well as the set\_input\_delay (page 598) command, is fundamental to validating the correctness of a design's timing. It is defined after the clocks are define and it references the related clock using the -clock option. Typically, there will be four (4) definitions of set\_output\_delay for each data/clock combination, at each timing corner. The required time of the data at its design output port is relative to this clock's arrival time. Therefore, the set\_clock\_latency (page 591) constraint will impact the required time of data related to that clock. The value of the set\_output\_delay constraint is used in the timing path which drives the output data signal. This value can be seen in a report\_checks (page 606) report in the data path section under "output external delay".

#### Example

In order to constrain a design's output port, a required time for a signal at the output port, relative to the asserted edge of a specified clock, can be defined using this command:

set\_output\_delay .1 -rise -max -clock [get\_clocks my\_clock\_name] [get\_ports
my\_output\_port\_name]
set\_output\_delay .13 -fall -max -clock [get\_clocks my\_clock\_name] [get\_ports
my\_output\_port\_name]
set\_output\_delay .05 -rise -min -clock [get\_clocks my\_clock\_name] [get\_ports
my\_output\_port\_name]
set\_output\_delay .055 -fall -min -clock [get\_clocks my\_clock\_name] [get\_ports
my\_output\_port\_name]

#### Also See

get\_ports (page 588)
get\_clocks (page 586)
report\_checks (page 606)
set\_clock\_latency (page 591)
set\_output\_delay (page 602)

# Interactive Timing Commands

These commands are used to query the ACE Static Timing Analyzer (STA) interactively, from the ACE command prompt. To use these commands, interactive timer mode must be enabled by calling **prepare\_sta** (page 605). To exit

interactive timer mode, call **reset\_sta** (page 609). While in interactive timer mode, regular ACE commands remain available, but the placement and routing of the design should not be changed.

## check\_setup

The check\_setup command performs sanity checks on the design. Individual checks can be performed with the keywords. If no check keywords are specified all checks are performed.

#### **Command Syntax**

```
check_setup [-verbose] [-unconstrained_endpoints] [-multiple_clock] [-no_clock] [-
no_input_delay] [-no_output_delay] [-loops] [-generated_clocks]
```

| Argument                 | Optional     | Description                                                                     |
|--------------------------|--------------|---------------------------------------------------------------------------------|
| -verbose                 | $\checkmark$ | Show offending objects rather than just error counts.                           |
| -unconstrained_endpoints | $\checkmark$ | Check path endpoints for timing constraints (timing check or set_output_delay). |
| -multiple_clock          | $\checkmark$ | Check register/latch clock pins for multiple clocks.                            |
| -no_clock                | $\checkmark$ | Check register/latch clock pins for a clock.                                    |
| -no_input_delay          | $\checkmark$ | Check for inputs that do not have a set_input_delay command.                    |
| -no_output_delay         | $\checkmark$ | Check for outputs that do not have a set_output_delay command.                  |
| -loops                   | $\checkmark$ | Check for combinational logic loops.                                            |
| -generated_clocks        | $\checkmark$ | Check that generated clock source pins have been defined as clocks.             |

#### Table 152 · Command-line Options for check\_setup

| Argument    | Optional     | Description            |
|-------------|--------------|------------------------|
| > filename  | $\checkmark$ | Write output to file.  |
| >> filename | $\checkmark$ | Append output to file. |

#### Example

To check the effectiveness of the timing constraint to fully constrain all of the design's timing endpoints, the check\_setup command can be run after [run\_prepare]:

The following generates standard output summarizing any checks that violate:

check\_setup

The following reports only a summary of the "unconstrained endpoints":

check\_setup -unconstrained\_endpoints

The following will create an "check\_setup.rpt" file, and will indicate all of the information available for each violations:

```
check_setup -unconstrained_endpoints -verbose > check_setup.rpt
check_setup -multiple_clock -verbose >> check_setup.rpt
check_setup -no_clock -verbose >> check_setup.rpt
check_setup -no_input_delay -verbose >> check_setup.rpt
check_setup -no_output_delay -verbose >> check_setup.rpt
check_setup -loops -verbose >> check_setup.rpt
check_setup -generated_clocks -verbose >> check_setup.rpt
```

#### prepare\_sta

The prepare\_sta command prepares the ACE Static Timing Analyzer (STA) for interactive use. This step is required before other interactive timer commands can be used. Typically, prepare\_sta is only used after place and route. If

the netlist, or the placement or routing, is modified, run this command again before interactive timing commands are used.

| Command Syntax                                            |
|-----------------------------------------------------------|
| <pre>prepare_sta (-slowc   -fastc) [-unconstrained]</pre> |

#### Table 153 · Command-line Options for prepare\_sta

| Argument                                                                                        | Optional | Description                                                                                                            |  |  |
|-------------------------------------------------------------------------------------------------|----------|------------------------------------------------------------------------------------------------------------------------|--|--|
| -slowc                                                                                          |          | Use delays for the slow timing corner. This option is often used for verifying setup time requirements. <sup>(1)</sup> |  |  |
| -fastc                                                                                          |          | Use delays for the fast timing corner. This option is often used for verifying hold time requirements. <sup>(1)</sup>  |  |  |
| -unconstrained                                                                                  | ✓        | Enable reporting of unconstrained paths.                                                                               |  |  |
| <ul> <li><b>Table Notes</b></li> <li>1. Exactly one timing corner must be specified.</li> </ul> |          |                                                                                                                        |  |  |

#### Example

To change the Tcl interface to be in STA interactive mode to analyze the slow timing arcs, enter the following from the ACE Tcl window, while in the ACE Tcl interface mode:

```
prepare_sta -slowc
```

When ACE is in STA "slowc" mode, to look at the fast timing arcs, enter the following:

```
reset_sta
prepare_sta -fastc
```

#### report\_checks

The report\_checks command reports the timing results for paths in the design.

#### **Command Syntax**

```
report_checks [-from <list>] [-to <list>] [-rise_to <list>] [-fall_to <list>] [-
path_delay <min,max>] [-group_count <int>] [-endpoint_count <int>] [-through <list>] [-
rise_through <list>] [-fall_through <list>] [-slack_max <float>] [-slack_min <float>] [-
sort_by_slack] [-path_group <list>] [-format <end,full,short,summary>] [-fields <list:
input_pins,nets>] [-digits <int>] [-no_line_split]
```

#### Table 154 • Command Line Options for report\_checks

| Argument                        | Optional     | Description                                                                                                                              |
|---------------------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------|
| -from <list></list>             | $\checkmark$ | Report only paths starting at the specified objects: clocks, instances, ports, or pins.                                                  |
| -to <list></list>               | $\checkmark$ | Report only paths ending at the specified objects: clocks, instances, ports, or pins.                                                    |
| -rise_to <list></list>          | $\checkmark$ | Report only paths ending rising edge at the specified objects: clocks, instances, ports, or pins.                                        |
| -fall_to <list></list>          | $\checkmark$ | Report only paths ending falling edge at the specified objects: clocks, instances, ports, or pins.                                       |
| -path_delay <min,max></min,max> | $\checkmark$ | The type of timing analysis. Currently only max (for setup analysis) and min (for hold time analysis) are supported. The default is max. |
| -group_count <int></int>        | $\checkmark$ | The maximum number of paths to report, per clock group.                                                                                  |
| -endpoint_count <int></int>     | $\checkmark$ | The number of paths to report per endpoint (default 1).                                                                                  |
| -through <list></list>          | $\checkmark$ | Report only paths through the specified objects: instances, pins, or nets.                                                               |
| -rise_through <list></list>     | $\checkmark$ | Report only paths through a rising edge at the specified objects: instances, pins, or nets.                                              |
| -fall_through <list></list>     | $\checkmark$ | Report only paths through a falling edge at the specified objects: instances, pins, or nets.                                             |
| -slack_max <float></float>      | $\checkmark$ | Report only paths with slack less than this number.                                                                                      |

| Argument                   | Optional     | Description                                                                                            |
|----------------------------|--------------|--------------------------------------------------------------------------------------------------------|
| -slack_min <float></float> | $\checkmark$ | Report only paths with slack larger than this number.                                                  |
| -sort_by_slack             | ✓            | Sort paths by slack across all path groups rather than by slack grouped for each path group (default). |
| -path_group <list></list>  | $\checkmark$ | Report only paths in these groups.                                                                     |
| -format <type></type>      | $\checkmark$ | Specifies which format to report for each path. [end, full, short, summary].                           |
| -fields <list></list>      | $\checkmark$ | Report extra fields to the path report: List of input_pins nets.                                       |
| -digits <int></int>        | $\checkmark$ | Number of digits to print after the decimal point.                                                     |
| -no_line_split             | $\checkmark$ | Do not break long lines.                                                                               |
| -unconstrained             | $\checkmark$ | Report unconstrained paths.                                                                            |
| > filename                 | $\checkmark$ | Write output to file.                                                                                  |
| >> filename                | $\checkmark$ | Append output to file.                                                                                 |

# report\_clock\_properties

The report\_clock\_properties command reports the clock defined for the timer in the design.

#### Command Syntax

report\_clock\_properties

#### Table 155 Command-line Options for report\_clock\_properties

| Argument    | Optional     | Description            |
|-------------|--------------|------------------------|
| > filename  | $\checkmark$ | Write output to file.  |
| >> filename | $\checkmark$ | Append output to file. |

#### Example

| Clock Period Waveform<br>                                                                                                                | <pre>cmd&gt; report_clock_properties</pre>                                   |                                                                      |                                                                      |                                                                      |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------------------|--|--|--|
| clk[1] 2.500 0.000 1.250<br>clk[2] 2.500 0.000 1.250<br>clk[3] 2.500 0.000 1.250                                                         | Clock                                                                        | Period                                                               | Wavefo                                                               | orm                                                                  |  |  |  |
| clk[5] 2.500 0.000 1.250<br>clk[6] 2.500 0.000 1.250<br>clk[7] 2.500 0.000 1.250<br>clk[8] 2.500 0.000 1.250<br>clk[9] 2.500 0.000 1.250 | clk[1]<br>clk[2]<br>clk[3]<br>clk[4]<br>clk[5]<br>clk[6]<br>clk[7]<br>clk[8] | 2.500<br>2.500<br>2.500<br>2.500<br>2.500<br>2.500<br>2.500<br>2.500 | 0.000<br>0.000<br>0.000<br>0.000<br>0.000<br>0.000<br>0.000<br>0.000 | 1.250<br>1.250<br>1.250<br>1.250<br>1.250<br>1.250<br>1.250<br>1.250 |  |  |  |

#### reset\_sta

The reset\_sta command exits interactive timer mode. This command should be used before changing placement or routing, otherwise the STA might use stale data.

**Command Syntax** 

reset\_sta

#### Example

When in ACE interactive timing mode (slowc or fastc), to run non-timing related commands, enter the following:

cmd> reset\_sta

To switch from interactive timing mode (slowc) to (fastc), enter the following:

```
reset_sta
prepare_sta -fastc
```

# ACE Tcl Commands

The following commands are used only within ACE. These are not available within Synplify, etc.

### add\_clock\_preroute

add\_clock\_preroute <net\_name> <track\_list> [-clock\_regions <list>] [-clusters
<list>] [-placement\_regions <list>] [-partitions <list>] [-data\_region]

This command will take a clock or reset net, and constrain it to be routed it over the clock tracks specified into the clock regions, fabric clusters, partition bounding boxes, or placement regions depending on what the user specifies.

| Argument                              | Optional | Description                                                                                                                                                                                                    |
|---------------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <net_name></net_name>                 |          | The name of the clock or reset net to be pre-routed.                                                                                                                                                           |
| <track_list></track_list>             |          | The list of integer clock track numbers to pre-route this net on. Valid clock track numbers are device-specific.                                                                                               |
| [-clock_regions <list>]</list>        | Υ        | The list of clock region names to pre-route this net into.<br>Valid clock region names are device-specific.                                                                                                    |
| [-clusters <list>]</list>             | Υ        | The list of cluster names to pre-route this net into. Valid cluster names are device-specific.                                                                                                                 |
| [-placement_regions<br><list>]</list> | Υ        | The list of placement region names to pre-route this net into. Valid placement region names are device-specific.                                                                                               |
| [-partitions <list>]</list>           | Y        | The list of partition names to pre-route this net into.<br>Valid partition are device-specific.                                                                                                                |
| [-data_region]                        | Y        | The -data_region option is only valid for non-clock nets.<br>You can optionally use -data_region to route the net<br>using region resources. "data_center" is applied by<br>default if this option isn't used. |

### add\_project\_constraints

add\_project\_constraints <file> [-project <string>] [-corner <string>] [temperature <string>] [-voltage <string>]

This command adds a link to an SDC, PDC, or TCL constraint file to a project.

| Argument                         | Optional | Description                                                                                                                                                                                                                                                                                       |
|----------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <file></file>                    |          | The required <file> argument is used to specify the file path to the SDC, PDC, or TCL constraint file.</file>                                                                                                                                                                                     |
| [-project <string>]</string>     | Υ        | The optional -project <projectname> option is used to specify an alternate project (by name) for the SDC constraint file to be added to.</projectname>                                                                                                                                            |
| [-corner <string>]</string>      | Y        | The optional -corner <corner> option is used to mark an SDC constraints file (containing only delays) as being applicable only to the given process corner. Valid values are "fast" and "slow"</corner>                                                                                           |
| [-temperature <string>]</string> | Υ        | The optional -temperature <temp> option is used to mark<br/>an SDC constraints file (containing only delays) as being<br/>applicable only to the given temperature corner. Valid<br/>values are device-specific and must match a value from<br/>the junction_temperature impl option list.</temp> |
| [-voltage <string>]</string>     | Υ        | The optional -voltage <v> option is used to mark an SDC constraints file (containing only delays) as being applicable only to the given core voltage corner. Valid values are device-specific and must match a value from the core_voltage impl option list.</v>                                  |

After a project has been created, you can point to a constraint file (SDC or PDC) using the following command. In this example, there is an existing file located at .../constraints/top.sdc:

add\_project\_constraints -project [get\_active\_project] "../constraints/top.sdc"

#### Also See

```
create_project (page 623)
get_active_project (page 643)
```

### add\_project\_ip

add\_project\_ip <list\_of\_files> [-project <string>]
This command associates one or more IP settings files with a project.

| Argument                        | Optional | Description                                                                                                                                                                                                      |
|---------------------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <list_of_files></list_of_files> |          | The required <list_of_files> argument is used to specify<br/>the file paths to the IP settings files. The file paths may be<br/>absolute, or may be relative to the acxprj file's directory.</list_of_files>     |
| [-project <string>]</string>    | Y        | The optional -project <projectname> option is used to<br/>specify an alternate project (by name) for the IP settings<br/>file to be added to. The named project must already be<br/>opened in ACE.</projectname> |

### add\_project\_netlist

# add\_project\_netlist <file> [-project <string>] [-impl <string>]

This command adds a link to a verilog netlist file to a project.

| Argument                     | Optional | Description                                                                                                                                                  |
|------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <file></file>                |          | The required <file> argument is used to specify the file path to the verilog netlist.</file>                                                                 |
| [-project <string>]</string> | Y        | The optional -project <projectname> option is used to specify an alternate project (by name) for the verilog netlist to be added to.</projectname>           |
| [-impl <string>]</string>    | Y        | The optional -impl <implname> options is used to select an alternate netlist for a different impl, i.e. due to varied synthesis tools or options.</implname> |

# add\_project\_source\_files

```
add_project_source_files <list_of_files> [-project <string>] [-ip] [-rtl] [-
syn_constraint] [-pnr_constraint] [-pnr_netlist] [-sim_tb] [-impl <string>] [-
corner <string>] [-temperature <string>] [-voltage <string>]
```

This command adds a link to one or more source files to a project.

| Argument                        | Optional | Description                                                                                                                                    |
|---------------------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------|
| <list_of_files></list_of_files> |          | The required <list_of_files> argument is used to specify the file paths to source files.</list_of_files>                                       |
| [-project <string>]</string>    | Y        | The optional -project <projectname> option is used to specify an alternate project (by name) for the source file to be added to.</projectname> |

| Argument                         | Optional | Description                                                                                                                                                                                                                                                                                                      |
|----------------------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-ip]                            | Y        | The optional -ip option is used to specify the source file to be added is an IP settings file.                                                                                                                                                                                                                   |
| [-rtl]                           | Υ        | The optional -rtl option is used to specify the source file to be added is an RTL file.                                                                                                                                                                                                                          |
| [-syn_constraint]                | Υ        | The optional -syn_constraint option is used to specify the source file to be added is a synthesis constraint file.                                                                                                                                                                                               |
| [-pnr_constraint]                | Y        | The optional -pnr_constraint option is used to specify the source file to be added is a place and route constraint file.                                                                                                                                                                                         |
| [-pnr_netlist]                   | Y        | The optional -pnr_netlist option is used to specify the source file to be added is a place and route netlist file.                                                                                                                                                                                               |
| [-sim_tb]                        | Y        | The optional -sim_tb option is used to specify the source file to be added is a simulation testbench file.                                                                                                                                                                                                       |
| [-impl <string>]</string>        | Υ        | The optional -impl <implname> option is used to select an alternate netlist for a different impl, i.e. due to varied synthesis tools or options. This option can only be used with "-pnr_netlist"</implname>                                                                                                     |
| [-corner <string>]</string>      | Υ        | The optional -corner <corner> option is used to mark a place and route SDC constraints file (containing only delays) as being applicable only to the given process corner. Valid values are "fast" and "slow"</corner>                                                                                           |
| [-temperature <string>]</string> | Υ        | The optional -temperature <temp> option is used to mark a<br/>place and route SDC constraints file (containing only<br/>delays) as being applicable only to the given temperature<br/>corner. Valid values are device-specific and must match a<br/>value from the junction_temperature impl option list.</temp> |
| [-voltage <string>]</string>     | Y        | The optional -voltage <v> option is used to mark a place<br/>and route SDC constraints file (containing only delays) as<br/>being applicable only to the given core voltage corner. Valid<br/>values are device-specific and must match a value from<br/>the core_voltage impl option list.</v>                  |

# add\_region\_find\_insts

add\_region\_find\_insts <region> <find\_command> [-flops\_only] [-clocks\_only] [include\_constants] [-batch] [-verbose]

Add user design instances to a placement region constraint using a find command

| Argument                      | Optional | Description                                                                                                                                                                                                                       |
|-------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <region></region>             |          | Name of the region                                                                                                                                                                                                                |
| <find_command></find_command> |          | Find command used to get list of user design instances                                                                                                                                                                            |
| [-flops_only]                 | Y        | When adding instances, filter out all instances except flops                                                                                                                                                                      |
| [-clocks_only]                | Y        | When adding instances, filter out all instances with no connected clock                                                                                                                                                           |
| [-include_constants]          | Y        | When adding instances, do not filter out power/ground constants                                                                                                                                                                   |
| [-batch]                      | Y        | Postpone application of this constraint until<br>apply_placement is called (this avoids frequent GUI<br>updates). This option is only relevant if you manually apply<br>placement constraints after the design has been prepared. |
| [-verbose]                    | Y        | Print additional command status messages.                                                                                                                                                                                         |

# add\_region\_insts

add\_region\_insts <region> <insts> [-flops\_only] [-clocks\_only] [include\_constants] [-batch] [-verbose]

#### Add user design instances to a placement region constraint

| Argument             | Optional | Description                                                                                                                                                                                                                       |
|----------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <region></region>    |          | Name of the region                                                                                                                                                                                                                |
| <insts></insts>      |          | List of user design instances                                                                                                                                                                                                     |
| [-flops_only]        | Y        | When adding instances, filter out all instances except flops                                                                                                                                                                      |
| [-clocks_only]       | Y        | When adding instances, filter out all instances with no connected clock                                                                                                                                                           |
| [-include_constants] | Y        | When adding instances, do not filter out power/ground constants                                                                                                                                                                   |
| [-batch]             | Y        | Postpone application of this constraint until<br>apply_placement is called (this avoids frequent GUI<br>updates). This option is only relevant if you manually apply<br>placement constraints after the design has been prepared. |

| Argument   | Optional | Description                               |
|------------|----------|-------------------------------------------|
| [-verbose] | Y        | Print additional command status messages. |

## apply\_highlights

apply\_highlights [-insts] [-nets] [-paths]

This command updates the GUI with highlighting information on the present design.

| Argument | Optional | Description                                        |
|----------|----------|----------------------------------------------------|
| [-insts] | Y        | Update highlighting of all instances in the design |
| [-nets]  | Y        | Update highlighting of all nets in the design      |
| [-paths] | Y        | Update highlighting of all paths in the design     |

### apply\_placement

apply\_placement [-batch] [-defparams] [-partition] [-nocomplain]
Apply batched pre-placement commands

| Argument      | Optional | Description                                                                                            |
|---------------|----------|--------------------------------------------------------------------------------------------------------|
| [-batch]      | Y        | Specifies that placement should be applied from batched placement commands                             |
| [-defparams]  | Υ        | Specifies that placement should be applied from defparams                                              |
| [-partition]  | Υ        | Specifies that placement should be applied on partition anchor instances before calling move_partition |
| [-nocomplain] | Υ        | Batched placement that does not yet apply is kept in the batch list and ignored                        |

# check\_project\_status

#### check\_project\_status [-rtl\_sim] [-syn] [-prepare]

This command checks if any project source files have changed since running the prepare flow step on the active implementation. If the source files are consistent, no message is printed. Otherwise, warnings are printed for each out of sync file.

| Argument   | Optional | Description                                               |
|------------|----------|-----------------------------------------------------------|
| [-rtl_sim] | Y        | Check cached source files during rtl simulation flowstep. |
| [-syn]     | Y        | Check cached source files during synthesis flowstep.      |
| [-prepare] | Y        | Check cached source files during prepare flowstep.        |

### clean\_project

#### clean\_project [-project <string>] [-impl\_names <list>]

This command deletes output files from multiple implementations on the file system. The implementations' output directories on the file system are not deleted.

| Argument                     | Optional | Description                                                                                                                                                                                                                                                          |
|------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-project <string>]</string> | Y        | The optional -project <projectname> option is used to<br/>specify an alternate project (by name) from which the<br/>implementations' output files will be removed. If no<br/>projectName is specified, the active project will be used by<br/>default.</projectname> |
| [-impl_names <list>]</list>  | Y        | The optional -impl_names <list> argument is used to<br/>specify the names of the implementations to remove. If no<br/>list is specified, the output files for all implementations<br/>under the project will be deleted.</list>                                      |

#### clear\_arcs

#### clear\_arcs [-id <int>]

This command allows you to clear a custom arc or all the arcs on the GUI's Floorplanner view.

| Argument          | Optional | Description                                                                                                                              |
|-------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------|
| [-id <int>]</int> | Y        | The optional -id <id> option specifies a unique id for a single arc to clear. If this option is not used, all arcs will be cleared.</id> |

# clear\_drawing

#### clear\_drawing

This command clears the current custom drawing on the GUI's Floorplanner view.

### clear\_flow

#### clear\_flow

This command clears user design DB and the completion status of all flow steps.

### clear\_lines

clear\_lines [-id <int>]

This command allows you to clear a custom line or all the lines on the GUI's Floorplanner view.

| Argument          | Optional | Description                                                                                                                                        |
|-------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| [-id <int>]</int> | Υ        | The optional -id <id> option specifies a unique id for a single<br/>line to clear. If this option is not used, all lines will be<br/>cleared.</id> |

### clear\_ovals

#### clear\_ovals [-id <int>]

This command allows you to clear a custom oval or all the ovals on the GUI's Floorplanner view.

| Argument          | Optional | Description                                                                                                                                        |
|-------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| [-id <int>]</int> | Υ        | The optional -id <id> option specifies a unique id for a single<br/>oval to clear. If this option is not used, all ovals will be<br/>cleared.</id> |

## clear\_polygons

```
clear_polygons [-id <int>]
```

This command allows you to clear a custom polygon or all the polygons on the GUI's Floorplanner view.

| Argument          | Optional | Description                                                                                                                                      |
|-------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| [-id <int>]</int> | Υ        | The optional -id <id> option specifies a unique id for a single polygon to clear. If this option is not used, all polygons will be cleared.</id> |

## clear\_rectangles

#### clear\_rectangles [-id <int>]

This command allows you to clear a custom rectangle or all the rectangles on the GUI's Floorplanner view.

| Argument          | Optional | Description                                                                                                                                          |
|-------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-id <int>]</int> | Y        | The optional -id <id> option specifies a unique id for a single rectangle to clear. If this option is not used, all rectangles will be cleared.</id> |

### clear\_strings

#### clear\_strings [-id <int>]

This command allows you to clear a custom string or all the strings on the GUI's Floorplanner view.

| Argument          | Optional | Description                                                                                                                                    |
|-------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------|
| [-id <int>]</int> | Y        | The optional -id <id> option specifies a unique id for a single string to clear. If this option is not used, all strings will be cleared.</id> |

### clock\_info

clock\_info [-domain <string>] [-pin <string>] [-net <string>] [-all] [-unique] [multi] [-freq] [-period] [-phase] [-edge\_type] [-routing\_props] [-core] [-driver] [-clock\_net] [-is\_clock] [-info] [-group] [-equal] [-names] [-sdc]

Return information from the clock database. If a domain is specified, by default the name of the domain is returned. If no domain is specified, by default a list of domains is returned. Options may modify the type of value that is returned.

| Argument                    | Optional | Description                                                            |
|-----------------------------|----------|------------------------------------------------------------------------|
| [-domain <string>]</string> | Y        | specifies name of domain                                               |
| [-pin <string>]</string>    | Y        | use the domain of this pin                                             |
| [-net <string>]</string>    | Y        | use the domain of this net                                             |
| [-all]                      | Y        | even report uninteresting domains                                      |
| [-unique]                   | Y        | use a unique domain for domains with the same frequency                |
| [-multi]                    | Y        | with -net or -pin: report a list of domains instead of a single domain |
| [-freq]                     | Y        | return the frequency (MHz); requires a domain                          |

| Argument         | Optional | Description                                                                    |
|------------------|----------|--------------------------------------------------------------------------------|
| [-period]        | Y        | return the period (ps); requires a domain                                      |
| [-phase]         | Y        | return the phase; requires a domain                                            |
| [-edge_type]     | Y        | 1 for pos-edge, -1 for neg-edge, 0 for combinational; requires a domain        |
| [-routing_props] | Υ        | list of strings denoting the routing properties (if set);<br>requires a domain |
| [-core]          | Y        | 1 if used in the core, otherwise 0; or list of domains used in core            |
| [-driver]        | Y        | name of the driving pin or port; requires a domain                             |
| [-clock_net]     | Y        | name of the clock net; requires a domain                                       |
| [-is_clock]      | Y        | true if net is a clock net; requires a pin or net                              |
| [-info]          | Y        | list as for 'array set'; requires a domain                                     |
| [-group]         | Y        | list of related domains, or list of groups                                     |
| [-equal]         | Y        | list of domains with same frequency; requires a domain                         |
| [-names]         | Y        | list of all names for the domain; requires a domain                            |
| [-sdc]           | Y        | return list of sdc commands                                                    |

### clock\_relation

#### clock\_relation <domain1> <domain2> [-default] [-group] [-sdc]

Return relation between clocks. For related clocks the return is a list with 5 values: the word "related" followed by T1 T2 e1 e2. T is the abstract period: T1/T2 = period1/period2. e is an abstract offset (in the same units as T). By default the numbers are as small as possible, but with -group all related clocks use the same units.

| Argument            | Optional | Description   |
|---------------------|----------|---------------|
| <domain1></domain1> |          | first domain  |
| <domain2></domain2> |          | second domain |

| Argument   | Optional | Description                         |
|------------|----------|-------------------------------------|
| [-default] | Y        | apply current default_relation rule |
| [-group]   | Y        | values are in group units           |
| [-sdc]     | Y        | return list of sdc commands         |

# create\_boundary\_pins

create\_boundary\_pins <name> <boundary\_pin\_names> [-clock] [-data] [-purpose
<string>]

This command instantiates IPIN/OPINs at the Core/IO Ring boundary

| Argument                                  | Optional | Description                                                                                                                                                                                           |
|-------------------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <name></name>                             |          | A reference to a net in the design where the boundary<br>pins should be inserted ( <p:toplevel_portname>  <br/><t:user_pin_name>   <n:net_name>)</n:net_name></t:user_pin_name></p:toplevel_portname> |
| <boundary_pin_names></boundary_pin_names> |          | A list of one or more instance names for the boundary pins to be inserted on the given net                                                                                                            |
| [-clock]                                  | Y        | Create a clock pin even if the specified net is a data net                                                                                                                                            |
| [-data]                                   | Y        | Create a data pin even if the specified net is a clock net                                                                                                                                            |
| [-purpose <string>]</string>              | Υ        | Set the PURPOSE property on the created boundary pin<br>instances. Legal values are: 'USER' (the default), 'JTAG',<br>'CFG'.                                                                          |

### create\_equivalent\_regions

#### create\_equivalent\_regions <source>

Create non-overlapping placement regions which have the same tiles in the same order as the provided <source>

| Argument  | Optional | Description                                              |
|-----------|----------|----------------------------------------------------------|
| <source/> |          | Name of the source. May be a region or a partition name. |

## create\_flow\_step

# create\_flow\_step <id> <label> [-command <string>] [-parent\_id <string>] [required] [-skip\_for\_eval\_mode] [-offset <int>] [-description <string>]

This command creates a flow step definition, which is basically a wrapper around an existing command or script that manages flow status and dependencies.

| Argument                         | Optional | Description                                                                                                                                                                                                                                                                                                                    |
|----------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <id></id>                        |          | The required <id> string argument specifies the identifier<br/>of the flow step to create. The <id> argument must be<br/>unique among all flow step ids in ACE. Run get_flow_steps<br/>for a list of existing flow step IDs.</id></id>                                                                                         |
| <label></label>                  |          | The required <label> argument specifies the label string to display in the GUI for this flow step. The label should be as short as possible.</label>                                                                                                                                                                           |
| [-command <string>]</string>     | Υ        | The optional -command <command/> option specifies the TCL command to run when this flow step is invoked.                                                                                                                                                                                                                       |
| [-parent_id <string>]</string>   | Υ        | The optional -parent_id <parentld> option specifies the<br/>flow step id of an existing flow step (which does not have a<br/>command of its own) that this new flow step will be<br/>grouped under in the flow hierarchy. Run get_flow_steps<br/>for a list of existing flow step IDs.</parentld>                              |
| [-required]                      | Y        | The optional -required option specifies whether or not this<br>flow step is required for further processing of the flow. If<br>this option is not used, the user may optionally enable or<br>disable this flow step for use in running the flow with<br>run_flow.                                                              |
| [-skip_for_eval_mode]            | Y        | The optional -skip_for_eval_mode option specifies whether or not this flow step will be skipped when flow_mode is set to evaluation.                                                                                                                                                                                           |
| [-offset <int>]</int>            | Υ        | The optional -offset <offset> option specifies the position<br/>(as a positive integer) under the parent flow step (or top<br/>level) at which this flow step should be inserted. Without<br/>this option, the flow step will be appended to the end of the<br/>flow steps under the parent flow step (or top level).</offset> |
| [-description <string>]</string> | Υ        | The optional -description <description> option specifies the description text to display in the GUI for this flow step.</description>                                                                                                                                                                                          |

10.1

### create\_impl

#### create\_impl <implName> [-project <string>] [-copy] [-not\_active]

This command creates a new implementation in a project. This command causes the new implementation to become the active implementation.

| Argument                     | Optional | Description                                                                                                                                       |
|------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| <implname></implname>        |          | The required <implname> argument is used to specify the name for the new implementation.</implname>                                               |
| [-project <string>]</string> | Y        | The optional -project <projectname> option is used to specify an alternate project (by name) for the implementation to be added to.</projectname> |
| [-copy]                      | Y        | The optional -copy option is used to copy the implementation options of the active implementation into the newly created implementation.          |
| [-not_active]                | Y        | If this option is set, the new project impl will not be<br>activated and the active impl in the current ACE session<br>will not be changed.       |

### create\_option\_sets

```
create_option_sets [-path <string>] [-device <string>] [-max_option_sets <int>] [-
prepare_impl_options <int>] [-pnr_impl_options <int>] [-exclude_synthesis] [-init]
[-verbose]
```

This command creates new option sets for a project implementation.

| Argument                                  | Optional | Description                                                       |
|-------------------------------------------|----------|-------------------------------------------------------------------|
| [-path <string>]</string>                 | Y        | The path to write to                                              |
| [-device <string>]</string>               | Y        | The Achronix device name                                          |
| <pre>[-max_option_sets <int>]</int></pre> | Υ        | The number of autogen option sets to create.<br>Default is 26.    |
| [-prepare_impl_options<br><int>]</int>    | Y        | The number of prepare impl options to add per option set.         |
| [-pnr_impl_options <int>]</int>           | Y        | The number of place and route impl options to add per option set. |
| [-exclude_synthesis]                      | Y        | Do not sweep over synthesis options                               |

| Argument   | Optional | Description                                         |
|------------|----------|-----------------------------------------------------|
| [-init]    | Y        | re-create the <path> to write option sets to</path> |
| [-verbose] | Y        | print exactly what is being done                    |

#### create\_path

#### create\_path <pins> [-id <string>] [-rgb <list>]

This command creates a user-defined pin path that may be used for selection or highlighting.

| Argument                | Optional | Description                                                                                                                                                                                                                                                                                       |
|-------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pins></pins>           |          | The required <pins> list argument specifies the ordered list of instance pins.</pins>                                                                                                                                                                                                             |
| [-id <string>]</string> | Y        | The optional -id <id> option specifies the string id to use for this path. If an id is not specified, a unique id will be automatically generated.</id>                                                                                                                                           |
| [-rgb <list>]</list>    | Y        | The optional -rgb <rgb> option is used to specify the RGB<br/>(Red-Green-Blue) color value to use for highlighting the<br/>specified objects as a 3 element list of integers {red green<br/>blue}. If the -rgb option is not used, then the objects in the list<br/>will be un-highlighted.</rgb> |

### create\_project

#### create\_project <projectFile> [-impl <string>] [-not\_active]

This command creates a new project in ACE.

| Argument                    | Optional | Description                                                                                                                                                             |
|-----------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <projectfile></projectfile> |          | The required <projectfile> argument is used to specify the project file location for the new project. The file name is used as the project's name in ACE.</projectfile> |
| [-impl <string>]</string>   | Υ        | The optional -impl <implname> option is used to specify the name of the initial implementation for this new project.</implname>                                         |
| [-not_active]               | Υ        | If this option is set, the new project impl will not be<br>activated and the active impl in the current ACE session<br>will not be changed.                             |

### create\_region

create\_region <name> <bounds> [-find\_insts <string>] [-insts <list>] [snap\_to\_clock\_regions] [-snap\_to\_fabric\_clusters] [-snap <string>] [-soft] [-type
<string>] [-flops\_only] [-clocks\_only] [-include\_routing] [-include\_constants] [pr\_zone] [-batch] [-verbose]

This command creates a placement region in the Core with the given name and bounding box of tiles. Instances may be added to this placement region to create a region constraint for the placer.

| Argument                           | Optional | Description                                                                                                                                                                                           |
|------------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <name></name>                      |          | Name of the region                                                                                                                                                                                    |
| <bounds></bounds>                  |          | List of bounding box coordinates {x1 y1 x2 y2}. x1 and y1 are<br>the upper left corner of the box. x2 and y2 are the lower right<br>corner of the box. Alternatively, a list of sites.                |
| [-find_insts <string>]</string>    | Y        | Pass in a find command string to create the list of user design<br>instances to constrain into this region's bounding box for the<br>placer.                                                          |
| [-insts <list>]</list>             | Y        | List of user design instances to constrain into this region's bounding box for the placer.                                                                                                            |
| [-<br>snap_to_clock_regions]       | Y        | Snap the bounding box to clock region boundaries (deprecated, use '-snap clock_regions')                                                                                                              |
| [-<br>snap_to_fabric_cluster<br>s] | Y        | Snap the bounding box to fabric cluster boundaries (deprecated, use '-snap fabric_clusters')                                                                                                          |
| [-snap <string>]</string>          | Y        | How to snap the region bounding box coordinates. Legal values are: 'none', 'tiles' (the default), 'fabric_clusters', 'clock_regions'.                                                                 |
| [-soft]                            | Y        | Create a 'soft' placement region, which attempts to pull<br>instance placement to its center, but allows instance<br>placement to overflow the bounds of the region (deprecated,<br>use '-type soft') |

| Argument                  | Optional | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-type <string>]</string> | Y        | What type of placement region this is. Legal values are:<br>'inclusive' (the default), 'keepout', 'soft'. Instances added to an<br>'inclusive' region (and attached routing wires when '-<br>include_routing' is set) will be placed within the region<br>bounding box. An 'inclusive' region permits instances to be<br>placed inside the region even if they do not belong to the<br>region. A 'keepout' region prevents any instances (and routing<br>wires when '-include_routing is set) from being placed inside<br>the region. No instances may be added to a 'keepout' region.<br>Instances added to an 'soft' region will be pulled toward the<br>region's center during placement, but instances are permitted<br>to overflow the bounds of the 'soft' region. |
| [-flops_only]             | Y        | When adding instances, filter out all instances except flops                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [-clocks_only]            | Y        | When adding instances, filter out all instances that do not have a connected clock pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [-include_routing]        | Y        | Constrain routing wires, as well as instances, to stay within the region boundary box                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [-include_constants]      | Y        | When adding instances, do not filter out power/ground constants                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [-pr_zone]                | Y        | This will indicate that the placement region is intended to be used for partial reconfiguration.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [-batch]                  | Υ        | Postpone application of this constraint until apply_placement<br>is called (this avoids frequent GUI updates). This option is only<br>relevant if you manually apply placement constraints after the<br>design has been prepared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [-verbose]                | Y        | Print additional command status messages.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

### deselect

deselect [-objects <list>]

This command removes objects from the current list of selected objects.

| Argument                 | Optional | Description                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-objects <list>]</list> | Υ        | The optional -objects <objects> option is used to specify a list<br/>of objects to remove from the current selection. Objects must<br/>be prepended with object type prefixes (see "find" command).<br/>Objects in the <objects> list that are not in the current<br/>selection are silently ignored. Without this option, the<br/>deselect command will remove all objects from the current<br/>selection.</objects></objects> |

# disable\_flow\_step

#### disable\_flow\_step <id>

This command disables an existing optional flow step from being run during a "run" command.

| Argument  | Optional | Description                                                                   |
|-----------|----------|-------------------------------------------------------------------------------|
| <id></id> |          | The required <id> argument specifies the id of the flow step to disable.</id> |

### disable\_project\_constraints

#### disable\_project\_constraints [-project <string>] [-impl <string>] <file>

This command disables project constraints files for a project implementation. If no project or impl names are specified, the currently active project implementation is used.

| Argument                     | Optional | Description                                                                                                                                                                                         |
|------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-project <string>]</string> | Y        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to disable constraints<br/>for.</implname></projectname> |
| [-impl <string>]</string>    | Y        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to disable constraints<br/>for.</implname></projectname> |
| <file></file>                |          | The project constraints file to disable for a project implementation.                                                                                                                               |

# disable\_project\_source\_file

# disable\_project\_source\_file <file> [-syn\_constraint] [-pnr\_constraint] [pnr\_netlist] [-project <string>] [-impl <string>]

This command disables project source files for a project implementation. If no project or impl names are specified, the currently active project implementation is used.

| Argument                     | Optional | Description                                                                                                                                                                                        |
|------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <file></file>                |          | The project constraints file to disable for a project implementation.                                                                                                                              |
| [-syn_constraint]            | Y        | The optional -syn_constraint option is used to specify the source file to be disabled is a synthesis constraint file.                                                                              |
| [-pnr_constraint]            | Y        | The optional -pnr_constraint option is used to specify the source file to be disabled is a place and route constraint file.                                                                        |
| [-pnr_netlist]               | Y        | The optional -pnr_netlist option is used to specify the source file to be disabled is a place and route netlist file.                                                                              |
| [-project <string>]</string> | Y        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to enable source file<br/>for.</implname></projectname> |
| [-impl <string>]</string>    | Y        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to enable source file<br/>for.</implname></projectname> |

### display\_file

#### display\_file <file> [-line\_number <int>] [-search <string>]

This command automatically opens a file in the GUI. This command has no effect in batch mode.

| Argument                   | Optional | Description                                                                                                              |
|----------------------------|----------|--------------------------------------------------------------------------------------------------------------------------|
| <file></file>              |          | The required <file> argument specifies the path to the file to automatically open in the GUI (when in -gui mode).</file> |
| [-line_number <int>]</int> | Υ        | The optional -line_number option allows you to open a text file to a particular line.                                    |

| Argument                    | Optional | Description                                                                                                |
|-----------------------------|----------|------------------------------------------------------------------------------------------------------------|
| [-search <string>]</string> | Υ        | The optional -search option allows you to open a text file to the first line where the searchtext appears. |

# display\_netlist

#### display\_netlist <object>

This command attempts to open the gate level netlist file in the GUI for the given user design instance or net. This command has no effect when ACE is running in batch mode.

| Argument          | Optional | Description                                                                                                                                        |
|-------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| <object></object> |          | The required <object> argument specifies the instance (i:) or<br/>net (n:) name for which the netlist file will be opened in the<br/>GUI.</object> |

### display\_properties

#### display\_properties <object> [-print]

This command displays detailed properties of the specified object in the GUI, and optionally prints the details to the console.

| Argument          | Optional | Description                                                                                                                 |
|-------------------|----------|-----------------------------------------------------------------------------------------------------------------------------|
| <object></object> |          | The required <object> argument specifies the object to get properties for.</object>                                         |
| [-print]          | Υ        | The -print option will print all the object property details to the TCL console in addition to sending the data to the GUI. |

### draw\_arc

draw\_arc <x> <y> <width> <height> <startAngle> <arcAngle> [-layer <int>] [-id <int>] [-rgb <list>] [-batch] [-thickness <int>] [-fill]

This command allows you to draw a custom arc on the GUI's Floorplanner view.

| Argument | Optional | Description                                                                      |
|----------|----------|----------------------------------------------------------------------------------|
| <x></x>  |          | The required <x> argument specifies the upper-left x coordinate for the arc.</x> |

| Argument                  | Optional | Description                                                                                                                                                                                                 |
|---------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <y></y>                   |          | The required <y> argument specifies the upper-left y coordinate for the arc.</y>                                                                                                                            |
| <width></width>           |          | The required <width> argument specifies the width of the arc.</width>                                                                                                                                       |
| <height></height>         |          | The required <height> argument specifies the height of the arc.</height>                                                                                                                                    |
| <startangle></startangle> |          | The required <startangle> argument specifies the starting angle of the arc.</startangle>                                                                                                                    |
| <arcangle></arcangle>     |          | The required <arcangle> argument specifies the angle of the arc.</arcangle>                                                                                                                                 |
| [-layer <int>]</int>      | Y        | The optional -layer <layer> option specifies the drawing<br/>layer for the arc. If this option is not used, the top layer (5)<br/>will be used. Using a value of 0 will draw on the<br/>background.</layer> |
| [-id <int>]</int>         | Y        | The optional -id <id> option specifies a unique id for the arc. If this option is not used, a unique id will be automatically generated and returned by the command.</id>                                   |
| [-rgb <list>]</list>      | Y        | The optional -rgb <rgb> option specifies the rgb color<br/>value for the arc as a 3 element list of integers {red green<br/>blue}. If this option is not used, the color blue will be used.</rgb>           |
| [-batch]                  | Y        | The optional -batch option causes the GUI to not refresh<br>after this command. This is useful when running many<br>draw commands in a row. Afterwards, refresh_drawing<br>can be called.                   |
| [-thickness <int>]</int>  | Y        | The optional -thickness <pixels> option specifies the arc<br/>thickness in pixels. If this option is not used, a thickness of<br/>1 will be used.</pixels>                                                  |
| [-fill]                   | Y        | The optional -fill option specifies whether the arc should<br>be filled with color or not. If this option is not used, the arc<br>will be hollow.                                                           |

# draw\_line

draw\_line <x1> <y1> <x2> <y2> [-layer <int>] [-id <int>] [-rgb <list>] [-batch] [thickness <int>] This command allows you to draw a custom line on the GUI's Floorplanner view.

| Argument                 | Optional | Description                                                                                                                                                                                                  |
|--------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <x1></x1>                |          | The required <x1> argument specifies the first x coordinate for the line.</x1>                                                                                                                               |
| <y1></y1>                |          | The required <y1> argument specifies the first y coordinate for the line.</y1>                                                                                                                               |
| <x2></x2>                |          | The required <x2> argument specifies the second x coordinate for the line.</x2>                                                                                                                              |
| <y2></y2>                |          | The required <y2> argument specifies the second y coordinate for the line.</y2>                                                                                                                              |
| [-layer <int>]</int>     | Y        | The optional -layer <layer> option specifies the drawing<br/>layer for the line. If this option is not used, the top layer (5)<br/>will be used. Using a value of 0 will draw on the<br/>background.</layer> |
| [-id <int>]</int>        | Y        | The optional -id <id> option specifies a unique id for the<br/>line. If this option is not used, a unique id will be<br/>automatically generated and returned by the command.</id>                           |
| [-rgb <list>]</list>     | Y        | The optional -rgb <rgb> option specifies the rgb color<br/>value for the line as a 3 element list of integers {red green<br/>blue}. If this option is not used, the color blue will be used.</rgb>           |
| [-batch]                 | Y        | The optional -batch option causes the GUI to not refresh<br>after this command. This is useful when running many<br>draw commands in a row. Afterwards, refresh_drawing<br>can be called.                    |
| [-thickness <int>]</int> | Υ        | The optional -thickness <pixels> option specifies the line thickness in pixels. If this option is not used, a thickness of 1 will be used.</pixels>                                                          |

### draw\_oval

draw\_oval <x> <y> <width> <height> [-layer <int>] [-id <int>] [-rgb <list>] [batch] [-thickness <int>] [-fill]

This command allows you to draw a custom oval on the GUI's Floorplanner view.

| Argument                 | Optional | Description                                                                                                                                                                                                  |
|--------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <x></x>                  |          | The required <x> argument specifies the upper-left x coordinate for the oval.</x>                                                                                                                            |
| <y></y>                  |          | The required <y> argument specifies the upper-left y coordinate for the oval.</y>                                                                                                                            |
| <width></width>          |          | The required <width> argument specifies the width of the oval.</width>                                                                                                                                       |
| <height></height>        |          | The required <height> argument specifies the height of the oval.</height>                                                                                                                                    |
| [-layer <int>]</int>     | Y        | The optional -layer <layer> option specifies the drawing<br/>layer for the oval. If this option is not used, the top layer (5)<br/>will be used. Using a value of 0 will draw on the<br/>background.</layer> |
| [-id <int>]</int>        | Y        | The optional -id <id> option specifies a unique id for the oval. If this option is not used, a unique id will be automatically generated and returned by the command.</id>                                   |
| [-rgb <list>]</list>     | Y        | The optional -rgb <rgb> option specifies the rgb color<br/>value for the oval as a 3 element list of integers {red green<br/>blue}. If this option is not used, the color blue will be used.</rgb>           |
| [-batch]                 | Y        | The optional -batch option causes the GUI to not refresh<br>after this command. This is useful when running many<br>draw commands in a row. Afterwards, refresh_drawing<br>can be called.                    |
| [-thickness <int>]</int> | Y        | The optional -thickness <pixels> option specifies the oval thickness in pixels. If this option is not used, a thickness of 1 will be used.</pixels>                                                          |
| [-fill]                  | Y        | The optional -fill option specifies whether the oval should<br>be filled with color or not. If this option is not used, the oval<br>will be hollow.                                                          |

# draw\_polygon

draw\_polygon <points> [-layer <int>] [-id <int>] [-rgb <list>] [-batch] [thickness <int>] [-fill]

This command allows you to draw a custom polygon on the GUI's Floorplanner view.

| Argument                 | Optional | Description                                                                                                                                                                                                 |
|--------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <points></points>        |          | The required <points> argument specifies the list of x-y coordinates for polygon, starting with the x coordinate and alternating. For example: {11223516}.</points>                                         |
| [-layer <int>]</int>     | Y        | The optional -layer <layer> option specifies the drawing<br/>layer for the arc. If this option is not used, the top layer (5)<br/>will be used. Using a value of 0 will draw on the<br/>background.</layer> |
| [-id <int>]</int>        | Y        | The optional -id <id> option specifies a unique id for the arc. If this option is not used, a unique id will be automatically generated and returned by the command.</id>                                   |
| [-rgb <list>]</list>     | Y        | The optional -rgb <rgb> option specifies the rgb color<br/>value for the polygon as a 3 element list of integers {red<br/>green blue}. If this option is not used, the color blue will be<br/>used.</rgb>   |
| [-batch]                 | Y        | The optional -batch option causes the GUI to not refresh<br>after this command. This is useful when running many<br>draw commands in a row. Afterwards, refresh_drawing<br>can be called.                   |
| [-thickness <int>]</int> | Y        | The optional -thickness <pixels> option specifies the arc<br/>thickness in pixels. If this option is not used, a thickness of<br/>1 will be used.</pixels>                                                  |
| [-fill]                  | Y        | The optional -fill option specifies whether the arc should<br>be filled with color or not. If this option is not used, the arc<br>will be hollow.                                                           |

## draw\_rectangle

draw\_rectangle <x> <y> <width> <height> [-layer <int>] [-id <int>] [-rgb <list>]
[-batch] [-thickness <int>] [-fill]

This command allows you to draw a custom rectangle on the GUI's Floorplanner view.

| Argument | Optional | Description                                                                            |
|----------|----------|----------------------------------------------------------------------------------------|
| <x></x>  |          | The required <x> argument specifies the upper-left x coordinate for the rectangle.</x> |
| <y></y>  |          | The required <y> argument specifies the upper-left y coordinate for the rectangle.</y> |

| Argument                 | Optional | Description                                                                                                                                                                                                       |
|--------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <width></width>          |          | The required <width> argument specifies the width of the rectangle.</width>                                                                                                                                       |
| <height></height>        |          | The required <height> argument specifies the height of the rectangle.</height>                                                                                                                                    |
| [-layer <int>]</int>     | Y        | The optional -layer <layer> option specifies the drawing<br/>layer for the rectangle. If this option is not used, the top<br/>layer (5) will be used. Using a value of 0 will draw on the<br/>background.</layer> |
| [-id <int>]</int>        | Y        | The optional -id <id> option specifies a unique id for the rectangle. If this option is not used, a unique id will be automatically generated and returned by the command.</id>                                   |
| [-rgb <list>]</list>     | Y        | The optional -rgb <rgb> option specifies the rgb color<br/>value for the rectangle as a 3 element list of integers {red<br/>green blue}. If this option is not used, the color blue will be<br/>used.</rgb>       |
| [-batch]                 | Y        | The optional -batch option causes the GUI to not refresh<br>after this command. This is useful when running many<br>draw commands in a row. Afterwards, refresh_drawing<br>can be called.                         |
| [-thickness <int>]</int> | Y        | The optional -thickness <pixels> option specifies the rectangle thickness in pixels. If this option is not used, a thickness of 1 will be used.</pixels>                                                          |
| [-fill]                  | Y        | The optional -fill option specifies whether the rectangle<br>should be filled with color or not. If this option is not used,<br>the rectangle will be hollow.                                                     |

# draw\_string

draw\_string <x> <y> <string> [-layer <int>] [-id <int>] [-rgb <list>] [-batch]
This command allows you to draw a custom string on the GUI's Floorplanner view.

| Argument | Optional | Description                                                              |
|----------|----------|--------------------------------------------------------------------------|
| <x></x>  |          | The required <x> argument specifies the x coordinate for the string.</x> |

| Argument             | Optional | Description                                                                                                                                                                                                    |
|----------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <y></y>              |          | The required <y> argument specifies the y coordinate for the string.</y>                                                                                                                                       |
| <string></string>    |          | The required <string> argument specifies the string text.</string>                                                                                                                                             |
| [-layer <int>]</int> | Y        | The optional -layer <layer> option specifies the drawing<br/>layer for the string. If this option is not used, the top layer<br/>(5) will be used. Using a value of 0 will draw on the<br/>background.</layer> |
| [-id <int>]</int>    | Y        | The optional -id <id> option specifies a unique id for the string. If this option is not used, a unique id will be automatically generated and returned by the command.</id>                                   |
| [-rgb <list>]</list> | Y        | The optional -rgb <rgb> option specifies the rgb color value<br/>for the string as a 3 element list of integers {red green<br/>blue}. If this option is not used, the color blue will be used.</rgb>           |
| [-batch]             | Y        | The optional -batch option causes the GUI to not refresh<br>after this command. This is useful when running many<br>draw commands in a row. Afterwards, refresh_drawing can<br>be called.                      |

## enable\_flow\_step

enable\_flow\_step <id>

This command enables an existing optional flow step to be run during a "run" command.

| Argument  | Optional | Description                                                                  |
|-----------|----------|------------------------------------------------------------------------------|
| <id></id> |          | The required <id> argument specifies the id of the flow step to enable.</id> |

### enable\_project\_constraints

enable\_project\_constraints [-project <string>] [-impl <string>] <file>

This command enables project constraints files for a project implementation. If no project or impl names are specified, the currently active project implementation is used.

| Argument                     | Optional | Description                                                                                                                                                                                        |
|------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-project <string>]</string> | Y        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to enable constraints<br/>for.</implname></projectname> |
| [-impl <string>]</string>    | Y        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to enable constraints<br/>for.</implname></projectname> |
| <file></file>                |          | The project constraints file to enable for a project implementation.                                                                                                                               |

# enable\_project\_source\_file

enable\_project\_source\_file <file> [-syn\_constraint] [-pnr\_constraint] [pnr\_netlist] [-project <string>] [-impl <string>]

This command enables project source files for a project implementation. If no project or impl names are specified, the currently active project implementation is used.

| Argument                     | Optional | Description                                                                                                                                                                                        |
|------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <file></file>                |          | The project constraints file to enable for a project implementation.                                                                                                                               |
| [-syn_constraint]            | Y        | The optional -syn_constraint option is used to specify the source file to be enabled is a synthesis constraint file.                                                                               |
| [-pnr_constraint]            | Y        | The optional -pnr_constraint option is used to specify the source file to be enabled is a place and route constraint file.                                                                         |
| [-pnr_netlist]               | Y        | The optional -pnr_netlist option is used to specify the source file to be enabled is a place and route netlist file.                                                                               |
| [-project <string>]</string> | Y        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to enable source file<br/>for.</implname></projectname> |

| Argument                  | Optional | Description                                                                                                                                                                                        |
|---------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-impl <string>]</string> | Y        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to enable source file<br/>for.</implname></projectname> |

## export\_all\_partitions

#### export\_all\_partitions [-info\_list]

Command to export the place-and-route database and blackbox Verilog model for all leaf-level partitions in the design

| Argument     | Optional | Description                                                                                                                                                |
|--------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-info_list] | Υ        | Return a Tcl list containing { <partition> <view> <epdb<br>filename&gt; <blackbox filename="">} for each partition</blackbox></epdb<br></view></partition> |

### export\_partition

# export\_partition <partition> [-dboutputfile <string>] [-bboutputfile <string>] [info\_list]

Command to export the place-and-route database and blackbox Verilog model for a partition

| Argument                          | Optional | Description                                                                                                                                                                                 |
|-----------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <partition></partition>           |          | Export the place-and-route database and blackbox<br>Verilog model for the specified partition                                                                                               |
| [-dboutputfile <string>]</string> | Υ        | Specifies the output file name for the partition<br>database (default is <active_impl_dir>/pnr/output/<br/>partitions/<cellname>_<partition>.epdb)</partition></cellname></active_impl_dir> |
| [-bboutputfile <string>]</string> | Υ        | Specifies the output file name for the partition<br>blackbox Verilog model (default is <active_impl_dir>/<br/>pnr/output/blackboxes/<cellname>_bb.v)</cellname></active_impl_dir>           |
| [-info_list]                      | Υ        | Return a Tcl list containing { <partition> <view> <epdb<br>filename&gt; <blackbox filename="">} for each partition</blackbox></epdb<br></view></partition>                                  |

### filter

# filter <objects> [-patterns <list>] [-insts] [-nets] [-ports] [-pins] [-paths] [sites] [-filter <string>] [-no\_prefix]

This command takes a TCL list of DB objects and returns a filtered TCL list of objects that match the filter options passed in. Each object name in the returned list is prepended with an object type indicator (unless -no\_prefix is used). Object types prefixes are: p: = port (top level user design), t: = pin, i: = instance, n: = net. Find results may contain a mixture of object types. The -insts, -nets, -ports, and -pins object type options may be used to filter the results to just those object types. Specifying no object type options will result in a search of all object types.

| Argument                  | Optional | Description                                                                                                                                                                                                                                                                                                                                                                              |
|---------------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <objects></objects>       |          | The required <objects> argument specifies a list of object names to filter.</objects>                                                                                                                                                                                                                                                                                                    |
| [-patterns <list>]</list> | Y        | The optional -patterns argument specifies a list of pattern strings<br>to match object names against. Each pattern string in the list may<br>use '*' and '?' wildcard characters for matching.                                                                                                                                                                                           |
| [-insts]                  | Y        | The optional -insts object type option is used to specify that the results may include instance object types. If no other object type option is used, all object types will be included in the results by default. If another object type option is used, and the -insts option is not used, then the results will not contain any instance objects.                                     |
| [-nets]                   | Y        | The optional -nets object type option is used to specify that the results may include net object types. If no other object type option is used, all object types will be included in the results by default. If another object type option is used, and the -nets option is not used, then the results will not contain any net objects.                                                 |
| [-ports]                  | Y        | The optional -ports object type option is used to specify that the results may include top level user design port object types. If no other object type option is used, all object types will be included in the results by default. If another object type option is used, and the -ports option is not used, then the results will not contain any top level user design port objects. |
| [-pins]                   | Y        | The optional -pins object type option is used to specify that the results may include pin object types. If no other object type option is used, all object types will be included in the results by default. If another object type option is used, and the -pins option is not used, then the results will not contain any pin objects.                                                 |

| Argument                    | Optional | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-paths]                    | Y        | The optional -paths object type option is used to specify that the results may include path object types. If no other object type option is used, all object types will be included in the results by default. If another object type option is used, and the -paths option is not used, then the results will not contain any path objects.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [-sites]                    | Υ        | The optional -sites object type option is used to specify that the results may include site object types. If no other object type option is used, all object types will be included in the results by default. If another object type option is used, and the -sites option is not used, then the results will not contain any site objects.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [-filter <string>]</string> | Υ        | The optional -filters option may be used to specify a boolean<br>expression of object properties to filter the results with. Each<br>property filter in the expression must follow the filter syntax of<br>@ <propertyname><operator><value>. Multiple property filters<br/>may be used in the expression by using boolean operators. For<br/>example: "find * -filter {@type=DFF    @type=LUT4}". The<br/>supported filter property names are currently: @async_reset,<br/>@attribute, @clock, @clock_as_data, @clock_domain,<br/>@clock_region, @data_as_clock, @direction, @driver_type,<br/>@driving_net, @driving_pin, @enable, @fanout,<br/>@fixed_placement, @limit, @partition, @placed, @power,<br/>@power_rank, @region, @reset, @sink_type, or @type. The<br/>supported filter operators are currently: &gt;, &lt;, !, and =. The<br/>supported boolean operators (when using multiple filters) are<br/>currently: &amp;&amp;,   , and ==.</value></operator></propertyname> |
| [-no_prefix]                | Y        | The optional -no_prefix option is used to remove the object type prefix from the names returned in the results.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

See also: Object Type Prefixes (page 334), Search Filter Builder Dialog (page 189), Filter Properties (page 264), find (page 638), Search View. (page 133)

### find

find <patterns> [-insts] [-nets] [-ports] [-pins] [-paths] [-sites] [-filter
<string>] [-sort <string>] [-sort\_order <string>] [-no\_prefix] [-no\_refresh] [handle] [-warning] [-error]

This command returns a TCL list of object names that match any of the pattern strings passed in. Each object name in the returned list is prepended with an object type indicator (unless -no\_prefix is used). Object types prefixes are: p: = port (top level user design), t: = pin, i: = instance, n: = net. Find results may contain a mixture of object types. The -insts, -nets, -ports, and -pins object type options may be used to filter the results to just those object types. Specifying no object type options will result in a search of all object types.

| Argument              | Optional | Description                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <patterns></patterns> |          | The required <patterns> argument specifies a list of pattern<br/>strings to match object names against. The pattern for matching<br/>with specific pins must have separator '/' in the form of<br/><instance pattern="">/<pin pattern="">. Each pattern string in the list<br/>may use '*' and '?' wildcard characters for matching.</pin></instance></patterns>                         |
| [-insts]              | Y        | The optional -insts object type option is used to specify that the results may include instance object types. If no other object type option is used, all object types will be included in the results by default. If another object type option is used, and the -insts option is not used, then the results will not contain any instance objects.                                     |
| [-nets]               | Y        | The optional -nets object type option is used to specify that the results may include net object types. If no other object type option is used, all object types will be included in the results by default. If another object type option is used, and the -nets option is not used, then the results will not contain any net objects.                                                 |
| [-ports]              | Y        | The optional -ports object type option is used to specify that the results may include top level user design port object types. If no other object type option is used, all object types will be included in the results by default. If another object type option is used, and the -ports option is not used, then the results will not contain any top level user design port objects. |
| [-pins]               | Y        | The optional -pins object type option is used to specify that the results may include pin object types. If no other object type option is used, all object types will be included in the results by default. If another object type option is used, and the -pins option is not used, then the results will not contain any pin objects.                                                 |
| [-paths]              | Y        | The optional -paths object type option is used to specify that the results may include path object types. If no other object type option is used, all object types will be included in the results by default. If another object type option is used, and the -paths option is not used, then the results will not contain any path objects.                                             |

| Argument                           | Optional | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-sites]                           | Y        | The optional -sites object type option is used to specify that the results may include site object types. If no other object type option is used, all object types will be included in the results by default. If another object type option is used, and the -sites option is not used, then the results will not contain any site objects.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [-filter <string>]</string>        | Υ        | The optional -filters option may be used to specify a boolean<br>expression of object properties to filter the results with. Each<br>property filter in the expression must follow the filter syntax of<br>@ <propertyname><operator><value>. Multiple property filters<br/>may be used in the expression by using boolean operators. For<br/>example: "find * -filter {@type=DFF    @type=LUT4}". The<br/>supported filter property names are currently: @async_reset,<br/>@attribute, @clock, @clock_as_data, @clock_domain,<br/>@clock_region, @data_as_clock, @direction, @driver_type,<br/>@driving_net, @driving_pin, @enable, @fanout,<br/>@fixed_placement, @limit, @partition, @placed, @power,<br/>@power_rank, @region, @reset, @sink_type, or @type. The<br/>supported filter operators are currently: &gt;, &lt;, !, and =. The<br/>supported boolean operators (when using multiple filters) are<br/>currently: &amp;&amp;,   , and ==.</value></operator></propertyname> |
| [-sort <string>]</string>          | Υ        | The -sort option allows the user to specify the type of sort<br>performed on the find results list. The default is "dictionary".<br>Other options are "ascii" or "none"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [-sort_order<br><string>]</string> | Υ        | The -sort_order option allows the user to specify the direction of sort performed on the find results list. You may specify either "increasing" or "decreasing". The default is "increasing".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [-no_prefix]                       | Y        | The optional -no_prefix option is used to remove the object type prefix from the names returned in the results                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [-no_refresh]                      | Y        | The optional -no_refresh option is used to prevent sending an update to the GUI Search View to optimize speed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [-handle]                          | Υ        | The optional -handle option is used to return the reserve string<br>"@@FindResults" instead of the TCL list of object names. This<br>handle can then be used in the highlight command to speed up<br>processing by avoiding extra name parsing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [-warning]                         | Y        | Print warning message if the find command does not find any objects.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Argument | Optional | Description                                                                |
|----------|----------|----------------------------------------------------------------------------|
| [-error] | Y        | Print message and error out if the find command does not find any objects. |

The ACE GUI provides a graphical interface for the find command through the Search View (page 133). See also: Object Type Prefixes (page 334), Search Filter Builder Dialog (page 189), Filter Properties (page 264), filter (page 637), select (page 709), Selection View (page 137), trace\_connections. (page 718)

### generate\_ioring\_design\_files

#### generate\_ioring\_design\_files <outputDir> [-add\_to\_project]

This command generates the all IO Ring design files for the active ACE project, using all ACXIP files that have been added to the active project.

| Argument                | Optional | Description                                                                                                                                                                                                                 |
|-------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <outputdir></outputdir> |          | The required <outputdir> argument allows the user to specify the directory path to output the IO Ring design files into.</outputdir>                                                                                        |
| [-add_to_project]       | Υ        | Using the -add_to_project option automatically adds the<br>required generated IO Ring design files to your ACE project.<br>This includes utilization XML, SDC constraints, PDC<br>constraints, and IO Ring bitstream files. |

### generate\_ip\_design\_files

#### generate\_ip\_design\_files <acxipFile>

This command generates the enabled design files for a given IP configuration (.acxip file).

| Argument                | Optional | Description                                                                                                              |
|-------------------------|----------|--------------------------------------------------------------------------------------------------------------------------|
| <acxipfile></acxipfile> |          | The required <acxipfile> argument specifies the IP configuration (.acxip file) to generate design files for.</acxipfile> |

### generate\_route\_delay\_table

#### generate\_route\_delay\_table [-outputfile <string>]

This command extracts route delay numbers on nets for estimating the cell-cell route delays vs fanout.

| Argument                        | Optional | Description                                                                                                                                                                                                                                                                          |
|---------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-outputfile <string>]</string> | Υ        | The optional -outputfile <file> option may be used to<br/>specify an output file name or file path. If this option is not<br/>present, the output is written to the default<br/>implementation .debug directory and is named<br/><design_name>_route_delay.log.</design_name></file> |

### get\_ace\_cputime

#### get\_ace\_cputime

This command returns the cumulative cpu time of this ACE process

#### get\_ace\_current\_memory\_usage

#### get\_ace\_current\_memory\_usage

This command returns the current memory usage (in kB) of this ACE process

#### get\_ace\_ext\_dir

#### get\_ace\_ext\_dir

This command returns the path to the ACE Extensions directory if one has been enabled.

### get\_ace\_ext\_lib

#### get\_ace\_ext\_lib <partName>

This command returns the blackbox library path in the ACE Extensions directory for the specified partname if one has been enabled.

| Argument              | Optional | Description                                                                                                                                                                                                                            |
|-----------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <partname></partname> |          | The required <partname> argument is used to specify the<br/>name of the target device to find the blackbox library file for.<br/>The part name specified must exist among the valid part<br/>names in the ACE installation.</partname> |

### get\_ace\_peak\_memory\_usage

#### get\_ace\_peak\_memory\_usage

This command returns the maximum memory usage (in kB) of this ACE process during the current session

### get\_ace\_version

#### get\_ace\_version [-buildid] [-builddate] [-full]

This command returns the version of ACE

| Argument     | Optional | Description                                                                       |
|--------------|----------|-----------------------------------------------------------------------------------|
| [-buildid]   | Υ        | The optional -buildid option will return the buildid.                             |
| [-builddate] | Υ        | The optional -builddate option will say when ace was built.                       |
| [-full]      | Υ        | The optional -full option will return the full ACE version and build designation. |

### get\_active\_impl

#### get\_active\_impl [-quiet]

This command returns the name of the active implementation in the current ACE session.

| Argument | Optional | Description                                          |
|----------|----------|------------------------------------------------------|
| [-quiet] | Y        | do not print a message if there is no active project |

#### Example

To automatically set the value of the set\_impl\_option -impl option, after the create\_project -impl command has been run, which defines the name of the active impl, the following command can be used:

```
set_impl_option -project [get_active_project] -impl [get_active_impl]
"partname" "AC16tSC01HI01C"
```

#### Also See

```
create_project (page 623)
get_active_project (page 643)
set_impl_option (page 712)
```

### get\_active\_project

get\_active\_project [-quiet] [-path]

This command returns the name of the active project (which contains the active implementation) in the current ACE session.

| Argument | Optional | Description                                                                                   |
|----------|----------|-----------------------------------------------------------------------------------------------|
| [-quiet] | Y        | do not print a message if there is no active project                                          |
| [-path]  | Y        | Return the file path to the active project's acxprj project file, instead of the project name |

### get\_best\_multiprocess\_impl

#### get\_best\_multiprocess\_impl

This command finds the best impl from the MultiProcess Summary Report in the active project.

# get\_clock\_region\_bounds

#### get\_clock\_region\_bounds <region>

Returns the bounding box for a clock region

| Argument          | Optional | Description        |
|-------------------|----------|--------------------|
| <region></region> |          | Name of the region |

### get\_clock\_regions

#### get\_clock\_regions

Returns the list of clock region names for the device

### get\_clock\_type

#### get\_clock\_type <clock>

Get properties of a clock. For a non-driving (target) clock pin, this is a combination of local properties and properties of the clock domain.

| Argument        | Optional | Description             |
|-----------------|----------|-------------------------|
| <clock></clock> |          | net or pin ('inst/pin') |

### get\_compatible\_ordering\_codes

#### get\_compatible\_ordering\_codes

This command returns a list of compatible ordering codes for the active project based on it's device, package, and speed grade.

### get\_compatible\_placements

get\_compatible\_placements <source> [-anchor <string>] [-outputfile <string>]

Get a list of compatible placements for the given <source> partition

| Argument                        | Optional | Description                                                                                                                  |
|---------------------------------|----------|------------------------------------------------------------------------------------------------------------------------------|
| <source/>                       |          | Name of the source partition                                                                                                 |
| [-anchor <string>]</string>     | Υ        | Name of the anchor instance. An anchor instance will be chosen automatically if not given.                                   |
| [-outputfile <string>]</string> | Y        | Name of optional output file. If given, the compatible placements will be written out as a series of set_placement commands. |

### get\_current\_design

#### get\_current\_design [-quiet]

This command returns the name of the top module in the current design. This command returns an error if no current design is loaded.

| Argument | Optional | Description                                          |
|----------|----------|------------------------------------------------------|
| [-quiet] | Y        | do not print a message if there is no active project |

### get\_current\_partname

#### get\_current\_partname [-quiet]

This command returns the name of the currently loaded device.

| Argument | Optional | Description                             |
|----------|----------|-----------------------------------------|
| [-quiet] | Υ        | do not warn if there is no current part |

# get\_efd\_file\_path

#### get\_efd\_file\_path <partName>

This command returns the path to the efd file for the given part.

| Argument              | Optional | Description                                                                                                                                                                                                      |
|-----------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <partname></partname> |          | The required <partname> argument is used to specify the<br/>name of the part to find the efd file for. The part name<br/>specified must exist among the valid part names in the ACE<br/>installation.</partname> |

# get\_enabled\_constraints

get\_enabled\_constraints [-project <string>] [-impl <string>]

This command returns a list of all the enabled constraint files for an implementation.

| Argument                     | Optional | Description                                                                                                                                                                                             |
|------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-project <string>]</string> | Y        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to get enabled<br/>constraints for.</implname></projectname> |
| [-impl <string>]</string>    | Y        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to get enabled<br/>constraints for.</implname></projectname> |

# get\_enabled\_source\_files

get\_enabled\_source\_files [-project <string>] [-impl <string>] [-syn\_constraint] [pnr\_constraint] [-pnr\_netlist]

This command returns a list of all the enabled source files for an implementation.

| Argument                     | Optional | Description                                                                                                                                                                                             |
|------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-project <string>]</string> | Y        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to get enabled<br/>constraints for.</implname></projectname> |
| [-impl <string>]</string>    | Υ        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to get enabled<br/>constraints for.</implname></projectname> |
| [-syn_constraint]            | Υ        | The optional -syn_constraint option is used to return a list of enabled synthesis constraint file paths.                                                                                                |

| Argument          | Optional | Description                                                                                                    |
|-------------------|----------|----------------------------------------------------------------------------------------------------------------|
| [-pnr_constraint] | Y        | The optional -pnr_constraint option is used to return a list of enabled place and route constraint file paths. |
| [-pnr_netlist]    | Υ        | The optional -pnr_netlist option is used to return a list of enabled place and route netlist file paths.       |

# get\_fabricdb\_path

```
get_fabricdb_path <partName>
```

This command returns the path to the fabric db file for the given part.

|                                                                                                                                                                                                                                                                          | Argument | Optional | Description                                                                                                                                                                                                       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <par< td=""><th>tName&gt;</th><td></td><td>The required <partname> argument is used to specify the<br/>name of the part to find the fabric db for. The part name<br/>specified must exist among the valid part names in the ACE<br/>installation.</partname></td></par<> | tName>   |          | The required <partname> argument is used to specify the<br/>name of the part to find the fabric db for. The part name<br/>specified must exist among the valid part names in the ACE<br/>installation.</partname> |

# get\_file\_line

#### get\_file\_line <object>

This command returns the file path and line offset into to the source netlist for the given user design instance or net.

| Argument          | Optional | Description                                                                                                                     |
|-------------------|----------|---------------------------------------------------------------------------------------------------------------------------------|
| <object></object> |          | The required <object> argument specifies the instance (i:) or net (n:) name for which the file line will be retrieved.</object> |

### get\_flow\_steps

#### get\_flow\_steps

This command returns a list of all the currently defined flow step id strings.

### get\_impl\_names

```
get_impl_names [-project <string>]
```

This command returns a list of all the implementation names for an existing project.

| Argument                     | Optional | Description                                                                                                                                      |
|------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| [-project <string>]</string> | Υ        | The optional -project <projectname> option is used to specify an alternate project (by name) to get the implementation names from.</projectname> |

### get\_impl\_option

```
get_impl_option <option_name> [-project <string>] [-impl <string>] [-syn] [-type]
[-range] [-default]
```

This command returns the current value of a project implementation option. Only one option value may be retrieved at a time.

| Argument                     | Optional | Description                                                                                                                                                                             |
|------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <option_name></option_name>  |          | The name of the impl option to retrieve a value for. To see a list of valid impl options, use the report_impl_options TCL command.                                                      |
| [-project <string>]</string> | Y        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to get options for.</implname></projectname> |
| [-impl <string>]</string>    | Y        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to get options for.</implname></projectname> |
| [-syn]                       | Y        | option is synthesis option                                                                                                                                                              |
| [-type]                      | Y        | return the type of this option - bool,list,string,integer                                                                                                                               |
| [-range]                     | Y        | return the permissible range of this option if bounded                                                                                                                                  |
| [-default]                   | Y        | return the default value                                                                                                                                                                |

# get\_impl\_option\_is\_supported

get\_impl\_option\_is\_supported <option\_name> [-project <string>] [-impl <string>]
Returns '1' if the impl option is supported on the current device, otherwise returns '0'

| Argument                     | Optional | Description                                                                                                                                                                             |
|------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <option_name></option_name>  |          | The name of the impl option to retrieve a value for. To see a list of valid impl options, use the report_impl_options TCL command.                                                      |
| [-project <string>]</string> | Y        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to get options for.</implname></projectname> |
| [-impl <string>]</string>    | Y        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to get options for.</implname></projectname> |

# get\_impl\_option\_is\_supported\_and\_enabled

get\_impl\_option\_is\_supported\_and\_enabled <option\_name> [-project <string>] [-impl <string>]

Returns '1' if the impl option is supported on the current device, otherwise returns '0'

| Argument                     | Optional | Description                                                                                                                                                                             |
|------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <option_name></option_name>  |          | The name of the impl option to retrieve a value for. To see a list of valid impl options, use the report_impl_options TCL command.                                                      |
| [-project <string>]</string> | Υ        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to get options for.</implname></projectname> |
| [-impl <string>]</string>    | Υ        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to get options for.</implname></projectname> |

# get\_inst\_partition

#### get\_inst\_partition <instance>

Returns the Partition associated with a user design instance

| Argument              | Optional | Description          |
|-----------------------|----------|----------------------|
| <instance></instance> |          | Name of the instance |

### get\_inst\_region

#### get\_inst\_region <instance>

#### Returns the region associated with a user design instance

| Argument              | Optional | Description          |
|-----------------------|----------|----------------------|
| <instance></instance> |          | Name of the instance |

# get\_installation\_directory

#### get\_installation\_directory

This command returns the path to the root of the ACE installation.

### get\_location

#### get\_location <object>

This command allows you to get the location of an object (i:instance, s:site, or t:pin) on the GUI's Floorplanner view.

| Argument          | Optional | Description                                                                                                                      |
|-------------------|----------|----------------------------------------------------------------------------------------------------------------------------------|
| <object></object> |          | The required <object> argument specifies the object to get coordinates for. The correct object type prefix is required.</object> |

# get\_noc\_children

#### get\_noc\_children <path\_hierarchy> [-device <string>] [-print]

Returns the path hierarchy of children nodes under the given path. Works for address maps, sub maps, and registers. Calling it on an address map will return a list of registers and/or address submaps. Calling it on a register will return a list of register fields. Calling it on a register field will return an empty list.

| Argument                          | Optional | Description                                                                                                                                                                                                                                                                                  |
|-----------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <path_hierarchy></path_hierarchy> |          | Each level of the path hierarchy must separated by a period,<br>contain either a string name or the address offset, and is<br>case insensitive. Each level after CSR_SPACE supports a *<br>wildcard, e.g. CSR_SPACE.GDDR_0.CH_*.0x10020. The first<br>level must be either CSR or CSR_SPACE. |
| [-device <string>]</string>       | Y        | The part name of the Achronix target device, e.g. AC7t1500/<br>AC7t800ES0.                                                                                                                                                                                                                   |
| [-print]                          | Y        | Print result.                                                                                                                                                                                                                                                                                |

### get\_noc\_info

#### get\_noc\_info <path\_hierarchy> [-device <string>] [-no\_desc] [-print]

Returns data for the last level of the path hierarchy. Providing an address map returns a dictionary with the address and base\_addr\_offset. Providing a register returns a dictionary with the address, base\_addr\_offset, msb, and lsb. Providing a register field returns a dictionary with address, base\_addr\_offset, msb, lsb, access, and description.

| Argument                          | Optional | Description                                                                                                                                                                                                                                                                                  |
|-----------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <path_hierarchy></path_hierarchy> |          | Each level of the path hierarchy must separated by a period,<br>contain either a string name or the address offset, and is<br>case insensitive. Each level after CSR_SPACE supports a *<br>wildcard, e.g. CSR_SPACE.GDDR_0.CH_*.0x10020. The first<br>level must be either CSR or CSR_SPACE. |
| [-device <string>]</string>       | Y        | The part name of the Achronix target device, e.g. AC7t1500/<br>AC7t800ES0.                                                                                                                                                                                                                   |
| [-no_desc]                        | Y        | Don't add the description to the result (only applies to register fields).                                                                                                                                                                                                                   |
| [-print]                          | Y        | Print result.                                                                                                                                                                                                                                                                                |

### get\_package\_names

#### get\_package\_names [<partName>] [-default]

This command returns the list of valid package names for the specified part.

| Argument                 | Optional | Description                       |
|--------------------------|----------|-----------------------------------|
| [ <partname>]</partname> | Y        | Name of part                      |
| [-default]               | Υ        | Returns the default package value |

### get\_part\_names

get\_part\_names [-default]

This command returns the list of valid part names in the installed library.

| Argument   | Optional | Description                        |
|------------|----------|------------------------------------|
| [-default] | Y        | Returns the default partname value |

# get\_partition\_changed

#### get\_partition\_changed <name>

#### Get the changed flag of a partition with the given name

| Argument      | Optional | Description           |
|---------------|----------|-----------------------|
| <name></name> |          | Name of the Partition |

# get\_partition\_force\_changed

#### get\_partition\_force\_changed <name>

Get the force changed flag of a partition with the given name

| Argument      | Optional | Description           |
|---------------|----------|-----------------------|
| <name></name> |          | Name of the Partition |

# get\_partition\_info

get\_partition\_info <name> [-timestamp] [-comment] [-view] [-type] [-is\_import] [import\_from] [-changed] [-id] [-disabled] [-parent] [-is\_top] [-is\_parent] Get info of a partition with the given name

| Argument       | Optional | Description                          |
|----------------|----------|--------------------------------------|
| <name></name>  |          | Name of the Partition                |
| [-timestamp]   | Υ        | get timestamp                        |
| [-comment]     | Y        | get comment                          |
| [-view]        | Y        | get view name                        |
| [-type]        | Y        | get partition type                   |
| [-is_import]   | Y        | was the partition imported (0 or 1)? |
| [-import_from] | Y        | file the partition was imported from |
| [-changed]     | Υ        | has the partition timestamp changed  |
| [-id]          | Υ        | unique partition id number           |

| Argument     | Optional | Description                                     |
|--------------|----------|-------------------------------------------------|
| [-disabled]  | Y        | is the partition disabled (0 or 1)?             |
| [-parent]    | Y        | name of the partition's parent partition        |
| [-is_top]    | Y        | is this the top partition (0 or 1)?             |
| [-is_parent] | Y        | is this partition a parent of another (0 or 1)? |

# get\_partition\_insts

#### get\_partition\_insts <name>

Returns the list of user design instances in a partition

| Argument      | Optional | Description           |
|---------------|----------|-----------------------|
| <name></name> |          | Name of the Partition |

### get\_partition\_names

#### get\_partition\_names

Returns the list of user design partition names

# get\_partition\_timestamp

#### get\_partition\_timestamp <name>

Get the timestamp of a partition with the given name

| Argument      | Optional | Description           |
|---------------|----------|-----------------------|
| <name></name> |          | Name of the Partition |

# get\_partition\_type

#### get\_partition\_type <name>

Get the type of a partition with the given name

| Argument      | Optional | Description           |
|---------------|----------|-----------------------|
| <name></name> |          | Name of the Partition |

# get\_path\_ids

#### get\_path\_ids

This command returns path IDs from the last timing run.

# get\_path\_property

get\_path\_property <id> [-pins] [-insts] [-nets] [-frequency] [-type] [-rgb] [text] [-slack]

This command returns path properties.

| Argument     | Optional | Description                                                                                                                                                            |
|--------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <id></id>    |          | The required <id> argument specifies the id of the path to get properties for.</id>                                                                                    |
| [-pins]      | Y        | The optional -pins option returns the list of pin names that make up this path.                                                                                        |
| [-insts]     | Y        | The optional -insts option returns the list of instance names on this path.                                                                                            |
| [-nets]      | Y        | The optional -nets option returns the list of net names on this path.                                                                                                  |
| [-frequency] | Y        | The optional -frequency option returns the frequency of this path in MHz. If no frequency is defined, -1 is returned.                                                  |
| [-type]      | Y        | The optional -type option returns the type of path: Setup<br>Check Met, Setup Check Violated, Hold Check Met, Hold<br>Check Violated, Hardware Limit, or User-Defined. |
| [-rgb]       | Y        | The optional -rgb option returns the integer rgb highlight color value for the path. A value of -1 means it is not highlighted.                                        |
| [-text]      | Y        | The optional -text option returns the details text for this path.                                                                                                      |
| [-slack]     | Y        | The optional -slack option returns the slack for this path.                                                                                                            |

# get\_placement

get\_placement <objName>

This command returns the site of the specified placed instance

| Argument            | Optional | Description                                                                                             |
|---------------------|----------|---------------------------------------------------------------------------------------------------------|
| <objname></objname> |          | The required <objname> argument is used to specify the instance or port to get placement for.</objname> |

# get\_project\_constraint\_files

#### get\_project\_constraint\_files [-project <string>]

This command returns a list of all the constraint file paths for a project.

| Argument                     | Optional | Description                                                                                                                                       |
|------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| [-project <string>]</string> | Y        | The optional -project <projectname> option is used to specify an alternate project (by name) to get the constraint file paths from.</projectname> |

### get\_project\_directory

get\_project\_directory [-project <string>]
This command returns the path to a project file's parent directory

| Argument                     | Optional | Description                                                                                                                                |
|------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------|
| [-project <string>]</string> | Υ        | The optional -project <projectname> option is used to specify an alternate project (by name) to get the directory path from.</projectname> |

# get\_project\_ip\_files

#### get\_project\_ip\_files [-project <string>]

This command returns a list of all the IP settings file paths for a project.

| Argument                     | Optional | Description                                                                                                                                        |
|------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| [-project <string>]</string> | Y        | The optional -project <projectname> option is used to specify an alternate project (by name) to get the IP settings file paths from.</projectname> |

### get\_project\_names

get\_project\_names

This command returns a list of all the project names loaded in the current ACE session.

### get\_project\_netlist\_files

#### get\_project\_netlist\_files [-project <string>] [-noimpl]

This command returns a list of all the netlist file paths for a project.

| Argument                     | Optional | Description                                                                                                                                    |
|------------------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------|
| [-project <string>]</string> | Y        | The optional -project <projectname> option is used to specify an alternate project (by name) to get the netlist file paths from.</projectname> |
| [-noimpl]                    | Y        | Do not list impl-specific files, even with active impl.                                                                                        |

### get\_project\_option

get\_project\_option <option\_name> [-project <string>] [-type] [-range] [-default]
[-quiet]

This command returns the current value of a project option. Only one option value may be retrieved at a time.

| Argument                     | Optional | Description                                                                                                                                 |
|------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------|
| <option_name></option_name>  |          | The name of the project option to retrieve a value for. To see a list of valid project options, use the report_project_options TCL command. |
| [-project <string>]</string> | Y        | The optional -project <projectname> option is used to specify an alternate project (by name) to get options for.</projectname>              |
| [-type]                      | Y        | return the type of this option - bool,list,string,integer                                                                                   |
| [-range]                     | Y        | return the permissible range of this option if bounded                                                                                      |
| [-default]                   | Y        | return the default value                                                                                                                    |
| [-quiet]                     | Y        | quietly return default if no project active.                                                                                                |

# get\_project\_option\_is\_supported

get\_project\_option\_is\_supported <option\_name> [-project <string>]
Returns '1' if the project option is supported on the current device, otherwise returns '0'

| Argument                     | Optional | Description                                                                                                                                 |
|------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------|
| <option_name></option_name>  |          | The name of the project option to retrieve a value for. To see a list of valid project options, use the report_project_options TCL command. |
| [-project <string>]</string> | Y        | The optional -project <projectname> option is used to specify an alternate project (by name) to get options for.</projectname>              |

# get\_project\_option\_is\_supported\_and\_enabled

get\_project\_option\_is\_supported\_and\_enabled <option\_name> [-project <string>]
Returns '1' if the project option is supported on the current device, otherwise returns '0'

| Argument                     | Optional | Description                                                                                                                                 |
|------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------|
| <option_name></option_name>  |          | The name of the project option to retrieve a value for. To see a list of valid project options, use the report_project_options TCL command. |
| [-project <string>]</string> | Υ        | The optional -project <projectname> option is used to specify an alternate project (by name) to get options for.</projectname>              |

### get\_project\_output\_directory

#### get\_project\_output\_directory [-project <string>]

This command returns the path to a project output directory specified by project option "project\_output\_path". By default, this command returns the project file's parent directory

| Argument                     | Optional | Description                                                                                                                                |
|------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------|
| [-project <string>]</string> | Υ        | The optional -project <projectname> option is used to specify an alternate project (by name) to get the directory path from.</projectname> |

# get\_project\_source\_files

```
get_project_source_files [-project <string>] [-ip] [-rtl] [-syn_constraint] [-
pnr_constraint] [-pnr_netlist] [-sim_tb]
```

This command returns a list of all the source file paths for a project.

| Argument                     | Optional | Description                                                                                                                                       |
|------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| [-project <string>]</string> | Y        | The optional -project <projectname> option is used to specify an alternate project (by name) to get the constraint file paths from.</projectname> |
| [-ip]                        | Y        | The optional -ip option is used to return a list of IP settings file paths.                                                                       |
| [-rtl]                       | Y        | The optional -rtl option is used to return a list of RTL file paths.                                                                              |
| [-syn_constraint]            | Y        | The optional -syn_constraint option is used to return a list of synthesis constraint file paths.                                                  |
| [-pnr_constraint]            | Y        | The optional -pnr_constraint option is used to return a list of place and route constraint file paths.                                            |
| [-pnr_netlist]               | Y        | The optional -pnr_netlist option is used to return a list of place and route netlist file paths.                                                  |
| [-sim_tb]                    | Y        | The optional -sim_tb option is used to return a list of simulation testbench file paths.                                                          |

# get\_properties

#### get\_properties <object>

This command returns the list of option-value pairs for the specified object.

| Argument          | Optional | Description                                                                         |
|-------------------|----------|-------------------------------------------------------------------------------------|
| <object></object> |          | The required <object> argument specifies the object to get properties for.</object> |

### get\_property

get\_property <object> <propName> [-object\_type <string>]

This command returns the specified property value for the specified object.

| Argument          | Optional | Description                                                                     |
|-------------------|----------|---------------------------------------------------------------------------------|
| <object></object> |          | The required <object> argument specifies which object will be queried.</object> |

| Argument                         | Optional | Description                                                                                                   |
|----------------------------------|----------|---------------------------------------------------------------------------------------------------------------|
| <propname></propname>            |          | The required <propname> argument specifies the name of the property whose value will be retrieved.</propname> |
| [-object_type <string>]</string> | Y        | type of object: cell   pin   net   port   clock                                                               |

### get\_pvt\_corners

```
get_pvt_corners [<partName>] [-default] [-speed_grade_only] [-speed_grade
<string>] [-core_voltage_only] [-core_voltage <string>] [-
junction_temperature_only]
```

This command returns a list of the valid PVT corners for the specified part

| Argument                          | Optional | Description                                                                                             |
|-----------------------------------|----------|---------------------------------------------------------------------------------------------------------|
| [ <partname>]</partname>          | Y        | Name of part                                                                                            |
| [-default]                        | Y        | Returns the default PVT corner.                                                                         |
| [-speed_grade_only]               | Υ        | Returns a list of valid speed_grade values for a specified part.                                        |
| [-speed_grade <string>]</string>  | Y        | Speed grade value.                                                                                      |
| [-core_voltage_only]              | Y        | Returns a list of valid core_volatge values for a specified part and speed_grade.                       |
| [-core_voltage <string>]</string> | Y        | Core voltage value.                                                                                     |
| [-<br>junction_temperature_only]  | Υ        | Returns a list of valid junction_temperature values for a specified part, speed_grade and core_voltage. |

### get\_region\_bounds

get\_region\_bounds <region>

Returns the bounding box for a placement region constraint

| Argument          | Optional | Description        |
|-------------------|----------|--------------------|
| <region></region> |          | Name of the region |

# get\_region\_insts

#### get\_region\_insts <region>

Returns the list of user design instances in a placement region constraint

| Argument          | Optional | Description        |
|-------------------|----------|--------------------|
| <region></region> |          | Name of the region |

### get\_regions

#### get\_regions [-verbose]

Returns the list of placement region constraint names

| Argument   | Optional | Description                               |
|------------|----------|-------------------------------------------|
| [-verbose] | Υ        | print region information with each region |

### get\_report\_sweep\_temperature\_corners

#### get\_report\_sweep\_temperature\_corners [-quiet]

This command returns a list of the valid junction temperatures for the target device at the given speed grade and core voltage level

| Argument | Optional | Description                                          |
|----------|----------|------------------------------------------------------|
| [-quiet] | Y        | do not print a message if there is no active project |

### get\_selection

#### get\_selection [-insts] [-nets] [-ports] [-pins] [-paths] [-sites] [-handle]

This command returns the current list of selected objects.

| Argument | Optional | Description                                                                                                                                                                                                                                                                                                                                          |
|----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-insts] | Y        | The optional -insts object type option is used to specify that the results may include instance object types. If no other object type option is used, all object types will be included in the results by default. If another object type option is used, and the -insts option is not used, then the results will not contain any instance objects. |

| Argument  | Optional | Description                                                                                                                                                                                                                                                                                                                                                                              |
|-----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-nets]   | Y        | The optional -nets object type option is used to specify that the results may include net object types. If no other object type option is used, all object types will be included in the results by default. If another object type option is used, and the -nets option is not used, then the results will not contain any net objects.                                                 |
| [-ports]  | Y        | The optional -ports object type option is used to specify that the results may include top level user design port object types. If no other object type option is used, all object types will be included in the results by default. If another object type option is used, and the -ports option is not used, then the results will not contain any top level user design port objects. |
| [-pins]   | Y        | The optional -pins object type option is used to specify that the results may include pin object types. If no other object type option is used, all object types will be included in the results by default. If another object type option is used, and the -pins option is not used, then the results will not contain any pin objects.                                                 |
| [-paths]  | Y        | The optional -paths object type option is used to specify that the results may include path object types. If no other object type option is used, all object types will be included in the results by default. If another object type option is used, and the -paths option is not used, then the results will not contain any path objects.                                             |
| [-sites]  | Y        | The optional -sites object type option is used to specify that the results may include site object types. If no other object type option is used, all object types will be included in the results by default. If another object type option is used, and the -sites option is not used, then the results will not contain any site objects.                                             |
| [-handle] | Y        | The optional -handle option is used to return the reserve string<br>"@@Selection" instead of the TCL list of object names. This<br>handle can be used in the highlight command to speed up<br>processing by avoiding extra name parsing                                                                                                                                                  |

# get\_synprj\_from\_netlist

### get\_synprj\_from\_netlist [<filename>]

This command returns the name the of the synthesis prj-file associated with the ace project, if available.

| Argument                 | Optional | Description                                        |
|--------------------------|----------|----------------------------------------------------|
| [ <filename>]</filename> | Y        | Name of file whose prj-file you want to find [any] |

### get\_synprj\_from\_project

#### get\_synprj\_from\_project

This command returns the name the of the synthesis prj-file associated with the ace project, if available.

### get\_techlib\_name

#### get\_techlib\_name <partName>

This command returns the name the of black box verilog library for the given part.

| Argument              | Optional | Description                                                                                                                                                                                                     |
|-----------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <partname></partname> |          | The required <partname> argument is used to specify the<br/>name of the part to find the library for. The part name<br/>specified must exist among the valid part names in the ACE<br/>installation.</partname> |

### get\_techlib\_path

#### get\_techlib\_path <partName>

This command returns the path to the black box verilog library file for the given part.

| Argument              | Optional | Description                                                                                                                                                                                                     |
|-----------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <partname></partname> |          | The required <partname> argument is used to specify the<br/>name of the part to find the library for. The part name<br/>specified must exist among the valid part names in the ACE<br/>installation.</partname> |

# get\_techlibdb\_path

#### get\_techlibdb\_path <partName>

This command returns the path to the techlib db file for the given part.

| Argument              | Optional | Description                                                                                                                                                                                                        |
|-----------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <partname></partname> |          | The required <partname> argument is used to specify the<br/>name of the part to find the techlib db for. The part name<br/>specified must exist among the valid part names in the ACE<br/>installation.</partname> |

# get\_techlibt\_name

#### get\_techlibt\_name <partName>

This command returns the name of the transmuted black box verilog library for the given part.

| Argument              | Optional | Description                                                                                                                                                                                                     |
|-----------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <partname></partname> |          | The required <partname> argument is used to specify the<br/>name of the part to find the library for. The part name<br/>specified must exist among the valid part names in the ACE<br/>installation.</partname> |

### get\_techlibt\_path

#### get\_techlibt\_path <partName>

This command returns the path to the transmuted black box verilog library file for the given part.

| Argument              | Optional | Description                                                                                                                                                                                                     |
|-----------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <partname></partname> |          | The required <partname> argument is used to specify the<br/>name of the part to find the library for. The part name<br/>specified must exist among the valid part names in the ACE<br/>installation.</partname> |

### get\_techlibx\_name

#### get\_techlibx\_name <partName>

This command returns the name the of the expanded black box verilog library for the given part.

| Argument              | Optional | Description                                                                                                                                                                                                     |
|-----------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <partname></partname> |          | The required <partname> argument is used to specify the<br/>name of the part to find the library for. The part name<br/>specified must exist among the valid part names in the ACE<br/>installation.</partname> |

### get\_techlibx\_path

#### get\_techlibx\_path <partName>

This command returns the path to the expanded black box verilog library file for the given part.

| Argument              | Optional | Description                                                                                                                                                                                                     |
|-----------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <partname></partname> |          | The required <partname> argument is used to specify the<br/>name of the part to find the library for. The part name<br/>specified must exist among the valid part names in the ACE<br/>installation.</partname> |

### get\_worst\_path

#### get\_worst\_path [-type <string>]

This command returns the path ID with the worst slack from the last timing run.

| Argument                  | Optional | Description                                                                                                                                                                                                                      |
|---------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-type <string>]</string> | Υ        | The optional -type <type> option returns the worst slack<br/>path ID for the specified type of path: Setup Check Met,<br/>Setup Check Violated, Hold Check Met, Hold Check Violated,<br/>Hardware Limit, or User-Defined.</type> |

### has\_ace\_ext\_lib

has\_ace\_ext\_lib <partName>

This command returns a 1 if the blackbox library path is configured in the ACE Extensions directory for the specified partname.

| Argument              | Optional | Description                                                                                                                                                                                                                            |
|-----------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <partname></partname> |          | The required <partname> argument is used to specify the<br/>name of the target device to find the blackbox library file for.<br/>The part name specified must exist among the valid part<br/>names in the ACE installation.</partname> |

### has\_partitions

#### has\_partitions

Check if partitions have been defined on the design via the \*.prt file

# highlight

#### highlight <objects> [-rgb <list>] [-batch] [-clear]

This command is used to highlight or un-highlight a list of objects in the GUI's physical view.

| Argument             | Optional | Description                                                                                                                                                                                                                                                                                                                                                  |
|----------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <objects></objects>  |          | The required <objects> argument is used to specify a list of<br/>objects which will have their highlight color set. Highlight of<br/>instance, net, and path object types is currently supported. All<br/>other object types passed in will be silently ignored. Objects<br/>must be prepended with object type prefixes (see "find"<br/>command).</objects> |
| [-rgb <list>]</list> | Y        | The optional -rgb <rgb> option is used to specify the RGB (Red-<br/>Green-Blue) color value to use for highlighting the specified<br/>objects as a 3 element list of 8-bit (0-255) integers {red green<br/>blue}. If the -rgb option is not used, then the objects in the list<br/>will be un-highlighted.</rgb>                                             |
| [-batch]             | Y        | The optional -batch option is used to suppress the refresh of<br>highlighting information to the GUI. This can be useful (faster)<br>if highlighting multiple groups of nets in a loop, since each<br>highlight command that affects a net will otherwise refresh the<br>entire routing data set in the GUI.                                                 |
| [-clear]             | Y        | The optional -clear option is used to clear all prior highlighting                                                                                                                                                                                                                                                                                           |

### ignore\_cancel

#### ignore\_cancel <script>

Temporarily ignore cancel button. Useful to execute cleanup commands in a flow step after a cancel has been caught.

| Argument                                                                         | Optional | Description |
|----------------------------------------------------------------------------------|----------|-------------|
| <script></td><td></td><td>commands to execute</td></tr></tbody></table></script> |          |             |

# import\_synplify\_project\_file

#### import\_synplify\_project\_file [<project\_file\_path>]

This command will allow the user to import all of the synthesis project options, RTL files, and Constraints into their ACE project automatically from an existing Synplify PRJ file.

| Argument                                   | Optional | Description                                                                                    |
|--------------------------------------------|----------|------------------------------------------------------------------------------------------------|
| [ <project_file_path>]</project_file_path> | Υ        | The <project_file_path> is used to specify the path to a synplify PRJ file</project_file_path> |

# initialize\_flow

#### initialize\_flow

This command clears the current flow model, then sources the master flow.tcl script. The master flow.tcl script uses these flow TCL commands to define the default flow.

### insert\_delay

#### insert\_delay <pinlist>

This command parses the user directive to add extra delays for paths that require additional delay for alleviating timing violations.

| Argument            | Optional | Description                                                                                                                                                                                                                                                                         |
|---------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pinlist></pinlist> |          | The required {pinlist} option is used to specify the load pins of a<br>net that need to be driven by inserted gates. For each pin, you<br>can optionally specify an integer delay value by using the format<br><delay>,<pin_name>. The default delay value is 1.</pin_name></delay> |

### is\_impl\_option\_enabled

is\_impl\_option\_enabled <option\_name> [-project <string>] [-impl <string>]
This command returns if an implementation option is enabled.

| Argument                     | Optional | Description                                                                                                                                                                             |
|------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <option_name></option_name>  |          | The name of the impl option to retrieve its enabled state.<br>To see a list of valid impl options, use the<br>report_impl_options TCL command.                                          |
| [-project <string>]</string> | Υ        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to get options for.</implname></projectname> |
| [-impl <string>]</string>    | Υ        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to get options for.</implname></projectname> |

# is\_incremental\_compile

#### is\_incremental\_compile

Check if the Incremental Compile Impl Option is set to 1, and that partitions have been defined on the design via the \*.prt file

### is\_labmode

#### is\_labmode

This command returns 1 if we are in labmode .

# is\_project\_option\_enabled

#### is\_project\_option\_enabled <option\_name> [-project <string>]

This command returns if a project option is enabled.

| Argument                     | Optional | Description                                                                                                                                       |
|------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| <option_name></option_name>  |          | The name of the project option to retrieve its enabled state. To see a list of valid project options, use the report_project_options TCL command. |
| [-project <string>]</string> | Y        | The optional -project <projectname> option is used to specify an alternate project implementation (by name) to get options for.</projectname>     |

# is\_timing\_met

#### is\_timing\_met [-type <string>]

This command returns 1 if there is positive slack on all critical paths from the last timing run. Otherwise, it returns 0

| Arg                                                                                                                                                                                                                                                                                                                                          | ument   | Optional | Description                                                                                                                                                                                                                                                                    |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-type <s1< td=""><td>tring&gt;]</td><td>Y</td><td>The optional -type <type> option returns 1 if there is positive<br/>slack for all paths of the specified type of path: Setup Check<br/>Met, Setup Check Violated, Hold Check Met, Hold Check<br/>Violated, Hardware Limit, or User-Defined. Otherwise, it<br/>returns 0</type></td></s1<> | tring>] | Y        | The optional -type <type> option returns 1 if there is positive<br/>slack for all paths of the specified type of path: Setup Check<br/>Met, Setup Check Violated, Hold Check Met, Hold Check<br/>Violated, Hardware Limit, or User-Defined. Otherwise, it<br/>returns 0</type> |

# load\_flowscripts

#### load\_flowscripts [-bitstream]

This command loads all of the encrypted flow scripts.

10.1

| Argument     | Optional | Description                              |
|--------------|----------|------------------------------------------|
| [-bitstream] | Y        | load only scripts relevant for bitstream |

### load\_noc\_info

load\_noc\_info <target\_device> [-file <string>]

Loads the NOC register data for the specified device.

| Argument                        | Optional | Description                                                               |
|---------------------------------|----------|---------------------------------------------------------------------------|
| <target_device></target_device> |          | The part name of the Achronix target device, e.g.<br>AC7t1500/AC7t800ES0. |
| [-file <string>]</string>       | Υ        | Override the XML file path with a specific path to register_data.xml.     |

# load\_project

#### load\_project <projectFile> [-not\_active] [-force]

This command loads a project file into ACE. Loading a project file does not load the design files, it just sets up a project for later use.

| Argument                    | Optional | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <projectfile></projectfile> |          | The required <projectfile> argument specifies the path to a project file.</projectfile>                                                                                                                                                                                                                                                                                                                                   |
| [-not_active]               | Y        | If this option is set, no impl in the project will be activated and the active impl in ACE will not be changed.                                                                                                                                                                                                                                                                                                           |
| [-force]                    | Y        | The -force option can be used to override a project lock that has<br>been set by another ACE session. Using -force causes the<br>current ACE session to take ownership of the project lock for the<br>project being restored. DO NOT use this option to run multiple<br>ACE sessions on the same project at the same time, or else<br>output files (acxprj, acxdb, icdb, jam, etc) and log files may<br>become corrupted! |

#### message

message <msg> [-file <string>] [-info] [-warning] [-error] [-none] [-console\_off]
[-console\_on]

This command prints a status message to the console and the log file.

| Argument                  | Optional | Description                                                                         |
|---------------------------|----------|-------------------------------------------------------------------------------------|
| <msg></msg>               |          | The message to be printed.                                                          |
| [-file <string>]</string> | Y        | The TCL channel to use - if set and not 'none', only print the message to the file. |
| [-info]                   | Y        | Make this message an informational message.                                         |
| [-warning]                | Y        | Make this message a warning message.                                                |
| [-error]                  | Y        | Make this message an error message.                                                 |
| [-none]                   | Y        | Make this message a none message (no prefix).                                       |
| [-console_off]            | Y        | turn off console io                                                                 |
| [-console_on]             | Y        | turn on console io                                                                  |

The -file argument, if specified, and not none, can be any TCL-channel - it is not limited to a file. For example:

```
set outfile [open "m.txt" w+]
message -file $outfile -info "Hello World to a file!"
message -file $outfile "Another info message : Hello World2 to a file!"
message -file $outfile -none "This is a message without prefix."
close $outfile
message -file none "This message goes to the console (and your ace-logfile)"
message "And so does this one !"
```

You can specify only one of the -info, -none, -warn, -error options.

### move\_project\_constraints

move\_project\_constraints [-project <string>] <file> <offset>

This command moves a project constraints file to the specified offset to allow re-ordering of constraints within a project.

| Argument                     | Optional | Description                                                                                                                         |
|------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------|
| [-project <string>]</string> | Υ        | The optional -project <projectname> option is used to specify an alternate project (by name) to move constraints for.</projectname> |

| Argument          | Optional | Description                                                                                                   |
|-------------------|----------|---------------------------------------------------------------------------------------------------------------|
| <file></file>     |          | The project constraints file to move.                                                                         |
| <offset></offset> |          | The offset to move the project constraints file to. Other constraints files will be moved down automatically. |

# move\_project\_netlists

move\_project\_netlists [-project <string>] <file> <offset>

This command moves a project netlist file to the specified offset to allow re-ordering of netlists within a project.

| Argument                     | Optional | Description                                                                                                                      |
|------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------|
| [-project <string>]</string> | Y        | The optional -project <projectname> option is used to specify an alternate project (by name) to move netlists for.</projectname> |
| <file></file>                |          | The project netlist file to move.                                                                                                |
| <offset></offset>            |          | The offset to move the project netlist file to. Other netlist files will be moved down automatically.                            |

### move\_project\_source\_file

# move\_project\_source\_file [-project <string>] <file> <offset> [-rtl] [syn\_constraint] [-pnr\_constraint] [-pnr\_netlist] [-sim\_tb]

This command moves a project RTL file to the specified offset to allow re-ordering of RTL files within a project.

| Argument                     | Optional | Description                                                                                                                      |
|------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------|
| [-project <string>]</string> | Y        | The optional -project <projectname> option is used to specify an alternate project (by name) to move RTL file for.</projectname> |
| <file></file>                |          | The project RTL file to move.                                                                                                    |
| <offset></offset>            |          | The offset to move the project RTL file to. Other RTL files will be moved down automatically.                                    |
| [-rtl]                       | Υ        | The optional -rtl option is used to specify the source file to be moved is an RTL file.                                          |

| Argument          | Optional | Description                                                                                                              |
|-------------------|----------|--------------------------------------------------------------------------------------------------------------------------|
| [-syn_constraint] | Y        | The optional -syn_constraint option is used to specify the source file to be moved is a synthesis constraint file.       |
| [-pnr_constraint] | Y        | The optional -pnr_constraint option is used to specify the source file to be moved is a place and route constraint file. |
| [-pnr_netlist]    | Y        | The optional -pnr_netlist option is used to specify the source file to be moved is a place and route netlist file.       |
| [-sim_tb]         | Y        | The optional -pnr_netlist option is used to specify the source file to be moved is a simulation testbench file.          |

# move\_relative\_paths

#### move\_relative\_paths <line> <source> <target>

Change relative paths in input string; starting out relative to parameter source ,returned as relative to parameter target.

| Argument          | Optional | Description                                                  |
|-------------------|----------|--------------------------------------------------------------|
| <line></line>     |          | line containing a quoted string of paths.                    |
| <source/>         |          | The location of the original script containing <line></line> |
| <target></target> |          | The script that will contain <line> and still work.</line>   |

### optimize\_tile

#### optimize\_tile [-verbose] [-timing <int>] [-optimize\_fixed]

optimize placement of single tile or tiles seperately

| Argument              | Optional | Description                                              |
|-----------------------|----------|----------------------------------------------------------|
| [-verbose]            | Y        | use verbose option reporting                             |
| [-timing <int>]</int> | Y        | timing-mode: 1 = timing-driven                           |
| [-optimize_fixed]     | Υ        | change placement of fixed instances - use with caution ! |

### redirect

redirect <command> [-variable <string>] [-noprint] [-printinfo]
redirect messages to variable.

| Argument                      | Optional | Description                        |
|-------------------------------|----------|------------------------------------|
| <command/>                    |          | command to run                     |
| [-variable <string>]</string> | Y        | name of variable                   |
| [-noprint]                    | Y        | just add to variable, do not print |
| [-printinfo]                  | Y        | just print info messages           |

### refresh\_drawing

#### refresh\_drawing

This command refreshes the current custom drawing on the GUI's Floorplanner view.

### regenerate\_all\_ip\_design\_files

#### regenerate\_all\_ip\_design\_files [-ioringOutputDir <string>] [-add\_to\_project]

This command re-generates design files the all ACXIP files in the active ACE project, for both Core fabric IP and IO Ring design.

| Argument                                | Optional | Description                                                                                                                                                                                                                 |
|-----------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-ioringOutputDir<br><string>]</string> | Υ        | The -ioringOutputDir option allows the user to specify a non-default directory path to output the IO Ring design files into.                                                                                                |
| [-add_to_project]                       | Y        | Using the -add_to_project option automatically adds the<br>required generated IO Ring design files to your ACE<br>project. This includes utilization XML, SDC constraints,<br>PDC constraints, and IO Ring bitstream files. |

### remap\_partial\_bitstream

remap\_partial\_bitstream <hex\_file> <original\_clusters> <new\_clusters> [output\_file <string>]

This command returns a list of compatible ordering codes for the active project based on it's device, package, and speed grade.

| Argument                                | Optional | Description                                                                                                                                                           |
|-----------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <hex_file></hex_file>                   |          | The path to the bitstream hex file.                                                                                                                                   |
| <original_clusters></original_clusters> |          | Provide a list of clusters from your original design (i.e.<br>{{LOGIC_CLUSTER_1_1} {LOGIC_CLUSTER_1_2}<br>{LOGIC_CLUSTER_2_1} {LOGIC_CLUSTER_2_2}}).                  |
| <new_clusters></new_clusters>           |          | Provide a list of clusters from your partially<br>reconfigured design (i.e. {{LOGIC_CLUSTER_6_4}<br>{LOGIC_CLUSTER_6_5} {LOGIC_CLUSTER_7_4}<br>{LOGIC_CLUSTER_7_5}}). |
| [-output_file <string>]</string>        | Υ        | Optional output file. If no output file is specified, the<br>command outputs the file to<br><original_hex_file>_remapped.hex</original_hex_file>                      |

# remove\_clock\_preroute

remove\_clock\_preroute <net\_name> <track\_list> [-clock\_regions <list>] [-clusters
<list>] [-placement\_regions <list>] [-partitions <list>]

This command will remove the pre-routing constraints from a clock or reset net on the clock tracks and regions specified.

| Argument                              | Optional | Description                                                                                                                  |
|---------------------------------------|----------|------------------------------------------------------------------------------------------------------------------------------|
| <net_name></net_name>                 |          | The name of the clock or reset net to remove from pre-routing.                                                               |
| <track_list></track_list>             |          | The list of integer clock track numbers to remove from pre-route on this net. Valid clock track numbers are device-specific. |
| [-clock_regions <list>]</list>        | Y        | The list of clock region names to remove from pre-<br>route on this net. Valid clock region names are<br>device-specific.    |
| [-clusters <list>]</list>             | Y        | The list of cluster names to remove from pre-route on this net. Valid cluster names are device-specific.                     |
| [-placement_regions<br><list>]</list> | Y        | The list of placement region names to remove from pre-route on this net. Valid placement region names are device-specific.   |
| [-partitions <list>]</list>           | Y        | The list of partition names to remove from pre-route on this net. Valid partition are device-specific.                       |

# remove\_flow\_step

#### remove\_flow\_step <id>

This command removes an existing flow step from ACE only if the flow step is a user-defined flow step.

| Argument  | Optional | Description                                                                  |
|-----------|----------|------------------------------------------------------------------------------|
| <id></id> |          | The required <id> argument specifies the id of the flow step to remove.</id> |

### remove\_impl

#### remove\_impl <implNames\_list> [-project <string>]

This command removes multiple implementations from a project. The implementations' output directories on the file system are not deleted.

| Argument                          | Optional | Description                                                                                                                                           |
|-----------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| <implnames_list></implnames_list> |          | The required <implnames_list> argument is used to specify the names of the implementations to remove.</implnames_list>                                |
| [-project <string>]</string>      | Υ        | The optional -project <projectname> option is used to specify an alternate project (by name) for the implementation to be removed from.</projectname> |

### remove\_path

```
remove_path [<id>] [-all]
```

This command removes a user-defined pin path.

| Argument     | Optional | Description                            |
|--------------|----------|----------------------------------------|
| [ <id>]</id> | Y        | Specifies the id of the path to remove |
| [-all]       | Y        | Removes all paths                      |

### remove\_project

remove\_project <projectName>

This command removes a project from ACE. The project file on disk is not deleted.

| Argument                    | Optional | Description                                                                                               |
|-----------------------------|----------|-----------------------------------------------------------------------------------------------------------|
| <projectname></projectname> |          | The required <projectname> argument is used to specify the project to be removed (by name).</projectname> |

# remove\_project\_constraints

#### remove\_project\_constraints <files> [-project <string>]

This command removes the link to an SDC, PDC, or TCL constraint file from a project. The SDC constraint file on disk is not deleted.

| Argument                     | Optional | Description                                                                                                                                                |
|------------------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <files></files>              |          | The required <files> argument is used to specify the SDC, PDC, or TCL constraint files (by file path).</files>                                             |
| [-project <string>]</string> | Υ        | The optional -project <projectname> option is used to specify an alternate project (by name) for the SDC constraint file to be removed from.</projectname> |

### remove\_project\_constraints\_pvt

#### remove\_project\_constraints\_pvt <file>

This command allows the user to remove all PVT conditions from an SDC constraint file.

| Argument      | Optional | Description                                                                                      |
|---------------|----------|--------------------------------------------------------------------------------------------------|
| <file></file> |          | The required <file> argument is used to specify the file path to the SDC constraint file.</file> |

### remove\_project\_ip

#### remove\_project\_ip <list\_of\_files> [-project <string>]

This command removes the association from a project to one or more IP settings files. The IP settings files on disk are not deleted.

| Argument                        | Optional | Description                                                                                                                                                                                               |
|---------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <list_of_files></list_of_files> |          | The required <list_of_files> argument is used to specify<br/>the IP settings files (by file path). The file paths may be<br/>absolute, or may be relative to the acxprj file's directory.</list_of_files> |

| Argument                     | Optional | Description                                                                                                                                                                                                          |
|------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-project <string>]</string> | Y        | The optional -project <projectname> option is used to<br/>specify an alternate project (by name) for the IP settings<br/>file to be removed from. The named project must already<br/>be opened in ACE.</projectname> |

### remove\_project\_netlist

remove\_project\_netlist <files> [-project <string>] [-impl <string>]

This command removes the link to a verilog netlist file from a project. The verilog netlist file on disk is not deleted.

| Argument                     | Optional | Description                                                                                                                                            |
|------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| <files></files>              |          | The required <file> argument is used to specify the verilog netlists (by file path).</file>                                                            |
| [-project <string>]</string> | Y        | The optional -project <projectname> option is used to specify an alternate project (by name) for the verilog netlist to be removed from.</projectname> |
| [-impl <string>]</string>    | Y        | If a file belongs to an impl and should be removed only from that impl, specify that impl here.                                                        |

### remove\_project\_source\_files

remove\_project\_source\_files <list\_of\_files> [-ip] [-rtl] [-syn\_constraint] [pnr\_constraint] [-pnr\_netlist] [-sim\_tb] [-project <string>]

This command removes the link to source files from a project. The source files on disk is not deleted.

| Argument                        | Optional | Description                                                                                                          |
|---------------------------------|----------|----------------------------------------------------------------------------------------------------------------------|
| <list_of_files></list_of_files> |          | The required <list_of_files> argument is used to specify a list of source files (by file path).</list_of_files>      |
| [-ip]                           | Y        | The optional -ip option is used to specify the source file to be removed is an IP settings file.                     |
| [-rtl]                          | Y        | The optional -rtl option is used to specify the source file to be removed is an RTL file.                            |
| [-syn_constraint]               | Y        | The optional -syn_constraint option is used to specify the source file to be removed is a synthesis constraint file. |

| Argument                     | Optional | Description                                                                                                                                     |
|------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| [-pnr_constraint]            | Y        | The optional -pnr_constraint option is used to specify the source file to be removed is a place and route constraint file.                      |
| [-pnr_netlist]               | Y        | The optional -pnr_netlist option is used to specify the source file to be removed is a place and route netlist file.                            |
| [-sim_tb]                    | Y        | The optional -pnr_netlist option is used to specify the source file to be removed is a simulation testbench file.                               |
| [-project <string>]</string> | Y        | The optional -project <projectname> option is used to specify an alternate project (by name) for the RTL file to be removed from.</projectname> |

# remove\_region

```
remove_region [-region <string>] [-all]
```

This command removes a placement region constraint specification

| Argument                    | Optional | Description                   |
|-----------------------------|----------|-------------------------------|
| [-region <string>]</string> | Y        | Name of the region to delete  |
| [-all]                      | Y        | Remove all region constraints |

# remove\_region\_insts

```
remove_region_insts <region> [-insts <list>] [-all] [-flops_only] [-clocks_only]
[-verbose]
```

Remove user design instances from an existing placement region constraint

| Argument               | Optional | Description                                                                    |
|------------------------|----------|--------------------------------------------------------------------------------|
| <region></region>      |          | name of the region to clear                                                    |
| [-insts <list>]</list> | Υ        | List of user design instances to remove from this placement region constraint. |
| [-all]                 | Υ        | Clear all user design instances from this region constraint                    |

| Argument       | Optional | Description                                                               |
|----------------|----------|---------------------------------------------------------------------------|
| [-flops_only]  | Y        | When removing instances, filter out all instances except flops            |
| [-clocks_only] | Y        | When removing instances, filter out all instances with no connected clock |
| [-verbose]     | Y        | Print additional debug messages.                                          |

# rename\_impl

### rename\_impl <newImplName> [-project <string>] [-impl <string>]

This command renames an implementation. Changing the name of an implementation also changes the name of the implementation output directory on disk (even without calling "save\_project").

| Argument                     | Optional | Description                                                                                                                                                                                     |
|------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <newimplname></newimplname>  |          | The required <newimpiname> argument is used to specify the new implementation name.</newimpiname>                                                                                               |
| [-project <string>]</string> | Y        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to change the name<br/>for.</implname></projectname> |
| [-impl <string>]</string>    | Y        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to change the name<br/>for.</implname></projectname> |

# report\_clock\_regions

### report\_clock\_regions [-outputfile <string>] [-text] [-csv]

This command generates and writes a formatted report showing which clock nets are routed in each clock region

| Argument                        | Optional | Description                                                                                                                                                                                                                                                         |
|---------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-outputfile <string>]</string> | Y        | The -outputfile <file> option may be used to specify an<br/>output file name or file path. If this option is not present,<br/>the output is written to the default implementation debug<br/>directory and is named <design_name>_regions.html.</design_name></file> |

| Argument | Optional | Description                                                                                                      |
|----------|----------|------------------------------------------------------------------------------------------------------------------|
| [-text]  | Y        | The -text option is used to specify whether the file should be output to the console as plain text               |
| [-csv]   | Y        | The -csv option is used to specify whether the file should be output as a CSV file for use in Excel spreadsheets |

# report\_clocks

report\_clocks

Report clocks in the current design

# report\_coverage

report\_coverage [-outputfile <list>] [-text] [-csv] [-html] [-columns <list>] [verbose]

Generate and write a coverage report for pins.

| Argument                    | Optional | Description                                                                                                                                                                                                                                                                     |
|-----------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-outputfile <list>]</list> | Y        | The optional -outputfile <file> option may be used to<br/>specify an output file name or file path. If this option is not<br/>present, the output is written to the default<br/>implementation reports directory and is named<br/><design_name>_pins.html.</design_name></file> |
| [-text]                     | Y        | The optional -text option is used to specify whether the file should be output as plain text.                                                                                                                                                                                   |
| [-csv]                      | Y        | The optional -csv option is used to specify whether the file should be output as a CSV file for use in Excel spreadsheets.                                                                                                                                                      |
| [-html]                     | Y        | The optional -html option is used to specify whether the file should be output as html-file.                                                                                                                                                                                    |
| [-columns <list>]</list>    | Y        | The optional -columns option is used to specify a customized ordered list of columns names to output in the pin assignment report.                                                                                                                                              |
| [-verbose]                  | Y        | The optional -verbose option is used to specify whether<br>the file should report ALL attributes and parameters for<br>each IO port/pad.                                                                                                                                        |

# report\_design\_stats

# report\_design\_stats [-outputfile <list>] [-html] [-csv] [-text] This command generates and writes a formatted report about various design statistics

| Argument                    | Optional | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-outputfile <list>]</list> | Y        | The -outputfile <file> option specifies a Tcl list of one or more<br/>output file names or file path names. If this option is not<br/>present, the output depends on the -text, -html, and -csv<br/>options. If -text is given the output is written to the GUI console<br/>and Ace logfile. If -html or -csv is given, the output is written to<br/>the default implementation reports directory in a file named<br/><design_name>_design_stats, with the extension .html<br/>or .csv (respectively).</design_name></file> |
| [-html]                     | Y        | The -html option specifies that the output file(s) are written in HTML format (this is the default)                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [-csv]                      | Y        | The -csv option specifies that the output file(s) are written in CSV format for import into Excel spreadsheets                                                                                                                                                                                                                                                                                                                                                                                                              |
| [-text]                     | Y        | The -text option specifies that the output file(s) are written in plain text format                                                                                                                                                                                                                                                                                                                                                                                                                                         |

# report\_impl\_options

```
report_impl_options [-outputfile <string>] [-text] [-csv] [-project <string>] [-
impl <string>] [-hide_values] [-show_standard] [-show_project_options] [-
diff_options]
```

Output a report of the current impl options defined in ACE. If no -project and/or -impl options are specified, the active impl will be reported.

| Argument                        | Optional | Description                                                                                                                                                                                                                                                           |
|---------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-outputfile <string>]</string> | Y        | The optional -outputfile option may be used to specify an<br>output file name or file path. If this option is not present,<br>the output is written to the default implementation<br>reports directory and is named<br><design_name>_impl_options.html.</design_name> |
| [-text]                         | Y        | The optional -text option is used to specify that the file should be output as plain text.                                                                                                                                                                            |

| Argument                     | Optional | Description                                                                                                                                                                                                                                                                 |
|------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-csv]                       | Y        | The optional -csv option is used to specify that the file should be output as a CSV file for use in Excel spreadsheets.                                                                                                                                                     |
| [-project <string>]</string> | Y        | The optional -project <projectname> option must be used<br/>with -impl <implname>. These options are used to<br/>specify an alternate project implementation (by name).</implname></projectname>                                                                            |
| [-impl <string>]</string>    | Y        | The optional -impl <implname> option can be used with<br/>or without the -project <projectname> option to specify<br/>an impl. Without -project <projectname>, -impl<br/><implname> finds the impl in the active project.</implname></projectname></projectname></implname> |
| [-hide_values]               | Y        | If the -hide_values flag is used, the report will NOT output<br>an additional column to display the current values for the<br>given impl.                                                                                                                                   |
| [-show_standard]             | Y        | If the -show_standard flag is used, the report and<br>optional diff options Tcl file will ONLY output standard<br>options that show in the GUI. If this flag is not set, by<br>default, all available options for the active impl will be<br>output.                        |
| [-show_project_options]      | Y        | If the -show_project_options flag is used, the options report table will contain an additional column specifying the option type.                                                                                                                                           |
| [-diff_options]              | Y        | The optional -diff_options flag is used to create a Tcl file<br>containing the full set of implementation options with<br>values which vary from the default values. Each impl<br>option's default value is listed as a comment.                                            |

# report\_partitions

report\_partitions [-outputfile <list>] [-html] [-csv] [-text]

This commands generates and writes a formatted partition report

| Argument                    | Optional | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-outputfile <list>]</list> | Y        | The -outputfile <file> option specifies a Tcl list of one or more<br/>output file names or file path names. If this option is not<br/>present, the output depends on the -text, -html, and -csv<br/>options. If -text is given the output is written to the GUI console<br/>and Ace logfile. If -html or -csv is given, the output is written to<br/>the default implementation reports directory in a file named<br/><design_name>_partitions, with the extension .html or .csv<br/>(respectively).</design_name></file> |
| [-html]                     | Y        | The -html option specifies that the output file(s) are written in HTML format (this is the default)                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [-csv]                      | Y        | The -csv option specifies that the output file(s) are written in CSV format for import into Excel spreadsheets                                                                                                                                                                                                                                                                                                                                                                                                            |
| [-text]                     | Y        | The -text option specifies that the output file(s) are written in plain text format                                                                                                                                                                                                                                                                                                                                                                                                                                       |

# report\_performance

report\_performance [-outputfile <list>] [-html] [-csv] [-text] [<num\_paths>] [setup\_pass\_only]

Generate a report detailing the estimated design performance and the quality of the mapping in ACE, including a critical path breakdown

| Argument                    | Optional | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-outputfile <list>]</list> | Y        | The -outputfile <file> option specifies a Tcl list of one or more<br/>output file names or file path names. If this option is not<br/>present, the output depends on the -text, -html, and -csv<br/>options. If -text is given the output is written to the GUI console<br/>and Ace logfile. If -html or -csv is given, the output is written to<br/>the default implementation reports directory in a file named<br/><design_name>_performance_report, with the<br/>extension .html or .csv (respectively).</design_name></file> |
| [-html]                     | Y        | The -html option specifies that the output file(s) are written in HTML format (this is the default)                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [-csv]                      | Y        | The -csv option specifies that the output file(s) are written in CSV format for import into Excel spreadsheets                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [-text]                     | Y        | The -text option specifies that the output file(s) are written in plain text format                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Argument                   | Optional | Description                                                                 |
|----------------------------|----------|-----------------------------------------------------------------------------|
| [ <num_paths>]</num_paths> | Y        | The number of critical paths to analyze in each clock domain (default is 3) |
| [-setup_pass_only]         | Y        | If set, only paths that meet timing are logged                              |

# report\_pins

report\_pins [-outputfile <list>] [-text] [-csv] [-html] [-columns <list>]
Generate and write a pin to package assignment report

| Argument                    | Optional | Description                                                                                                                                                                                                                                                                     |
|-----------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-outputfile <list>]</list> | Υ        | The optional -outputfile <file> option may be used to<br/>specify an output file name or file path. If this option is not<br/>present, the output is written to the default<br/>implementation reports directory and is named<br/><design_name>_pins.html.</design_name></file> |
| [-text]                     | Υ        | The optional -text option is used to specify whether the file should be output as plain text.                                                                                                                                                                                   |
| [-csv]                      | Υ        | The optional -csv option is used to specify whether the file should be output as a CSV file for use in Excel spreadsheets.                                                                                                                                                      |
| [-html]                     | Υ        | The optional -html option is used to specify whether the file should be output as html-file.                                                                                                                                                                                    |
| [-columns <list>]</list>    | Υ        | The optional -columns option is used to specify a customized ordered list of columns names to output in the pin assignment report.                                                                                                                                              |

# report\_placement

report\_placement [-outputfile <list>] [-html] [-csv] [-text]
This command generates and writes a formatted placement QoR report

| Argument                    | Optional | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-outputfile <list>]</list> | Y        | The -outputfile <file> option specifies a Tcl list of one or more<br/>output file names or file path names. If this option is not<br/>present, the output depends on the -text, -html, and -csv<br/>options. If -text is given the output is written to the GUI console<br/>and Ace logfile. If -html or -csv is given, the output is written to<br/>the default implementation reports directory in a file named<br/><design_name>_placement, with the extension .html or .csv<br/>(respectively).</design_name></file> |
| [-html]                     | Y        | The -html option specifies that the output file(s) are written in HTML format (this is the default)                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [-csv]                      | Y        | The -csv option specifies that the output file(s) are written in CSV format for import into Excel spreadsheets                                                                                                                                                                                                                                                                                                                                                                                                           |
| [-text]                     | Y        | The -text option specifies that the output file(s) are written in plain text format                                                                                                                                                                                                                                                                                                                                                                                                                                      |

### report\_power

report\_power [-outputfile <list>] [-html] [-csv] [-text] [-temperature <string>]
[-clocks <string>] [-achieved] [-saif\_file <string>] [-saif\_top\_level <string>]
This command generates and writes a formatted power dissipation report

| Argument                    | Optional | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-outputfile <list>]</list> | Y        | The -outputfile <file> option specifies a Tcl list of one or<br/>more output file names or file path names. If this option is<br/>not present, the output depends on the -text, -html, and -csv<br/>options. If -text is given the output is written to the GUI<br/>console and Ace logfile. If -html or -csv is given, the output is<br/>written to the default implementation reports directory in a<br/>file named <design_name>_power, with the extension .html<br/>or .csv (respectively).</design_name></file> |
| [-html]                     | Y        | The -html option specifies that the output file(s) are written in HTML format (this is the default)                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [-csv]                      | Y        | The -csv option specifies that the output file(s) are written in CSV format for import into Excel spreadsheets                                                                                                                                                                                                                                                                                                                                                                                                       |
| [-text]                     | Υ        | The -text option specifies that the output file(s) are written in plain text format                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Argument                               | Optional | Description                                                                                                                                                                                                                                                                                                                                     |
|----------------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-temperature <string>]</string>       | Υ        | Report power at the given junction temperatre (in degees C) instead of the currently specified operating condition                                                                                                                                                                                                                              |
| [-clocks <string>]</string>            | Y        | The -clocks <{ {clk1 freq} {clk2 freq} {clkn freq} }> option<br>may be used to specify the operating frequency (in MHz) of<br>all the clocks in the design. If this option is not present, the<br>frequencies from the design constraints will be used by<br>default. If no constraints are found, the best achieved<br>frequency will be used. |
| [-achieved]                            | Y        | The -achieved option may be used to specify that achieved static timing results be used to calculate the power dissipation report for each clock                                                                                                                                                                                                |
| [-saif_file <string>]</string>         | Υ        | The -saif_file option may be used to specify the path to<br>a .saif file. Switching Activity Interchange Format (saif) files<br>can be used to provide a more accurate power profile of a<br>design.                                                                                                                                            |
| [-saif_top_level<br><string>]</string> | Y        | The -saif_top_level option may be used to specify the name of the top level instance in the saif file. Default name used is "DUT".                                                                                                                                                                                                              |

# report\_project\_options

report\_project\_options [-outputfile <string>] [-text] [-csv] [-project <string>]
[-hide\_values] [-show\_standard] [-diff\_options]

Output a report of the current Project options defined in ACE. If no -project option is specified, the active project will be reported.

| Argument                        | Optional | Description                                                                                                                                                                                                                                                           |
|---------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-outputfile <string>]</string> | Y        | The optional -outputfile option may be used to specify an<br>output file name or file path. If this option is not present,<br>the output is written to the default implementation reports<br>directory and is named<br><design_name>_impl_options.html.</design_name> |
| [-text]                         | Υ        | The optional -text option is used to specify that the file should be output as plain text.                                                                                                                                                                            |
| [-csv]                          | Υ        | The optional -csv option is used to specify that the file should be output as a CSV file for use in Excel spreadsheets.                                                                                                                                               |

| Argument                     | Optional | Description                                                                                                                                                                                                                                       |
|------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-project <string>]</string> | Y        | The optional -project <projectname> option is used to specify an alternate project (by name).</projectname>                                                                                                                                       |
| [-hide_values]               | Y        | If the -hide_values flag is used, the report will NOT output<br>an additional column to display the current values for the<br>given project.                                                                                                      |
| [-show_standard]             | Y        | If the -show_standard flag is used, the report and optional<br>diff options Tcl file will ONLY output standard options that<br>show in the GUI. If this flag is not set, by default, all<br>available options for the active impl will be output. |
| [-diff_options]              | Y        | The optional -diff_options flag is used to create a Tcl file<br>containing the full set of project options with values which<br>vary from the default values. Each project option's default<br>value is listed as a comment.                      |

# report\_routing

report\_routing [-outputfile <list>] [-text] [-csv] [-html] [-nonterse] [-terse] [wl] [-overflowreportlimit <int>]

This command generates and writes a formatted routing report.

| Argument                    | Optional | Description                                                                                                                                                                                                                                                                      |
|-----------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-outputfile <list>]</list> | Y        | The optional -outputfile <file> option may be used to<br/>specify an output file name or file path. If this option is<br/>not present, the output is written to the default<br/>implementation debug directory and is named<br/><design_name>_routing.html.</design_name></file> |
| [-text]                     | Υ        | The optional -text option is used to specify whether the file should be output as plain text ( Default is autodetect )                                                                                                                                                           |
| [-csv]                      | Υ        | The optional -csv option is used to specify whether the file should be output as a CSV file for use in Excel spreadsheets.                                                                                                                                                       |
| [-html]                     | Y        | The optional -html option is used to specify whether the file should be output as html-file.                                                                                                                                                                                     |
| [-nonterse]                 | Y        | normal information level.                                                                                                                                                                                                                                                        |
| [-terse]                    | Y        | terse info level.                                                                                                                                                                                                                                                                |

| Argument                              | Optional | Description                                       |
|---------------------------------------|----------|---------------------------------------------------|
| [-wl]                                 | Y        | wire length report.                               |
| [-overflowreportlimit<br><int>]</int> | Y        | limit on the number of overflows. Defaults to 11. |

# report\_utilization

### report\_utilization [-outputfile <list>] [-html] [-csv] [-text]

This command generates and writes a formatted device utilization report

| Argument                    | Optional | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-outputfile <list>]</list> | Y        | The -outputfile <file> option specifies a Tcl list of one or more<br/>output file names or file path names. If this option is not<br/>present, the output depends on the -text, -html, and -csv<br/>options. If -text is given the output is written to the GUI console<br/>and Ace logfile. If -html or -csv is given, the output is written to<br/>the default implementation reports directory in a file named<br/><design_name>_utilization, with the extension .html or .csv<br/>(respectively).</design_name></file> |
| [-html]                     | Υ        | The -html option specifies that the output file(s) are written in HTML format (this is the default)                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [-csv]                      | Υ        | The -csv option specifies that the output file(s) are written in CSV format for import into Excel spreadsheets                                                                                                                                                                                                                                                                                                                                                                                                             |
| [-text]                     | Υ        | The -text option specifies that the output file(s) are written in plain text format                                                                                                                                                                                                                                                                                                                                                                                                                                        |

### reset\_impl\_option

### reset\_impl\_option [<option\_name>] [-all] [-project <string>] [-impl <string>]

This command resets a project implementation option to its (device-specific) default value. Only one option may be reset at a time.

| Argument                       | Optional | Description                                                                                                                              |
|--------------------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------|
| [ <option_name>]</option_name> | Υ        | The name of the impl option to reset to its default. To see<br>a list of valid impl options, use the report_impl_options<br>TCL command. |

| Argument                     | Optional | Description                                                                                                                                                                             |
|------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-all]                       | Y        | The optional -all option resets all impl options to their device-specific default values.                                                                                               |
| [-project <string>]</string> | Y        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to set options for.</implname></projectname> |
| [-impl <string>]</string>    | Y        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to set options for.</implname></projectname> |

### reset\_project\_option

### reset\_project\_option [<option\_name>] [-all] [-project <string>]

This command resets a project option to its (device-specific) default value. Only one option may be reset at a time.

| Argument                       | Optional | Description                                                                                                                                 |
|--------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------|
| [ <option_name>]</option_name> | Y        | The name of the project option to reset to its default. To see a list of valid project options, use the report_project_options TCL command. |
| [-all]                         | Y        | The optional -all option resets all project options to their device-specific default values.                                                |
| [-project <string>]</string>   | Y        | The optional -project <projectname> option is used to specify an alternate project (by name) to set options for.</projectname>              |

### restore\_impl

### restore\_impl <filename> [-project <string>] [-impl <string>]

The restore\_impl command loads an ACXDB file to restore the state of the DB and impl options for a given impl. Restoring an impl automatically makes that impl the active impl. If no -impl and -project options are specified, then the ACXDB file is loaded for the current active impl. By default, the DB will be restored using all saved information in the ACXDB file, including placement and routing information. Restoring an impl overrides the current impl option values with the impl option values saved in the ACXDB file. Restoring an impl clears the current state of the DB for the current active impl, so be sure to save your active impl before restoring an impl.

| Argument              | Optional | Description                                                                |
|-----------------------|----------|----------------------------------------------------------------------------|
| <filename></filename> |          | Specifies the ACXDB file path to restore the state of the active impl from |

| Argument                     | Optional | Description                                                                                                                |
|------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------|
| [-project <string>]</string> | Y        | Specifies an alternate project name to use instead of the active project when using the -impl <implname> option</implname> |
| [-impl <string>]</string>    | Υ        | Specifies an alternate impl name to restore instead of restoring the current active impl                                   |

This functionality is also accessible through buttons/menus in the ACE GUI as described in **Restoring Implementations** (page 301).

#### A Restoring an Implementation clears current data

Restoring an Implementation (page 231) will first clear all data in memory before beginning the restore process. Any data that has not been saved will be lost.

The restored implementation (and project) will become the Active Project and Active Implementation, and all Implementation Options will also be restored from file, overwriting any values currently in memory.

See also: save\_impl (page 706) and Saving Implementations (page 301).

### restore\_project

# restore\_project <projectFile> [-reload] [-not\_active] [-no\_db] [-activeimpl <string>] [-acxdb <string>] [-force]

The restore\_project command loads an ACE project (.acxprj) file and restores the project's implementation options. The -acxdb option can be used to specify the file path of the ACXDB file to restore the DB state for the active implementation. The -activeimpl option can be used to specify the impl name to activate and restore. If -not\_active is used, no impl in the project will be activated or restored from its ACXDB file and the active impl in ACE will not be changed.

| Argument                    | Optional | Description                                                                                                                                                                           |
|-----------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <projectfile></projectfile> |          | Specifies the ACE project (.acxprj) file path to load and restore.                                                                                                                    |
| [-reload]                   | Y        | Use this option to re-load the ACE project (.acxprj) file from disk. This will clear the design DB and flow status, requiring the design to be re-run from the beginning of the flow. |
| [-not_active]               | Y        | If this option is set, no impl in the project will be activated or restored from its ACXDB file and the active impl in ACE will not be changed.                                       |
| [-no_db]                    | Y        | If this option is set, the DB state of the active impl for the project will not be restored.                                                                                          |

| Argument                           | Optional | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-activeimpl<br><string>]</string> | Y        | The -activeimpl option can be used to specify an alternate<br>impl name to activate and restore. By default, the last active<br>impl during the session the project was saved in will be<br>activated.                                                                                                                                                                                                                    |
| [-acxdb <string>]</string>         | Y        | Specifies an ACXDB file path from which to restore the state of the active impl.                                                                                                                                                                                                                                                                                                                                          |
| [-force]                           | Y        | The -force option can be used to override a project lock that<br>has been set by another ACE session. Using -force causes the<br>current ACE session to take ownership of the project lock for<br>the project being restored. DO NOT use this option to run<br>multiple ACE sessions on the same project at the same time,<br>or else output files (acxprj, acxdb, icdb, jam, etc) and log files<br>may become corrupted! |

### run

### run [-step <string>] [-stop\_at\_step <string>] [-resume] [-ic <string>]

This command runs the steps of the design flow. It can be used to run the entire flow from the beginning, run a specific flow step, or resume the flow from the last incomplete step. Using no options will run the entire flow from the beginning. The default Achronix flow step IDs (for those options requiring them) are: {prepare run\_prepare report\_timing\_prepared write\_netlist\_prepared place\_and\_route run\_place report\_timing\_placed run\_route report\_timing\_routed design\_completion post\_process final\_drc\_checks report\_timing\_final write\_netlist\_final fpga\_program write\_bitstream fpga\_download} Because advanced users may create their own flow steps, a complete list of all flow step IDs can be retrieved with the Tcl command 'get\_flow\_steps'.

| Argument                             | Optional | Description                                                                                                                                                                                                          |
|--------------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-step <string>]</string>            | Y        | The optional -step <id> option is used to run the specified<br/>flow step, by ID, (along with any incomplete pre-requisite<br/>steps,) and all of its children. See 'get_flow_steps' for a list<br/>of all IDs.</id> |
| [-stop_at_step<br><string>]</string> | Υ        | The optional -stop_at_step <id> option is used to stop the flow after running the specified flow step, by ID. See 'get_flow_steps' for a list of all IDs.</id>                                                       |
| [-resume]                            | Υ        | The optional -resume option is used to run the entire flow from the last successfully completed flow step.                                                                                                           |

| Argument                | Optional | Description                                                                                                                                                                                                                                                      |
|-------------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-ic <string>]</string> | Y        | The optional -ic init continue option specifies incremental<br>compilation flow modes. 'init' implies beginning of the flow<br>without using previous state of compiled design and<br>'continue' implies incrementally compiling of previous<br>state of design. |

### run\_fanout\_control

run\_fanout\_control [-physical <int>] [-fanout\_limit <int>] [-fanout\_limit\_clone
<int>]

#### This command does fanout control for high fanout control nets

| Argument                          | Optional | Description                                                      |
|-----------------------------------|----------|------------------------------------------------------------------|
| [-physical <int>]</int>           | Υ        | Clone Critical Instances that have slack lower than this limit   |
| [-fanout_limit <int>]</int>       | Υ        | Apply fanout control on nets with fanout greater than this limit |
| [-fanout_limit_clone <int>]</int> | Υ        | Apply fanout cloning on nets with fanout greater than this limit |

## run\_final\_drc\_checks

#### run\_final\_drc\_checks

This command performs final DRC checks on the active design. If there is currently no active project/ implementation, the reports ir and debugdir must be specified.

### run\_fpga\_download

#### run\_fpga\_download [-hex\_file <string>]

This command downloads the generated bitstream to the target device for the active implementation.

| Argument                      | Optional | Description                                                                                                              |
|-------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------|
| [-hex_file <string>]</string> | Y        | Optional hex file to download. The default hex file in<br>your output directory will be used if this is not<br>specified |

### run\_generate\_bitstream

### run\_generate\_bitstream [-outputdir <string>] [-aeskey <string>]

This command generates a bitstream file for programming the target device.

| Argument                       | Optional | Description                                                                                                                 |
|--------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------|
| [-outputdir <string>]</string> | Υ        | Output directory name                                                                                                       |
| [-aeskey <string>]</string>    | Υ        | Key used for encryption. If not given, key is taken from<br>impl. If not active in impl, the bitstream is not<br>encrypted. |

## run\_generate\_final\_reports

#### run\_generate\_final\_reports [-name\_postfix <string>] [-format <string>]

This command generates various report files, including clocks, pins, power, etc. Implementation options are used to control which report files are generated.

| Argument                          | Optional | Description                                                                        |
|-----------------------------------|----------|------------------------------------------------------------------------------------|
| [-name_postfix <string>]</string> | Υ        | Postfix added to report file name (e.g., to distinguish multiple 'placed' reports) |
| [-format <string>]</string>       | Υ        | Specify report formats; default is { text html csv }                               |

## run\_generate\_fullchip\_sim

run\_generate\_fullchip\_sim [-debugdir <string>] [-modelsdir <string>]

This command generates the files necessary for fullchip simulation.

| Argument                       | Optional | Description                                                                                                       |
|--------------------------------|----------|-------------------------------------------------------------------------------------------------------------------|
| [-debugdir <string>]</string>  | Υ        | The -debugdir <dir> option is used to override the default location for debug files during this step.</dir>       |
| [-modelsdir <string>]</string> | Υ        | The -modelsdir <dir> option is used to override the default location for the fullchip sim top-level models.</dir> |

### run\_generate\_netlist

### run\_generate\_netlist [-outputfile <string>] [-final] [-compress]

This command generates a verilog netlist for simulation.

| Argument                        | Optional | Description                    |
|---------------------------------|----------|--------------------------------|
| [-outputfile <string>]</string> | Y        | Output netlist file name.      |
| [-final]                        | Y        | Output DRC-free final netlist  |
| [-compress]                     | Y        | Compress output file with gzip |

### run\_insert\_holdbuffers

run\_insert\_holdbuffers [-margin <int>] [-io\_buffers <int>] [-typebased\_buffers
<int>]

This command generates extra gate delays by inserting a buffer per target pin if that pin has a hold time slack value that is less than the margin specified.

| Argument                            | Optional | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-margin <int>]</int>               | Y        | Insert a delay buffer per target pin whose hold time slack is less than the specified value                                                                                                                                                                                                                                                                                                                                                                                       |
| [-io_buffers <int>]</int>           | Y        | Insert a delay buffer per target pin when driven directly by a flopped IO Pad/Pin                                                                                                                                                                                                                                                                                                                                                                                                 |
| [-typebased_buffers<br><int>]</int> | Y        | Insert a delay buffer per target pin according to the given<br>cell-type bitfield specification (2^0 = DFF inputs, 2^1 = DFF<br>outputs, 2^2 = clocked OPIN inputs, 2^3 = clocked IPIN<br>outputs, 2^4=BRAM inputs, 2^5 = BRAM outputs, 2^6 =<br>LRAM inputs, 2^7 = LRAM outputs, 2^8 = DSP inputs, 2^9 =<br>DSP outputs, 2^10 = MLP inputs, 2^11 = MLP outputs, 2^12<br>= NAP inputs, 2^13 = NAP outputs). All other values are<br>reserved for future use and should be unset.) |

### run\_multiprocess

```
run_multiprocess [-use_existing_impls <list>] [-use_seeds <list>] [-
parallel_job_count <int>] [-use_job_submission <int>] [-stop_flow_at <string>] [-
copy_icdb <int>] [-jobs_exec <string>] [-jobs_wd <string>] [-jobs_name <string>] [-
jobs_log <string>] [-jobs_args <list>] [-jobs_nfs_latency <int>] [-
create_option_sets] [-exclude_synthesis] [-remove_nonbest]
```

This command runs the ACE multiprocess flow for the active implementation. To generate new implementations from option sets and run multiprocess, use -create\_option\_sets. NOTE: For any optional arguments that are not specified, the current Multiprocess configuration from the ACE GUI User Preferences will be used as defaults.

| Argument                               | Optional | Description                                                                                                                                                                                                                                                                       |
|----------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-use_existing_impls<br><list>]</list> | Y        | The use_existing_impls option allows the user to specify a<br>list of existing impl names to run in multiprocess, instead of<br>using seed sweep or generating impls from option sets. To<br>run all existing impls, you can specify -use_existing_impls<br>[ace::get_impl_names] |
| [-use_seeds <list>]</list>             | Y        | The use_seeds option allows the user to specify a list of PnR seed values to run in multiprocess, instead of using existing impls or generating impls from option sets.                                                                                                           |
| [-parallel_job_count<br><int>]</int>   | Υ        | (optional) Sets the number of implementations to run in parallel. If not specified, defaults to the GUI's preference setting.                                                                                                                                                     |
| [-use_job_submission<br><int>]</int>   | Y        | (optional) Set to a 0 to run background jobs on the local<br>machine, or set to a 1 to submit jobs to a cloud/grid/batch<br>submission system. If not specified, defaults to the GUI's<br>preference setting.                                                                     |
| [-stop_flow_at<br><string>]</string>   | Y        | (optional) If a valid flow step ID is specified, that flow step<br>will be enabled and will be the last flow step executed by all<br>implementations. If not specified, ACE will run the entire<br>flow (ignores user's GUI preference setting).                                  |
| [-copy_icdb <int>]</int>               | Y        | (optional) Set to a 1 to copy the incremental flow DB from<br>the template impl, or set to a 0 to not copy. Defaults to 0 (no<br>file copy) if not specified (ignores user's GUI preference<br>setting).                                                                          |
| [-jobs_exec <string>]</string>         | Y        | (optional) Specify the job submission system executable.<br>Relevant only when a job submission system is in use. If not<br>specified, defaults to the GUI's preference setting.                                                                                                  |
| [-jobs_wd <string>]</string>           | Y        | (optional) Specify the job submission system working<br>directory argument. Relevant only when a job submission<br>system is in use. If not specified, defaults to the GUI's<br>preference setting.                                                                               |
| [-jobs_name <string>]</string>         | Y        | (optional) Specify the job submission system job name<br>argument. Relevant only when a job submission system is in<br>use. If not specified, defaults to the GUI's preference setting.                                                                                           |
| [-jobs_log <string>]</string>          | Y        | (optional) Specify the job submission system job log<br>argument. Relevant only when a job submission system is in<br>use. If not specified, defaults to the GUI's preference setting.                                                                                            |

| Argument                           | Optional | Description                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-jobs_args <list>]</list>         | Y        | (optional) Specify the job submission system list of<br>additional arguments, each with at most one optional value,<br>formatted as a list of TCL lists in the form: {{arg1 val1} {arg2}<br>{arg3 val3} }. Relevant only when a job submission system<br>is in use. If not specified, defaults to the GUI's preference<br>setting.                                                                                          |
| [-jobs_nfs_latency<br><int>]</int> | Y        | (optional) Specify the allowed seconds of NFS write latency<br>(how long to wait between process completion and reading<br>the files generated by the just-finished process). This is<br>relevant both to local background jobs, and job submission<br>systems. If not specified, defaults to the GUI's preference<br>setting.                                                                                              |
| [-create_option_sets]              | Y        | (optional) Auto-generate option sets relevant to the active<br>implementation, which will appear the active impl's<br>option_sets directory. Note that this is only relevant when<br>neither -use_existing_impls nor -use_seeds are active<br>(meaning we're in the default mode, generating new impls<br>for option sets).                                                                                                 |
| [-exclude_synthesis]               | Y        | (optional) Auto-generate option sets excluding synthesis<br>options relevant to the active implementation, which will<br>appear the active impl's option_sets directory. This option is<br>ignored if 'run_synthesis' flow step is disabled. Note that<br>this is only relevant when neither -use_existing_impls nor<br>-use_seeds are active (meaning we're in the default mode,<br>generating new impls for option sets). |
| [-remove_nonbest]                  | Y        | (optional) Removes all recently generated implementations from the Projects View, except for the base impl and best impl, at the end of the Multiprocess run.                                                                                                                                                                                                                                                               |

#### (i) Default Values

For any parameters that are not specified, the ACE GUI user preferences will be used.

For example, if <code>-parallel\_job\_count</code> is not explicitly specified, and if your ACE GUI user preferences are currently configured to use four (4) jobs, that value will be used for your batch multiprocess run.

A more detailed description of the use of run\_multiprocess can be found in the **Multiprocess Batch Mode** (page 317) section.

The GUI provides a graphical interface for multiprocess through the Multiprocess View (page 75). See also: Running Multiple Flows in Parallel (page 307), Attempting Likely Optimizations Using Option Sets (page 392).

### run\_multiprocess\_iterator

run\_multiprocess\_iterator [-use\_existing\_impls <list>] [-use\_seeds <list>] [parallel\_job\_count <int>] [-use\_job\_submission <int>] [-stop\_flow\_at <string>] [copy\_icdb <int>] [-jobs\_exec <string>] [-jobs\_wd <string>] [-jobs\_name <string>] [jobs\_log <string>] [-jobs\_args <list>] [-jobs\_nfs\_latency <int>] [create\_option\_sets] [-exclude\_synthesis] [-remove\_nonbest] [-iterations <int>]

This command runs the ACE multiprocess flow for the active implementation for 5 (default) iterations, each time selecting the 'best' impl option for the subsequent multiprocess run. To run the same multiprocess flow as run\_multiprocess, this command is exposed to all options from run\_multiprocess. To run multiprocess with option sets, use -create\_option\_sets.

| Argument                               | Optional | Description                                                                                                                                                                                                                                                                       |
|----------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-use_existing_impls<br><list>]</list> | Y        | The use_existing_impls option allows the user to specify a<br>list of existing impl names to run in multiprocess, instead of<br>using seed sweep or generating impls from option sets. To<br>run all existing impls, you can specify -use_existing_impls<br>[ace::get_impl_names] |
| [-use_seeds <list>]</list>             | Y        | The use_seeds option allows the user to specify a list of PnR seed values to run in multiprocess, instead of using existing impls or generating impls from option sets.                                                                                                           |
| [-parallel_job_count<br><int>]</int>   | Y        | (optional) Sets the number of implementations to run in parallel. If not specified, defaults to the GUI's preference setting.                                                                                                                                                     |
| [-use_job_submission<br><int>]</int>   | Y        | (optional) Set to a 0 to run background jobs on the local<br>machine, or set to a 1 to submit jobs to a cloud/grid/batch<br>submission system. If not specified, defaults to the GUI's<br>preference setting.                                                                     |
| [-stop_flow_at<br><string>]</string>   | Y        | (optional) If a valid flow step ID is specified, that flow step<br>will be enabled and will be the last flow step executed by all<br>implementations. If not specified, ACE will run the entire<br>flow (ignores user's GUI preference setting).                                  |
| [-copy_icdb <int>]</int>               | Y        | (optional) Set to a 1 to copy the incremental flow DB from<br>the template impl, or set to a 0 to not copy. Defaults to 0 (no<br>file copy) if not specified (ignores user's GUI preference<br>setting).                                                                          |
| [-jobs_exec <string>]</string>         | Y        | (optional) Specify the job submission system executable.<br>Relevant only when a job submission system is in use. If not<br>specified, defaults to the GUI's preference setting.                                                                                                  |

| Argument                           | Optional | Description                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-jobs_wd <string>]</string>       | Y        | (optional) Specify the job submission system working<br>directory argument. Relevant only when a job submission<br>system is in use. If not specified, defaults to the GUI's<br>preference setting.                                                                                                                                                                                                                         |
| [-jobs_name <string>]</string>     | Y        | (optional) Specify the job submission system job name<br>argument. Relevant only when a job submission system is in<br>use. If not specified, defaults to the GUI's preference setting.                                                                                                                                                                                                                                     |
| [-jobs_log <string>]</string>      | Y        | (optional) Specify the job submission system job log<br>argument. Relevant only when a job submission system is in<br>use. If not specified, defaults to the GUI's preference setting.                                                                                                                                                                                                                                      |
| [-jobs_args <list>]</list>         | Y        | (optional) Specify the job submission system list of<br>additional arguments, each with at most one optional value,<br>formatted as a list of TCL lists in the form: {{arg1 val1} {arg2}<br>{arg3 val3} }. Relevant only when a job submission system<br>is in use. If not specified, defaults to the GUI's preference<br>setting.                                                                                          |
| [-jobs_nfs_latency<br><int>]</int> | Y        | (optional) Specify the allowed seconds of NFS write latency<br>(how long to wait between process completion and reading<br>the files generated by the just-finished process). This is<br>relevant both to local background jobs, and job submission<br>systems. If not specified, defaults to the GUI's preference<br>setting.                                                                                              |
| [-create_option_sets]              | Y        | (optional) Auto-generate option sets relevant to the active<br>implementation, which will appear the active impl's<br>option_sets directory. Note that this is only relevant when<br>neither -use_existing_impls nor -use_seeds are active<br>(meaning we're in the default mode, generating new impls<br>for option sets).                                                                                                 |
| [-exclude_synthesis]               | Y        | (optional) Auto-generate option sets excluding synthesis<br>options relevant to the active implementation, which will<br>appear the active impl's option_sets directory. This option is<br>ignored if 'run_synthesis' flow step is disabled. Note that<br>this is only relevant when neither -use_existing_impls nor<br>-use_seeds are active (meaning we're in the default mode,<br>generating new impls for option sets). |
| [-remove_nonbest]                  | Y        | (optional) Removes all recently generated implementations<br>from the Projects View, except for the base impl and best<br>impl, at the end of the Multiprocess run.                                                                                                                                                                                                                                                         |

| Argument                  | Optional | Description                                                                                              |
|---------------------------|----------|----------------------------------------------------------------------------------------------------------|
| [-iterations <int>]</int> | Y        | The iterations option allows the user to specify the number of iterations between 1 and 5. Default is 5. |

#### Warning: Early Access Functionality

This multiprocess iterator (along with the QoR sorting of the **Multiprocess Summary Report** (page 256)) should currently be considered early-access functionality. Future ACE releases may improve QoR, reduce runtimes, and require fewer iterations to achieve similar results.

See also: run\_multiprocess (page 693), Multiprocess View (page 75), Running Multiple Flows in Parallel (page 307), Attempting Likely Optimizations Using Option Sets (page 392), Multiprocess Batch Mode (page 317)

### run\_place

#### run\_place

This command clears all routing and places the design.

### run\_post\_process

#### run\_post\_process

This command post-processes the routed design to insert reset and other Achronix-specific technologies.

### run\_prepare

#### run\_prepare [-ic <string>]

This command clears the current netlist and constraints data, then loads all the design files for the active implementation, runs design checks, and compiles the design into an Achronix design.

| Argument                | Optional | Description                                                                                                                                                                                                                                                   |
|-------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-ic <string>]</string> | Y        | The optional -ic init continue option specifies incremental<br>compilation flow modes. 'init' implies beginning the flow<br>without using previous state of compiled design and<br>'continue' implies incrementally compiling of previous state<br>of design. |

### run\_route

#### run\_route

This command routes the design.

### run\_secureshare

#### run\_secureshare [-read\_manifest <string>] [-generate\_manifest <string>] [archive\_path <string>] [-encrypt] [-wizard] [-force]

Read or generate a SecureShare Manifest File, and create a zipped (and optionally encrypted) archive containing project source, database, log, report, and debug files. To receive better support, please attach this zip to your Achronix support ticket.

| Argument                                  | Optional | Description                                                                                                                                                                                                                                                        |
|-------------------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-read_manifest<br><string>]</string>     | Υ        | Manifest file path read to generate an archive (unless<br>-no_archive is specified). Cannot be used with<br>-generate_manifest.                                                                                                                                    |
| [-generate_manifest<br><string>]</string> | Y        | Manifest file output path, and default archive output path<br>(unless -archive_path is specified). Cannot be used with<br>-read_manifest.                                                                                                                          |
| [-archive_path <string>]</string>         | Y        | Archive output path, which can override the output directory within a manifest when using -read_manifest                                                                                                                                                           |
| [-encrypt]                                | Y        | Encrypt the archive. With -read_manifest, the archive is<br>always encrypted (unless -no_archive is specified). With<br>-generate_manifest, the manifest is marked for<br>encryption, and the generated archive is encrypted<br>(unless -no_archive is specified). |
| [-wizard]                                 | Y        | Generate a manifest and then open the GUI file-picker.                                                                                                                                                                                                             |
| [-force]                                  | Υ        | Overwrite generated output files.                                                                                                                                                                                                                                  |

### Why is this command taking so long?

In some cases, such as when the home directory is mounted to a network drive, reading the log files can be quite slow.

To skip this step run, add the following flag to the run\_secureshare command:

| Argument                    | Optional | Description                                                                 |
|-----------------------------|----------|-----------------------------------------------------------------------------|
| [-skip_home_directory_logs] | Υ        | When generating a manifest, do not search the home directory for log files. |

### Example

Running the command with no arguments will automatically generate a SecureShare manifest and archive using the current active impl:

run\_secureshare

If you'd like to create the archive in a specific location, rather than the project default, use:

run\_secureshare -archive\_path <output\_path>

A The file extension for a regular SecureShare archive will always be .zip

To encrypt the archive, use:

run\_secureshare -encrypt

A The file extension for an encrypted SecureShare archive will always be .zip.encrypted

To generate an archive from a previously created manifest, use:

run\_secureshare -read\_manifest <manifest\_path.acxssm>

This will read the .acxssm manifest file, which includes the archive output directory and encryption status, and generate an archive using these options.

You can override the manifest with the -archive\_path <output\_path> and -encrypt options.

If you'd like to automatically create a manifest without generating an archive, use:

run\_secureshare -no\_archive

To specify the manifest path, use:

run\_secureshare -generate\_manifest <manifest\_path>

A The file extension for a SecureShare manifest will always be .acxssm

To overwrite manifest and archive outputs, as well as create missing directories, use:

run\_secureshare -force

### run\_simulation

```
run_simulation [-rtl] [-gate] [-routed] [-final]
```

This command runs custom simulator commands to simulate user design.

| Argument  | Optional | Description                              |
|-----------|----------|------------------------------------------|
| [-rtl]    | Y        | Run RTL Simulation (this is the default) |
| [-gate]   | Y        | Run Gate-level Netlist Simulation        |
| [-routed] | Y        | Run Post-Route Netlist Simulation        |
| [-final]  | Y        | Run Final Netlist Simulation             |

### run\_snapshot

```
run_snapshot <snapshotFile> [-jtag_id <string>] [-ir_bits_before <int>] [-
ir_bits_after <int>] [-target_offset <int>] [-startup_trigger] [-timeout <int>] [-
cleanse_snapshot_file] [-verbose]
```

This command runs the Snapshot Debugger for a given Snapshot configuration (.snapshot file). This command outputs a VCD file and a Log file. The file paths are specified in the Snapshot configuration file.

| Argument                      | Optional | Description                                                                                                                                |
|-------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------|
| <snapshotfile></snapshotfile> |          | The required <snapshotfile> argument specifies the Snapshot configuration (.snapshot file) to be used by Snapshot debugger.</snapshotfile> |
| [-jtag_id <string>]</string>  | Y        | The unique ID of JTAG device to communicate with                                                                                           |

| Argument                      | Optional | Description                                                                                                                                                                                   |
|-------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-ir_bits_before <int>]</int> | Υ        | Number of instruction register bits in the scan chain<br>before the target device. Default: set to 0 for single<br>device scan chains                                                         |
| [-ir_bits_after <int>]</int>  | Υ        | Number of instruction register bits in the scan chain<br>after the target device. Default: set to 0 for single device<br>scan chains                                                          |
| [-target_offset <int>]</int>  | Υ        | Target device offset in the scan chain. A value of 0<br>indicates the first device on the scan chain that receives<br>TDI from the JTAG programmer device. Default: 0                         |
| [-startup_trigger]            | Υ        | Run Snapshot Startup Trigger to capture the startup trigger in the Snapshot Debugger. Default: Snapshot Arm                                                                                   |
| [-timeout <int>]</int>        | Υ        | Specifies the timeout (in seconds) before Snapshot is<br>cancelled while waiting for all trigger conditions to occur.<br>If not specified, Snapshot will not timeout.                         |
| [-cleanse_snapshot_file]      | Υ        | Cleanse the Snapshot (.snapshot) file content before<br>beginning normal work. This is typically only needed<br>when a *.snapshot file fails to load, and at most is<br>needed once per file. |
| [-verbose]                    | Y        | Exposes additional log info when running Snapshot.                                                                                                                                            |

See also: Running the Snapshot Debugger (page 363), Snapshot User Guide (UG016)

### Cleansing the .snapshot file

This is normally not necessary, but if any \*.snapshot file fails to load, try using this functionality once per file (cleansing a file a second time with the same version of ACE will have no effect). When enabled, this opens the file, performs a validate-cleanse-and-version-upgrade pass on the content, and re-saves the cleansed content to the same filename/path, overwriting the prior content. Cleansing occurs before beginning normal (arm or startup\_trigger) Snapshot processing. Cleansing will only be necessary with files that fail to load successfully; these are typically files which have been hand-edited, or with files which are several years old. Note that cleansing adds 10s-30s of runtime, thus cleansing is disabled by default.

### run\_synthesis

#### run\_synthesis

This command synthesizes the user design RTL using the specified synthesis constraints.

# run\_timing\_analysis

```
run_timing_analysis [-prepared] [-placed] [-routed] [-final] [-name_postfix
<string>] [-format <string>] [-temperature <string>] [-voltage <string>] [-grade
<string>]
```

This command runs timing analysis on the design.

| Argument                          | Optional | Description                                                                        |
|-----------------------------------|----------|------------------------------------------------------------------------------------|
| [-prepared]                       | Y        | Indicates that the design has only been prepared (this is the default)             |
| [-placed]                         | Υ        | Indicates that the design has been placed but not routed                           |
| [-routed]                         | Υ        | Indicates that the design has been placed and routed                               |
| [-final]                          | Y        | Indicates that this is sign-off timing (this involves some extra checks)           |
| [-name_postfix <string>]</string> | Y        | Postfix added to report file name (e.g., to distinguish multiple 'placed' reports) |
| [-format <string>]</string>       | Y        | Specify report formats; default is { text html csv }                               |
| [-temperature <string>]</string>  | Υ        | The temperature selection to do timing analysis at a PVT corner                    |
| [-voltage <string>]</string>      | Υ        | The voltage selection to do timing analysis at a PVT corner                        |
| [-grade <string>]</string>        | Y        | The speed grade selection to do timing analysis at a PVT corner                    |

See also: Generating Timing Reports (page 352), Timing Report (page 245), Timing Across All Temperature Corners (page 266)

### run\_tool

### run\_tool <id> [-args <string>]

This command runs a registered tool executable by tool ID, as specified in the ACE extensions config.xml file.

10.1

| Argument                  | Optional | Description                                                                                                                             |
|---------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------|
| <id></id>                 |          | The required <id> argument must match a registered tool executable by tool ID, as specified in the ACE extensions config.xml file.</id> |
| [-args <string>]</string> | Y        | The optional -args <tool_args> option is used to pass commandline arguments to the underlying tool.</tool_args>                         |

### run\_un\_post\_process

run\_un\_post\_process [-reportsdir <string>] [-debugdir <string>] [-reroute]
This command removes design post-processing.

| Argument                        | Optional | Description                                                                                                             |
|---------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------|
| [-reportsdir <string>]</string> | Y        | The optional -reportsdir <dir> option is used to override the default location for report files during this step.</dir> |
| [-debugdir <string>]</string>   | Υ        | The optional -debugdir <dir> option is used to override the default location for debug files during this step.</dir>    |
| [-reroute]                      | Υ        | The optional -reroute option is used to re-route the affected nets after un_post_process                                |

# run\_unplace

run\_unplace [-fixed] [-boundary] [-core] [-constants] [-insts <list>]
Unplace instances in the design

| Argument               | Optional | Description                                                                     |
|------------------------|----------|---------------------------------------------------------------------------------|
| [-fixed]               | Y        | Unplace instances with fixed placement constraints as well as movable instances |
| [-boundary]            | Y        | Only unplace boundary instances                                                 |
| [-core]                | Y        | Only unplace core elements                                                      |
| [-constants]           | Y        | Only unplace constant sources                                                   |
| [-insts <list>]</list> | Y        | Only unplace the instances specified in this list                               |

### run\_unroute

```
run_unroute [-net <string>] [-pin <string>] [-nets <list>] [-regions <list>] [-
regionarea <list>] [-nocore] [-clock_only] [-core] [-keepsametile] [-uniqify] [-
consts] [-keepconsts]
```

Remove all or parts of a routing.

| Argument                    | Optional | Description                                  |
|-----------------------------|----------|----------------------------------------------|
| [-net <string>]</string>    | Y        | Only remove routing for given net            |
| [-pin <string>]</string>    | Y        | Only remove routing for given pin            |
| [-nets <list>]</list>       | Y        | unroute only the nets specified in this list |
| [-regions <list>]</list>    | Y        | unroute only the nets in the given regions   |
| [-regionarea <list>]</list> | Y        | unroute only the nets in the given regions   |
| [-nocore]                   | Y        | unroute only nets in the I/O-ring            |
| [-clock_only]               | Y        | only unroute clock nets                      |
| [-core]                     | Y        | only unroute core nets                       |
| [-keepsametile]             | Y        | keep all same-tile - connections             |
| [-uniqify]                  | Y        | make constants unique again                  |
| [-consts]                   | Y        | only unroute constants                       |
| [-keepconsts]               | Y        | do NOT unroute constants                     |

# save\_clock\_preroute

# save\_clock\_preroute [-outputfile <string>] [-add\_to\_project] This command will save the pre-routing constraints to a PDC file.

| Argument                        | Optional | Description                                                                                                                                                                                                                                                                                                                  |
|---------------------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-outputfile <string>]</string> | Y        | The optional -outputfile <file> option is used to specify the<br/>file path to which the add_clock_preroute commands will<br/>be saved. If this option is not used, the file will be saved to<br/><project_dir>/<impl_dir>/pnr/output/<br/><project_name>_clock_preroutes.pdc</project_name></impl_dir></project_dir></file> |

| Argument          | Optional | Description                                                                                                                                                                                                              |
|-------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-add_to_project] | Y        | The optional -add_to_project option is used to specify that<br>the file should be automatically added to the active project.<br>If this is omitted, the generated PDC file is not<br>automatically added to any project. |

### save\_impl

### save\_impl <filename> [-no\_log]

The save\_impl command always uses the active impl, since only the active impl is connected to the live DB state. All other impls have no live DB state. The save\_impl command saves the state of an impl (impl options and db state) to a .acxdb file. By default, the .acxdb file will save the entire state of the current DB, including placement and routing information. If an impl is saved before running the prepare flow step, a warning message will be printed and only the impl options will be saved, since the DB has not been prepared.

| Argument              | Optional | Description                                                                                                                                     |
|-----------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| <filename></filename> |          | Specifies the ACXDB file path where the active impl state should be saved                                                                       |
| [-no_log]             | Υ        | If the -no_log option is set, no additional debug information will be saved in the ACXDB file, including log files from the current ACE session |

This functionality is also accessible through buttons/menus in the ACE GUI – see Saving Implementations (page 301). See also: restore\_impl (page 688) and Restoring Implementations (page 301).

# save\_partition\_placements

```
save_partition_placements [-outputfile <string>] [-partition <string>] [-
add_to_project]
```

Save the partition placement constraints to a PDC file which can be added to the active project.

| Argument                        | Optional | Description                                                                                                                                       |
|---------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| [-outputfile <string>]</string> | Y        | The name of the output file                                                                                                                       |
| [-partition <string>]</string>  | Y        | The name of the specific partition to save.                                                                                                       |
| [-add_to_project]               | Υ        | The optional -add_to_project option is used to specify whether the generated PDC file should automatically be added to the active project or not. |

# save\_placement

save\_placement [-iofile <string>] [-corefile <string>] [-add] [-output\_regions] [create\_iopins] [-io\_only] [-iopins\_only] [-core\_only] [-fixed\_only] [-fix] [device\_port\_names] [-instances <list>]

Save the current placement to one or more files as a set of pre-placement commands

| Argument                      | Optional | Description                                                                                                                                                                                                                                                     |
|-------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-iofile <string>]</string>   | Y        | The -iofile <file> option is used to specify the file path to<br/>save the IO Ring Boundary instance pre-placement<br/>commands to. If this option is not used, the file will be<br/>saved to the active project's directory as<br/>io_preplacement.pdc.</file> |
| [-corefile <string>]</string> | Y        | The -corefile <file> option is used to specify the file path to<br/>save the Core instance pre-placement commands to. If<br/>this option is not used, the file will be saved to the active<br/>project's directory as core_preplacement.pdc</file>              |
| [-add]                        | Y        | The -add option specifies that the outputfile should be<br>automatically added to the active project's constraints. (It<br>will be added to the end of the constraints list, and will<br>thus be the last constraints file loaded.)                             |
| [-output_regions]             | Y        | The -output_regions option is used to enable output of region constraints into the Core PDC file (or IO Ring Boundary PDC file if -io_only is used)                                                                                                             |
| [-create_iopins]              | Y        | The -create_iopins option is used to enable output of<br>create_boundary_pin commands into the IO Ring<br>Boundary PDC file                                                                                                                                     |
| [-io_only]                    | Y        | The -io_only option is used to specify whether only the IO<br>Ring Boundary pre-placement file is output or not                                                                                                                                                 |
| [-iopins_only]                | Y        | The -iopins_only option allows you to save only the placement of the boundary pin instances                                                                                                                                                                     |
| [-core_only]                  | Y        | The -core_only option is used to specify whether only the<br>Core pre-placement file is output or not                                                                                                                                                           |
| [-fixed_only]                 | Y        | The -fixed_only option is used to specify whether only<br>Fixed Instance placement data is output or not                                                                                                                                                        |
| [-fix]                        | Y        | The -fix option forces all saved placements to be "fixed"<br>placement, allowing you to lock down all of your placed<br>instances                                                                                                                               |

| Argument                   | Optional | Description                                                                                                                                                                                            |
|----------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-device_port_names]       | Y        | The -device_port_names option is used to specify<br>whether device port names should be output for IPINs/<br>OPINs instead of site names                                                               |
| [-instances <list>]</list> | Y        | The -instances <instances> option is used to specify a specific list of design instances you want to save placement for. You can call the find command to pass its results to this option.</instances> |

# save\_project

### save\_project [-project <string>] [-outputfile <string>] [-acxdb <string>] [no\_log]

The save\_project command saves the state of an ACE project to a .acxprj project file. By default, the active project is saved, unless the -project option is specified. The project is saved to the original project file path unless -outputfile is used. If the project contains the current active impl, the state of the DB can optionally be saved to an .acxdb file using the -acxdb option.

| Argument                        | Optional | Description                                                                                                                                           |
|---------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-project <string>]</string>    | Y        | The optional -project <projectname> option may be used to specify a project to write out.</projectname>                                               |
| [-outputfile <string>]</string> | Y        | The optional -outputfile <projectfile> option may be used to specify an output file location.</projectfile>                                           |
| [-acxdb <string>]</string>      | Y        | Enables output of an ACXDB file for the active implementation and requires a file path to save the state of the active impl to                        |
| [-no_log]                       | Y        | If the -no_log option is set, no additional debug<br>information will be saved in the ACXDB file, including<br>log files from the current ACE session |

### save\_properties

### save\_properties [-outputfile <string>] [-add]

This command is used to save all changed properties on objects in the DB after prepare has been run.

| Argument                        | Optional | Description                                                                                                                                                                                                                             |
|---------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-outputfile <string>]</string> | Y        | The optional -outputfile <file> option is used to specify the file path to which the set_property commands will be saved. If this option is not used, the file will be saved to the active project's directory as properties.sdc</file> |
| [-add]                          | Y        | The optional -add option is used to specify that the file<br>should be automatically added to the active project. If this<br>is omitted, the file of changed properties is not<br>automatically added to any project.                   |

# save\_regions

save\_regions [-outputfile <string>] [-region <string>] [-all] [-explicit] [-add]
Save the placement region constraints to a file, using a TCL command history list approach by default.

| Argument                        | Optional | Description                                                                                                                                            |
|---------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-outputfile <string>]</string> | Y        | The name of the output file                                                                                                                            |
| [-region <string>]</string>     | Y        | The name of the region to save. Saves explicit instance list.                                                                                          |
| [-all]                          | Y        | Save all regions (default)                                                                                                                             |
| [-explicit]                     | Y        | Save explicit lists of instances constrained to each region, as opposed to saving the sequence of TCL commands used to build up the region constraints |
| [-add]                          | Y        | The optional -add option is used to specify whether the file automatically added to the active project or not.                                         |

### select

### select <objects> [-clear]

This command is used to control the current object selection.

| Argument            | Optional | Description                                                                                                                                                                         |
|---------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <objects></objects> |          | The required <objects> argument specifies a list of objects to append to the current selection. Objects must be prepended with object type prefixes (see "find" command).</objects> |

| Argument | Optional | Description                                                                                   |
|----------|----------|-----------------------------------------------------------------------------------------------|
| [-clear] | Υ        | The optional -clear flag is used to deselect all objects before performing the select action. |

The ACE GUI provides a graphical interface for this command through the Selection View (page 137). See also: Object Type Prefixes (page 334), Search View (page 133), find (page 638), Selecting Objects in the Floorplanner (page 340), trace\_connections. (page 718)

### set\_active\_impl

#### set\_active\_impl <implName> [-project <string>]

This command sets the active implementation for the current ACE session. The active implementation controls which implementation the flow and project management commands are operating on.

| Argument                     | Optional | Description                                                                                                                                            |
|------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| <implname></implname>        |          | The required <implname> argument is used to specify<br/>the name of the implementation to set as the active<br/>implementation.</implname>             |
| [-project <string>]</string> | Υ        | The optional -project <projectname> option is used to specify an alternate project (by name) for the active implementation to be set in.</projectname> |

### set\_clock\_type

set\_clock\_type <clock> [-batch] [-boundary] [-trunk] [-minitrunk] [-data\_region]
[-data\_center] [-data\_local] [-data\_column]

Set properties of a clock. If a non-driving (target) clock pin is specified, a local property is set for that pin only.

| Argument        | Optional | Description                                                                                                                                                                              |
|-----------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <clock></clock> |          | net or pin ('inst/pin')                                                                                                                                                                  |
| [-batch]        | Y        | Postpone application of this constraint until<br>apply_placement is called at the end of run_prepare. This<br>is useful for nets that are created or renamedby ACE during<br>run_prepare |
| [-boundary]     | Y        | boundary clock (not routed through the trunk)                                                                                                                                            |
| [-trunk]        | Y        | trunk clock                                                                                                                                                                              |

| Argument       | Optional | Description                                |
|----------------|----------|--------------------------------------------|
| [-minitrunk]   | Y        | routed via minitrunk instead of main trunk |
| [-data_region] | Y        | data as clock, using region resources      |
| [-data_center] | Y        | data as clock, using center resources      |
| [-data_local]  | Y        | data as clock, using local resources       |
| [-data_column] | Y        | data as clock, using branch base resources |

# set\_cluster

#### set\_cluster <cluster> [-id <int>] [-wt <int>]

Pre-placement command to generate user-defined clusters. This clustering command directs the ACE Placer to keep the specified instances together.

| Argument            | Optional | Description                                                                                                    |
|---------------------|----------|----------------------------------------------------------------------------------------------------------------|
| <cluster></cluster> |          | The required <cluster> list argument is a list of instances which should be clustered in an RLB half</cluster> |
| [-id <int>]</int>   | Y        | Optional 2nd level cluster id                                                                                  |
| [-wt <int>]</int>   | Y        | Optional 2nd level cluster weight {2,, 5} - higher weights signify cluster importance                          |

# set\_equivalent\_pins

set\_equivalent\_pins <equivalent\_pin\_names>

This command marks multiple nets or instance pins as functionally equivalent

| Argument                                      | Optional | Description                                                                                                                                                                                                 |
|-----------------------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <equivalent_pin_names></equivalent_pin_names> |          | A list of pin names or net names that are to be marked<br>as functionally equivalent ( <p:toplevel_port_name>  <br/><t:user_pin_name>   <n:net_name>)</n:net_name></t:user_pin_name></p:toplevel_port_name> |

# set\_flyline\_direction

set\_flyline\_direction <direction>

This command is used to control whether selected instance flylines are shown for loads of the selected instance, drivers, or both.

| Argument                | Optional | Description                                                                                                                                                                                                                    |
|-------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <direction></direction> |          | The required <direction> argument specifies whether<br/>selected instance flylines are shown for loads of the selected<br/>instance, drivers, or both. Valid values are loads_only,<br/>drivers_only, both and all</direction> |

### set\_impl\_option

set\_impl\_option <option\_name> [<value>] [-project <string>] [-impl <string>]
This command sets options for a project implementation. Only one option may be set at a time.

| Argument                     | Optional | Description                                                                                                                                                                             |
|------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <option_name></option_name>  |          | The name of the impl option to set a value for. To see a list of valid impl options, use the report_impl_options TCL command.                                                           |
| [ <value>]</value>           | Y        | The new value to set the impl option to.                                                                                                                                                |
| [-project <string>]</string> | Y        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to set options for.</implname></projectname> |
| [-impl <string>]</string>    | Y        | The optional -project <projectname> and -impl<br/><implname> options are used to specify an alternate<br/>project implementation (by name) to set options for.</implname></projectname> |

## set\_max\_flyline\_fanout

#### set\_max\_flyline\_fanout <limit>

This command is used to hide selected instance flylines for nets with fanout greater than the limit passed in.

| Argument        | Optional | Description                                                                                                |
|-----------------|----------|------------------------------------------------------------------------------------------------------------|
| <limit></limit> |          | The required <limit> argument specifies the maximum fanout for flylines to be displayed for a net.</limit> |

### set\_partition\_force\_changed

set\_partition\_force\_changed <name> <changed>

Set the force changed flag of a partition with the given name. This command should be called at the end of the incremental compile flow. Setting the flag will force the partition to be recompiled the next time that the flow is run, even if the partition timestamp has not changed.

| Argument            | Optional | Description                                                                                                               |
|---------------------|----------|---------------------------------------------------------------------------------------------------------------------------|
| <name></name>       |          | Name of the Partition                                                                                                     |
| <changed></changed> |          | Set to 1 to mark this partition as force changed, set to 0 to reset the flag and mark the partition as not forced changed |

## set\_partition\_info

set\_partition\_info [-name <string>] [-view <string>] [-cp\_type <string>]
-timestamp <string> -import <string> [-comment <string>] [-exclusive\_placement]

Set partition (compile point) information on the design. This command creates a new partition definition if one does not already exist in the design. This usually comes from the synthesis tool in <design>\_partition.tcl

| Argument                     | Optional | Description                                                                                                                                                                       |
|------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-name <string>]</string>    | Y        | Hierarchical pathname of the partition in the netlist<br>(e.g. /top_module/instance1/instance2)                                                                                   |
| [-view <string>]</string>    | Y        | Module name of the partition in the original RTL. Will be<br>used as the name of the blackbox module if the partition<br>is exported.                                             |
| [-cp_type <string>]</string> | Y        | Compile point type (hard, locked, or soft)                                                                                                                                        |
| -timestamp <string></string> |          | Timestamp in seconds to indicate when this partition<br>was last synthesized. Default is current time in seconds.<br>The options -timestamp and -import are mutually<br>exclusive |
| -import <string></string>    |          | Pathname to the .epdb file containing the placed and routed partition database to be imported. The options -timestamp and -import are mutually exclusive                          |
| [-comment <string>]</string> | Y        | User specified comment string describing the partition                                                                                                                            |
| [-exclusive_placement]       | Y        | Sets the given partition with an exclusive placement<br>property. Instances belonging to the current partition will<br>not be placed together with non partition instances        |

## set\_placement

set\_placement <objName> <siteName> [-fixed] [-batch] [-partition] [-warning] [auto\_place\_neighbors <int>]

This command assigns the placement of an instance to a site

| Argument                               | Optional | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <objname></objname>                    |          | The required <objname> argument is used to specify the<br/>name of an instance (i:) or port (p:) to be placed. If multiple<br/>objects are to be placed at once, a TCL list of objectnames<br/>may be specified. NOTE: Ports (p:) may not be used if the<br/>port is connected to a black box IO Ring instance. The port<br/>(p:) may only be used to place boundary pins (IPIN, OPIN,<br/>CLK_IPIN, CLK_OPIN) that are connected to the port.</objname> |
| <sitename></sitename>                  |          | The required <sitename> argument is used to specify the<br/>site (s:) to place the instance on. In the case of IO pin<br/>placement, a device port name (d:) may be specified instead<br/>of a site name. If multiple objects are to be placed at once, a<br/>TCL list of sitenames may be specified.</sitename>                                                                                                                                         |
| [-fixed]                               | Y        | The -fixed option specifies that the placement of the instance should be fixed to this site and not movable by the placer                                                                                                                                                                                                                                                                                                                                |
| [-batch]                               | Y        | Postpone application of this constraint until<br>apply_placement is called at the end of run_prepare. This<br>option is useful for instances that are created or renamed<br>by Ace during run_prepare.                                                                                                                                                                                                                                                   |
| [-partition]                           | Y        | Use this instance as an anchor to specify the placement of an entire partition relative to the specified site                                                                                                                                                                                                                                                                                                                                            |
| [-warning]                             | Y        | Instead of erroring out, only print a warning message if the instance(s) specified with <objname> do not exist at the time this constraint is applied</objname>                                                                                                                                                                                                                                                                                          |
| [-auto_place_neighbors<br><int>]</int> | Y        | This option can be applied to PINs and takes the number of logic levels to process as an argument. It currently only supports placing LUTs driving OPINs for 1 level of logic.                                                                                                                                                                                                                                                                           |

## set\_project\_constraints\_pvt

set\_project\_constraints\_pvt <file> [-corner <string>] [-temperature <string>] [voltage <string>]

This command allows the user to set the specific PVT conditions in which an SDC constraint file is applied.

| Argument                         | Optional | Description                                                                                                                                                                                                                                                              |
|----------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <file></file>                    |          | The required <file> argument is used to specify the file path to the SDC constraint file.</file>                                                                                                                                                                         |
| [-corner <string>]</string>      | Y        | The -corner <corner> option is used to mark an SDC constraints file (containing only delays) as being applicable only to the given process corner. Valid values are "fast" and "slow"</corner>                                                                           |
| [-temperature <string>]</string> | Y        | The -temperature <temp> option is used to mark an SDC constraints file (containing only delays) as being applicable only to the given temperature corner. Valid values are device-specific and must match a value from the junction_temperature impl option list.</temp> |
| [-voltage <string>]</string>     | Y        | The -voltage <v> option is used to mark an SDC<br/>constraints file (containing only delays) as being applicable<br/>only to the given core voltage corner. Valid values are<br/>device-specific and must match a value from the<br/>core_voltage impl option list.</v>  |

## set\_project\_option

#### set\_project\_option <option\_name> [<value>] [-project <string>]

This command sets options for a project. Only one option may be set at a time.

| Argument                     | Optional | Description                                                                                                                                  |
|------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------|
| <option_name></option_name>  |          | The name of the project option to set a value for. To see<br>a list of valid project options, use the<br>report_project_options TCL command. |
| [ <value>]</value>           | Y        | The new value to set the project option to.                                                                                                  |
| [-project <string>]</string> | Y        | The optional -project <projectname> is used to specify an alternate project (by name) to set options for.</projectname>                      |

## set\_property

<propValue> <objects> [-warning] [-quiet] This command is used to set properties on objects in the DB.

| Argument                | Optional | Description                                                                                                                                                              |
|-------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <propname></propname>   |          | The required <propname> argument specifies property name to set on the objects passed in.</propname>                                                                     |
| <propvalue></propvalue> |          | The required <propvalue> argument specifies property value to set on the objects passed in.</propvalue>                                                                  |
| <objects></objects>     |          | The required <objects> argument specifies a list of objects to set the property for. Objects must be prepended with object type prefixes (see "find" command).</objects> |
| [-warning]              | Y        | The optional -warning option allows you to downgrade error<br>messages about missing netlist objects to warning<br>messages                                              |
| [-quiet]                | Y        | The optional -quiet option allows you to disable printing of info messages                                                                                               |

## set\_region\_bounds

set\_region\_bounds <region> <bounds> [-snap\_to\_clock\_regions] [snap\_to\_fabric\_clusters] [-snap <string>]

This command updates a placement region's bounding box of tiles

| Argument                   | Optional | Description                                                                                                                                            |
|----------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| <region></region>          |          | Name of the region                                                                                                                                     |
| <bounds></bounds>          |          | List of bounding box coordinates {x1 y1 x2 y2}. x1 and<br>y1 are the upper left corner of the box. x2 and y2 are<br>the lower right corner of the box. |
| [-snap_to_clock_regions]   | Υ        | Snap the bounding box to clock region boundaries (deprecated, use '-snap clock_regions')                                                               |
| [-snap_to_fabric_clusters] | Υ        | Snap the bounding box to fabric cluster boundaries (deprecated, use -snap fabric_clusters')                                                            |
| [-snap <string>]</string>  | Υ        | How to snap the region bounding box coordinates.<br>Legal values are: 'none', 'tiles' (the default),<br>'fabric_clusters', 'clock_regions'             |

## set\_region\_type

# set\_region\_type <region> [-type <string>] [-soft] [-include\_routing] This command updates a placement region's type

| Argument                  | Optional | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <region></region>         |          | Name of the region                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [-type <string>]</string> | Y        | What type of placement region this is. Legal values are:<br>'inclusive' (the default), 'keepout', 'soft'. Instances added to an<br>'inclusive' region (and attached routing wires when '-<br>include_routing' is set) will be placed within the region bounding<br>box. An 'inclusive' region permits instances to be placed inside<br>the region even if they do not belong to the region. A 'keepout'<br>region prevents any instances (and routing wires when '-<br>include_routing is set) from being placed inside the region. No<br>instances may be added to a 'keepout' region. Instances added to<br>an 'soft' region will be pulled toward the region's center during<br>placement, but instances are permitted to overflow the bounds<br>of the 'soft' region. |
| [-soft]                   | Y        | A 'soft' placement region attempts to pull instance placement to its center, but allows instance placement to overflow it's bounds                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [-include_routing]        | Y        | Constrain routing wires, as well as instances, to stay within the region boundary box                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

### set\_units

#### set\_units

Set the default units for timing constraints.

## sleep

#### sleep <seconds>

sleep for number seconds.

| Argument            | Optional | Description                |
|---------------------|----------|----------------------------|
| <seconds></seconds> |          | number of seconds to sleep |

## source\_encrypted

```
source_encrypted <tclfile> [-nodigest] [-debug] [-sig] [-untar]
```

source encrypted tcl file.

| Argument            | Optional | Description                                 |
|---------------------|----------|---------------------------------------------|
| <tclfile></tclfile> |          | encrypted tcl file to source                |
| [-nodigest]         | Y        | no digest is also OK                        |
| [-debug]            | Y        | internal use only                           |
| [-sig]              | Y        | only require a signature                    |
| [-untar]            | Y        | encrypted file is tar archive, untar first. |

#### source\_secure

source\_secure <tclfile> [-encoding <string>] [-nodigest] [-sig] [-untar]
source encrypted tcl file.

| Argument                      | Optional | Description                                 |
|-------------------------------|----------|---------------------------------------------|
| <tclfile></tclfile>           |          | encrypted tcl file to source                |
| [-encoding <string>]</string> | Y        | compatibility with 'source'                 |
| [-nodigest]                   | Y        | no digest is also OK                        |
| [-sig]                        | Y        | only require a signature                    |
| [-untar]                      | Y        | encrypted file is tar archive, untar first. |

## trace\_connections

```
trace_connections <insts> [-drivers_only] [-targets_only] [-include_clocks] [-
include_resets]
```

This command is used to find instances that are connected to the list of instances passed in. By default, this command traces to find all (drivers and targets) connected instances, except for those connected via clock or reset pins.

| Argument          | Optional | Description                                                                                                                                                                                  |
|-------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <insts></insts>   |          | The required <insts> argument specifies a list of instance<br/>objects to trace connectivity from. Objects must be<br/>prepended with object type prefixes (see "find"<br/>command).</insts> |
| [-drivers_only]   | Y        | If you want to select only upstream logic that drives the instances in the current selection, use -drivers_only                                                                              |
| [-targets_only]   | Y        | If you want to select only downstream logic driven by the currently selected instances, use -targets_only.                                                                                   |
| [-include_clocks] | Y        | To include tracing connectivity on clock nets, use -include_clocks.                                                                                                                          |
| [-include_resets] | Y        | To include tracing connectivity on reset nets, use -include_resets.                                                                                                                          |

Similar to the find (page 638) command, this functionality is especially useful when creating lists as input to other Tcl commands, like select (page 709) and highlight (page 665).

#### untar

#### untar <tarfile> [-member <string>] [-list] [-lz]

extract content from tar file.

| Argument                    | Optional | Description                      |
|-----------------------------|----------|----------------------------------|
| <tarfile></tarfile>         |          | tarfile from which to extract    |
| [-member <string>]</string> | Y        | member to extract, default: none |
| [-list]                     | Y        | list files in archive            |
| [-lz]                       | Y        | uncompress first                 |

## write\_aeskey\_efuse\_bitstream

write\_aeskey\_efuse\_bitstream aeskey\_file aeskey\_index [-outputfile <string>]
This command generates a .hex file used to burn the AES key eFuse. It can run after the run\_prepare flow step.

| Argument                        | Optional | Description                                                                                                                                                                                                                                                                    |
|---------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| aeskey_file                     |          | The path to the aes key file containing your 256-bit AES key.                                                                                                                                                                                                                  |
| aeskey_index                    |          | The AES key index to burn. Must be either 1,2,3.                                                                                                                                                                                                                               |
| [-outputfile <string>]</string> | Y        | The optional -outputfile <file> option may be used to<br/>specify an output file name or file path. If this option is not<br/>present, the output is written to the default<br/>implementation output directory and is named<br/><design_name>_efuse.hex.</design_name></file> |

## write\_bitstream

write\_bitstream [-outputfile <string>] [-debugdir <string>] [-reportsdir <string>]
[-flash] [-pcie] [-pcie\_txt] [-cpu] [-cpu\_width <int>] [-two\_stage] [-nocompress]
[-compress] [-chainfile <string>]

This command generates a programming bitstream for a fully placed and routed design in .hex format.

| Argument                        | Optional | Description                                                                                                                                                                                                                                                              |  |
|---------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| [-outputfile <string>]</string> | Υ        | The optional -outputfile <file> option may be used to<br/>specify an output file name or file path. If this option is not<br/>present, the output is written to the default<br/>implementation output directory and is named<br/><design_name>.hex.</design_name></file> |  |
| [-debugdir <string>]</string>   | Υ        | The optional -debugdir <dir> option is used to override the default location for debug files during this step.</dir>                                                                                                                                                     |  |
| [-reportsdir <string>]</string> | Υ        | The optional -reportsdir <dir> option is used to override the default location for report files during this step.</dir>                                                                                                                                                  |  |
| [-flash]                        | Υ        | The optional -flash option may be used to output an additional serial flash binary file format output                                                                                                                                                                    |  |
| [-pcie]                         | Υ        | The optional -pcie option may be used to output an additional PCIe binary file format output                                                                                                                                                                             |  |
| [-pcie_txt]                     | Υ        | The optional -pcie_txt option may be used to output an<br>additional PCIe file format output. This is a text file format<br>used for debug and must be used with -pcie or<br>bitstream_output_pcie                                                                       |  |

| Argument                       | Optional | Description                                                                                                                                                                                                              |
|--------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-cpu]                         | Υ        | The optional -cpu option may be used to output an additional CPU Mode file format output                                                                                                                                 |
| [-cpu_width <int>]</int>       | Y        | This option controls the bit width of the CPU Mode<br>formatted output file. If you are using the CPU interface in<br>x8 mode, set this value to 8. If you are using the CPU<br>interface in x128 mode, set this to 128. |
| [-two_stage]                   | Y        | The optional -two_stage option may be used to output bitstream files divided by user mode                                                                                                                                |
| [-nocompress]                  | Y        | write output as plain-text file                                                                                                                                                                                          |
| [-compress]                    | Y        | compress output-file                                                                                                                                                                                                     |
| [-chainfile <string>]</string> | Υ        | The optional -chainfile <file> may be used to override the chainfile set in the active Impl</file>                                                                                                                       |

## write\_critical\_paths\_script

#### write\_critical\_paths\_script [-outputfile <string>]

This command writes a tcl script that may be used for viewing critical paths in the synthesis tool.

| Argument                        | Optional | Description                                                                                                                                                                                                                                                                             |
|---------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [-outputfile <string>]</string> | Υ        | The optional -outputfile <file> option may be used to<br/>specify an output file name or file path. If this option is not<br/>present, the output is written to the default implementation<br/>output directory and is named<br/><design_name>_critical_paths.tcl.</design_name></file> |

## write\_netlist

write\_netlist [-outputfile <string>] [-debugdir <string>] [-final] [-compress] This command generates a verilog netlist for simulation (same as run\_generate\_netlist).

| Argument                        | Optional | Description                                                                                                          |  |
|---------------------------------|----------|----------------------------------------------------------------------------------------------------------------------|--|
| [-outputfile <string>]</string> | Y        | Output netlist file name.                                                                                            |  |
| [-debugdir <string>]</string>   | Υ        | The optional -debugdir <dir> option is used to override the default location for debug files during this step.</dir> |  |

| Argument    | Optional | Description                    |
|-------------|----------|--------------------------------|
| [-final]    | Y        | Output DRC-free final netlist  |
| [-compress] | Y        | Compress output file with gzip |

## write\_partition\_blackbox

write\_partition\_blackbox <partition> [-library <string>] [-outputfile <string>]
Command to write a verilog blackbox model for a partition

| Argument                        | Optional | Description                                                                                                                                   |
|---------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| <partition></partition>         |          | Export a blackbox netlist for the specified partition as a verilog file                                                                       |
| [-library <string>]</string>    | Υ        | Specifies the name of the blackbox model library<br>(default is "blackbox")                                                                   |
| [-outputfile <string>]</string> | Y        | Specifies the output file name for the blackbox netlist<br>(default is <cellname>_bb.v in the implementation<br/>output directory)</cellname> |

## write\_partition\_db

write\_partition\_db <partition> [-outputfile <string>] [-include\_pr\_zone] Command to export the place-and-route database for a partition

| Argument                        | Optional | Description                                                                                                                                                 |
|---------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <partition></partition>         |          | Export the place-and-route database for the specified partition into an .epdb file                                                                          |
| [-outputfile <string>]</string> | Υ        | Specifies the output file name for the partition database<br>(default is partitions/ <instname>.epdb in the<br/>implementation output directory)</instname> |
| [-include_pr_zone]              | Υ        | Search for Placement Region that corresponds to partition and use it in splitting routing for nets                                                          |

## write\_tcl\_history

```
write_tcl_history <outputfile>
```

722

#### Dump the TCL command history for this ACE session to a file

| Argument                  | Optional | Description                        |
|---------------------------|----------|------------------------------------|
| <outputfile></outputfile> |          | The file to save the TCL script to |

## Tcl Commands for the IP Generator Plugin Framework

These commands are in the ace\_ip:: namespace.

- add\_ip\_binary\_property (page 724)
- add\_ip\_bool\_property (page 725)
- add\_ip\_enum\_property (page 726)
- add\_ip\_file\_path\_property (page 727)
- add\_ip\_float\_property (page 727)
- add\_ip\_gui\_control (page 728)
- add\_ip\_gui\_group (page 729)
- add\_ip\_gui\_page (page 730)
- add\_ip\_hex\_property (page 731)
- add\_ip\_include\_path (page 731)
- add\_ip\_int\_property (page 732)
- add\_ip\_label (page 733)
- add\_ip\_output\_file (page 734)
- add\_ip\_output\_file\_group (page 734)
- add\_ip\_port (page 735)
- add\_ip\_rule\_message (page 736)
- add\_ip\_signal\_name\_property (page 737)
- add\_ip\_string\_property (page 737)
- add\_ip\_to\_gui (page 738)
- create\_ip (page 739)
- get\_ip\_include\_paths (page 739)
- get\_ip\_macro\_name (page 740)
- get\_ip\_ports (page 740)
- get\_ip\_property\_attributes (page 741)
- get\_ip\_property\_value (page 743)
- remove\_ip\_gui\_control (page 744)
- remove\_ip\_gui\_group (page 744)
- remove\_ip\_gui\_page (page 745)
- remove\_ip\_label (page 745)

- remove\_ip\_property (page 746)
- send\_ip\_definitions (page 746)
- send\_ip\_gui\_update (page 747)
- set\_ip\_category (page 747)
- set\_ip\_description (page 747)
- set\_ip\_macro\_name (page 748)
- set\_ip\_property\_value (page 748)
- set\_ip\_property\_verilog\_param\_attributes (page 749)
- set\_ip\_resource\_count (page 750)
- set\_ip\_resource\_types (page 751)
- set\_update\_ip\_configuration\_callback (page 751)
- update\_ip\_binary\_property (page 755)
- update\_ip\_bool\_property (page 756)
- update\_ip\_configuration (page 756)
- update\_ip\_enum\_property (page 757)
- update\_ip\_file\_path\_property (page 758)
- update\_ip\_float\_property (page 758)
- update\_ip\_hex\_property (page 759)
- update\_ip\_int\_property (page 759)
- update\_ip\_label (page 760)
- update\_ip\_signal\_name\_property (page 760)
- update\_ip\_string\_property (page 761)

## add\_ip\_binary\_property

add\_ip\_binary\_property <name> <gui\_label> <default\_value> <number\_of\_bits> [-min <number>] [-max <number>] [-description <text>] [-enabled <state>] [-ip\_name <ip\_name>]

| Argument                          | Optional | Туре    | Description                                 |
|-----------------------------------|----------|---------|---------------------------------------------|
| <name></name>                     |          | String  | ACXIP property name                         |
| <gui_label></gui_label>           |          | String  | Property label to display on the GUI editor |
| <default_value></default_value>   |          | String  | Default property value (binary)             |
| <number_of_bits></number_of_bits> |          | Integer | Number of allowed bits                      |

| Argument                       | Optional | Туре    | Description                           |
|--------------------------------|----------|---------|---------------------------------------|
| [-min <number>]</number>       | Y        | String  | Minimum allowed value (binary)        |
| [-max <number>]</number>       | Y        | String  | Maximum allowed value (binary)        |
| [-description <text>]</text>   | Y        | String  | Tool-tip / documentation description  |
| [-enabled <state>]</state>     | Y        | Boolean | Flag to enable/disable property       |
| [-ip_name <ip_name>]</ip_name> | Y        | String  | IP name associated with this property |

The add\_ip\_binary\_property is used to define an IP binary property.

#### Example

```
add_ip_binary_property "example_binary_property_1" "Example Binary Range Property
1" "0101" 4 -min "0000" -max "1111" -description "Long description text for tool
tip" -enabled "false"
```

## add\_ip\_bool\_property

add\_ip\_bool\_property <name> <gui\_label> <default\_value> [-description <text>] [enabled <state>] [-ip\_name <ip\_name>]

| Argument                        | Optional | Туре    | Description                                    |
|---------------------------------|----------|---------|------------------------------------------------|
| <name></name>                   |          | String  | ACXIP property name                            |
| <gui_label></gui_label>         |          | String  | Property label to display on the GUI<br>editor |
| <default_value></default_value> |          | String  | Default property value (Yes or No)             |
| [-description <text>]</text>    | Y        | String  | Tool-tip / documentation description           |
| [-enabled <state>]</state>      | Y        | Boolean | Flag to enable/disable property                |
| [-ip_name <ip_name>]</ip_name>  | Y        | String  | IP name associated with this property          |

The add\_ip\_bool\_property is used to define an IP boolean property.

### Example

```
add_ip_bool_property "example_bool_property_1" "Example Boolean Property 1" "Yes"
-description "Long description text for tooltip" -enabled "false"
```

## add\_ip\_enum\_property

```
add_ip_enum_property <name> <gui_label> <default_value> <list_of_valid_values> [-
description <text>] [-enabled <state>] [-ip_name <ip_name>]
```

| Argument                                      | Optional | Туре    | Description                                 |
|-----------------------------------------------|----------|---------|---------------------------------------------|
| <name></name>                                 |          | String  | ACXIP property name                         |
| <gui_label></gui_label>                       |          | String  | Property label to display on the GUI editor |
| <default_value></default_value>               |          | String  | Default property value                      |
| <list_of_valid_values></list_of_valid_values> |          | Array   | List of valid values                        |
| [-description <text>]</text>                  | Y        | String  | Tool-tip / documentation description        |
| [-enabled <state>]</state>                    | Y        | Boolean | Flag to enable/disable property             |
| [-ip_name <ip_name>]</ip_name>                | Y        | String  | IP name associated with this property       |

### Description

The add\_ip\_enum\_property is used to define an IP enum property.

#### Example

```
add_ip_enum_property "example_enum_property_1" "Example Enum Property 1"
"Item2" {"Item1" "Item2" "Item3"} -description "Long description text for tool tip"
-enabled "false"
```

## add\_ip\_file\_path\_property

```
add_ip_file_path_property <name> <gui_label> <default_value> [-description <text>]
[-enabled <state>] [-file_must_exist <exists>] [-isDirectory <is_dir>] [-ip_name
<ip_name>]
```

| Argument                                | Optional | Туре    | Description                                                                               |
|-----------------------------------------|----------|---------|-------------------------------------------------------------------------------------------|
| <name></name>                           |          | String  | ACXIP property name                                                                       |
| <gui_label></gui_label>                 |          | String  | Property label to display on the GUI editor                                               |
| <default_value></default_value>         |          | String  | Default property value                                                                    |
| [-file_must_exist<br><exists>]</exists> | Y        | Boolean | If set to "true", the file must exist in the filesystem, or else the rule check will fail |
| [-isDirectory<br><is_dir>]</is_dir>     | Y        | Boolean | Set to "true" if the path is a directory instead of a file                                |
| [-description <text>]</text>            | Y        | String  | Tool-tip / documentation description                                                      |
| [-enabled <state>]</state>              | Y        | Boolean | Flag to enable/disable property                                                           |
| [-ip_name <ip_name>]</ip_name>          | Y        | String  | IP name associated with this property                                                     |

### Description

The add\_ip\_file\_path\_property is used to define an IP file path property.

#### Example

```
add_ip_file_path_property "example_filepath_property_1" "Example Filepath Property
1" "./test_file.txt" -description "Long description text for tool-tip" -enabled
"false" -file_must_exist "true"
```

## add\_ip\_float\_property

```
add_ip_float_property <name> <gui_label> <default_value> [-min <number>] [-max
<number>] [-description <text>] [-enabled <state>] [-ip_name <ip_name>]
```

| Argument                        | Optional | Туре    | Description                                 |
|---------------------------------|----------|---------|---------------------------------------------|
| <name></name>                   |          | String  | ACXIP property name                         |
| <gui_label></gui_label>         |          | String  | Property label to display on the GUI editor |
| <default_value></default_value> |          | Double  | Default property value                      |
| [-min <number>]</number>        | Y        | Double  | Minimum allowed value                       |
| [-max <number>]</number>        | Y        | Double  | Maximum allowed value                       |
| [-description <text>]</text>    | Y        | String  | Tool-tip / documentation description        |
| [-enabled <state>]</state>      | Y        | Boolean | Flag to enable/disable property             |
| [-ip_name <ip_name>]</ip_name>  | Y        | String  | IP name associated with this property       |

The add\_ip\_float\_property is used to define an IP float property.

#### Example

add\_ip\_float\_property "example\_float\_property\_1" "Example Floating Point Range
Property 1" "3.1" -min "2.7" -max "32.4" -description "Long description text for
tooltip" -enabled "false"

## add\_ip\_gui\_control

```
add_ip_gui_control <property_name> <page> [-parent <parent>] [-control_type <type>]
[-span <column_span>] [-ip_name <ip_name>]
```

| Argument                        | Optional | Туре   | Description                                                     |
|---------------------------------|----------|--------|-----------------------------------------------------------------|
| <property_name></property_name> |          | String | ACXIP property name                                             |
| <page></page>                   |          | String | IP GUI page name to add the control into                        |
| [-parent <parent>]</parent>     | Y        | String | The parent IP Group box to add the control into (if applicable) |

| Argument                            | Optional | Туре    | Description                                                               |
|-------------------------------------|----------|---------|---------------------------------------------------------------------------|
| [-control_type <type>]</type>       | Y        | String  | GUI control type. Valid options are combo,<br>radio, text, checkbox, file |
| [-span <column_span>]</column_span> | Y        | Integer | GUI page layout column span                                               |
| [-ip_name <ip_name>]</ip_name>      | Y        | String  | IP name associated with this page                                         |

The add\_ip\_gui\_control is used to define IP property GUI controls. Control types for each of the property type can be as follows: combo, radio or text for List, combo or text for Int, text for Float, Hex, Binary and Signal and file for Filepath.

#### Example

add\_ip\_gui\_control "some\_int\_property" "Overview" -control\_type "combo" add\_ip\_gui\_control "another\_int\_property" "Overview" -control\_type "text"

## add\_ip\_gui\_group

```
add_ip_gui_group <name> <label> <page> [-parent <parent_group>] [-columns
<layout_columns>] [-span <column_span>] [-ip_name <ip_name>]
```

| Argument                                        | Optional | Туре    | Description                                                   |
|-------------------------------------------------|----------|---------|---------------------------------------------------------------|
| <name></name>                                   |          | String  | Group name                                                    |
| <label></label>                                 |          | String  | GUI visible group label                                       |
| <page></page>                                   |          | String  | IP GUI page name to add the group to                          |
| [-parent<br><parent_group>]</parent_group>      | Y        | String  | The parent IP Group box to add the group into (if applicable) |
| [-columns<br><layout_columns>]</layout_columns> | Y        | Integer | Number of columns to use for layout inside this group         |
| [-span <column_span>]</column_span>             | Y        | Integer | Column span                                                   |
| [-ip_name <ip_name>]</ip_name>                  | Y        | String  | IP name associated with this page                             |

The add\_ip\_gui\_group is used to define groups for GUI control/s in IP editor GUI page.

### Example

```
add_ip_gui_group "group_x" "Example Group X" "Overview" -columns 2 -span 1
add_ip_gui_control "some_list_property" "Overview" -parent "group_x" -control_type
"combo"
```

## add\_ip\_gui\_page

```
add_ip_gui_page <name> <description> [-parent <parent_page_name>] [-columns
<layout_columns>] [-ip_name <ip_name>]
```

| Argument                                           | Optional | Туре    | Description                         |
|----------------------------------------------------|----------|---------|-------------------------------------|
| <name></name>                                      |          | String  | IP GUI page name                    |
| <description></description>                        |          | String  | IP description text for page banner |
| [-columns<br><layout_columns>]</layout_columns>    | Y        | Integer | Number of GUI page layout columns   |
| [-parent<br><parent_page_name>]</parent_page_name> | Y        | String  | The parent IP page (if applicable)  |
| [-ip_name <ip_name>]</ip_name>                     | Y        | String  | IP name associated with this page   |

### Description

The add\_ip\_gui\_page is used to define GUI page structure as part of the GUI page layout definition.

#### Example

```
add_ip_gui_page "Overview" "Long description text for page banner"
add_ip_gui_page "Sub-Page A" -parent "Overview" "Long description text for page
banner"
add_ip_gui_page "Sub-Page B" -parent "Overview" "Long description text for page
banner"
add_ip_gui_page "Sub-Page C" -parent "Sub-Page B" "Long description text for page
banner"
```

## add\_ip\_hex\_property

```
add_ip_hex_property <name> <gui_label> <default_value> <number_of_bits> [-min
<number>] [-max <number>] [-description <text>] [-enabled <state>] [-ip_name
<ip_name>]
```

| Argument                          | Optional | Туре    | Description                                    |
|-----------------------------------|----------|---------|------------------------------------------------|
| <name></name>                     |          | String  | ACXIP property name                            |
| <gui_label></gui_label>           |          | String  | Property label to display on the GUI<br>editor |
| <default_value></default_value>   |          | String  | Default property value (hex)                   |
| <number_of_bits></number_of_bits> |          | Integer | Number of allowed bits                         |
| [-min <number>]</number>          | Y        | String  | Minimum allowed value (hex)                    |
| [-max <number>]</number>          | Y        | String  | Maximum allowed value (hex)                    |
| [-description <text>]</text>      | Y        | String  | Tool-tip / documentation description           |
| [-enabled <state>]</state>        | Y        | Boolean | Flag to enable/disable property                |
| [-ip_name <ip_name>]</ip_name>    | Y        | String  | IP name associated with this property          |

#### Description

The add\_ip\_hex\_property is used to define an IP hexadecimal property.

#### Example

```
add_ip_hex_property "example_hex_property_1" "Example Hex Range Property 1"
"012345" 24 -min "000000" -max "FFFFFF" -description "Long description text for
tooltip" -enabled "false"
```

## add\_ip\_include\_path

add\_ip\_include\_path <include\_path> [-ip\_name <ip\_name>]

| Argument                       | Optional | Туре   | Description                           |
|--------------------------------|----------|--------|---------------------------------------|
| <include_path></include_path>  |          | String | Include path                          |
| [-ip_name <ip_name>]</ip_name> | Y        | String | IP name associated with this property |

The add\_ip\_include\_path is used to include path in output file. This is optional, and is used by any built-in output file generator TCL procedures.

#### Example

```
add_ip_include_path "speedster7t/macros/ACX_EXAMPLE_SOFT_IP/src/rtl/
ACX_EXAMPLE_SOFT_IP.sv"
add_ip_include_path "speedster7t/macros/ACX_EXAMPLE_SOFT_IP/src/include/
example_include_file.svh"
```

## add\_ip\_int\_property

add\_ip\_int\_property <name> <gui\_label> <default\_value> [-min <number>] [-max <number>] [-description <text>] [-enabled <state>] [-ip\_name <ip\_name>]

| Argument                        | Optional | Туре    | Description                                    |
|---------------------------------|----------|---------|------------------------------------------------|
| <name></name>                   |          | String  | ACXIP property name                            |
| <gui_label></gui_label>         |          | String  | Property label to display on the GUI<br>editor |
| <default_value></default_value> |          | Integer | Default property value (decimal)               |
| [-min <number>]</number>        | Y        | Integer | Minimum allowed value (decimal)                |
| [-max <number>]</number>        | Y        | Integer | Maximum allowed value (decimal)                |
| [-description <text>]</text>    | Y        | String  | Tool-tip / documentation description           |
| [-enabled <state>]</state>      | Y        | Boolean | Flag to enable/disable property                |
| [-ip_name <ip_name>]</ip_name>  | Y        | String  | IP name associated with this property          |

The add\_ip\_int\_property is used to define an IP integer property.

#### Example

```
add_ip_int_property "example_int_property_1" "Example Integer Range Property 1" "3"
-min "2" -max "32" -description "Long description text for tool tip" -enabled
"false"
```

## add\_ip\_label

```
add_ip_label <name> <gui_label> <default_value> [-description <text>] [-enabled
<state>] [-ip_name <ip_name>]
```

| Argument                        | Optional | Туре    | Description                                 |
|---------------------------------|----------|---------|---------------------------------------------|
| <name></name>                   |          | String  | ACXIP property name                         |
| <gui_label></gui_label>         |          | String  | Property label to display on the GUI editor |
| <default_value></default_value> |          | String  | Default property value                      |
| [-description <text>]</text>    | Y        | String  | Tool-tip / documentation description        |
| [-enabled <state>]</state>      | Y        | Boolean | Flag to enable/disable property             |
| [-ip_name <ip_name>]</ip_name>  | Y        | String  | IP name associated with this property       |

#### Description

The add\_ip\_label is used to define IP labels.

#### Example

add\_ip\_label "examplelabel\_1" "Example Dynamic Label 1" "Hello World" -description "Long description text for tool tip" -enabled "true"

## add\_ip\_output\_file

add\_ip\_output\_file <label> <enable\_property> <file\_property> <group> <description>
[-file\_ext <supported\_extensions>] [-enabled <state>] [-ip\_name <ip\_name>]

| Argument                                                     | Optional | Туре    | Description                                |
|--------------------------------------------------------------|----------|---------|--------------------------------------------|
| <label></label>                                              |          | String  | IP GUI page editor name                    |
| <enable_property></enable_property>                          |          | String  | ACXIP property name for file output enable |
| <file_property></file_property>                              |          | String  | Output file ACXIP property name            |
| <group></group>                                              |          | String  | Output generation group                    |
| <description></description>                                  |          | String  | Description text                           |
| [-file_ext<br><supported_extensions>]</supported_extensions> | Y        | String  | Supported extension                        |
| [-enabled <state>]</state>                                   | Y        | Boolean | Enable setting in GUI                      |
| [-ip_name <ip_name>]</ip_name>                               | Y        | String  | IP name associated with this property      |

### Description

The add\_ip\_output\_file is used to define output file types (Verilog, VHDL, SystemVerilog, SDC, PDC, Custom, etc).

#### Example

```
add_ip_output_file_group "RTL Files" "Some description text for tool-tip and docs"
add_ip_output_file "Verilog Model" "output.verilog_file_en" "output.verilog_file"
"RTL Files" "Description text here..." -enabled "Yes" -file_ext "*.v"
```

## add\_ip\_output\_file\_group

add\_ip\_output\_file\_group <name> <description>

| Argument      | Optional | Туре   | Description            |
|---------------|----------|--------|------------------------|
| <name></name> |          | String | Output file group name |

| Argument                    | Optional | Туре   | Description                                |
|-----------------------------|----------|--------|--------------------------------------------|
| <description></description> |          | String | Output file group description for tool-tip |

The add\_ip\_output\_file\_group is used to define output file group for supported output file types (Verilog, VHDL, SystemVerilog, SDC, PDC, Custom, etc).

#### Example

add\_ip\_output\_file\_group "RTL Files" "Some description text for tool-tip and docs"

## add\_ip\_port

```
add_ip_port <port_name> <signal_group> <direction> <width> <diagram_side>
<description> [-exposed <exposed>] [-tieoff <tieoff>] [-typedef <typedef>] [-
clock_domain <domain>]
```

| Argument                       | Optional | Туре    | Description                                                                                                         |
|--------------------------------|----------|---------|---------------------------------------------------------------------------------------------------------------------|
| <port_name></port_name>        |          | String  | Port name                                                                                                           |
| <signal_group></signal_group>  |          | String  | Port signal group                                                                                                   |
| <direction></direction>        |          | String  | Port direction (in/out/inout)                                                                                       |
| <width></width>                |          | Integer | Port width                                                                                                          |
| <diagram_side></diagram_side>  |          | String  | GUI diagram side (East/West)                                                                                        |
| <description></description>    |          | String  | Port description for tooltip                                                                                        |
| [-exposed <exposed>]</exposed> | Y        | Boolean | Indicates whether to tie off this port on the<br>underlying soft IP macro, or expose it in the<br>generated wrapper |
| [-tieoff <tieoff>]</tieoff>    | Y        | String  | If a port is not "exposed", use this value to tie it off inside the generated wrapper                               |
| [-typedef <typedef>]</typedef> | Y        | String  | Optionally add a typedef string to the generated Verilog                                                            |

| Argument                             | Optional | Туре   | Description                                                                           |
|--------------------------------------|----------|--------|---------------------------------------------------------------------------------------|
| [-clock_domain<br><domain>]</domain> | Υ        | String | Optionally indicate what clock domain this port is on (for generating SDC files, etc) |

The add\_ip\_port is used to define ports for generated Verilog/VHDL and interactive diagram.

#### Example

```
add_ip_port "ref_clk" "Clocks and Resets" "in" 1 "West" "Some description Text for tool-tip and documentation..."
```

## add\_ip\_rule\_message

add\_ip\_rule\_message <ip\_property\_name> <title> <status> <message>

| Argument                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Optional | Туре   | Description         |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------|---------------------|
| <ip_property_name></ip_property_name>                                                                                                                                                                                                                                                                                                                                                                                                                     |          | String | ACXIP property name |
| <title>&lt;/td&gt;&lt;td&gt;&lt;/td&gt;&lt;td&gt;String&lt;/td&gt;&lt;td&gt;message title&lt;/td&gt;&lt;/tr&gt;&lt;tr&gt;&lt;td&gt;&lt;status&gt;&lt;/td&gt;&lt;td&gt;&lt;/td&gt;&lt;td&gt;String&lt;/td&gt;&lt;td&gt;Error, Warning, Info&lt;/td&gt;&lt;/tr&gt;&lt;tr&gt;&lt;td&gt;&lt;message&gt;&lt;/td&gt;&lt;td&gt;&lt;/td&gt;&lt;td&gt;String&lt;/td&gt;&lt;td&gt;message to be displayed&lt;/td&gt;&lt;/tr&gt;&lt;/tbody&gt;&lt;/table&gt;</title> |          |        |                     |

#### Description

The add\_ip\_rule\_message is used to report ip rule messages.

#### Example

add\_ip\_rule\_message "read\_data\_width" "Data width mismatch example" "Error" "Write width must be set to the same value as Read Width. The current values are different. Please fix this."

## add\_ip\_signal\_name\_property

add\_ip\_signal\_name\_property <name> <gui\_label> <default\_value> [-description
<text>] [-enabled <state>] [-ip\_name <ip\_name>]

| Argument                        | Optional | Туре    | Description                                 |
|---------------------------------|----------|---------|---------------------------------------------|
| <name></name>                   |          | String  | ACXIP property name                         |
| <gui_label></gui_label>         |          | String  | Property label to display on the GUI editor |
| <default_value></default_value> |          | String  | Default property value                      |
| [-description <text>]</text>    | Y        | String  | Tool-tip / documentation description        |
| [-enabled <state>]</state>      | Y        | Boolean | Flag to enable/disable property             |
| [-ip_name <ip_name>]</ip_name>  | Y        | String  | IP name associated with this property       |

#### Description

The add\_ip\_signal\_name\_property is used to define an IP signal name property.

#### Example

```
add_ip_signal_name_property "example_signal_name_property_1" "Example Signal Name
Property 1" "Yes" -description "Long description text for tool tip" -enabled
"false"
```

## add\_ip\_string\_property

add\_ip\_string\_property <name> <gui\_label> <default\_value> [-min\_characters <number>] [-max\_characters <number>] [-valid\_characters\_regex <regex>] [description <text>] [-enabled <state>] [-ip\_name <ip\_name>]

| Argument                | Optional | Туре   | Description                                 |
|-------------------------|----------|--------|---------------------------------------------|
| <name></name>           |          | String | ACXIP property name                         |
| <gui_label></gui_label> |          | String | Property label to display on the GUI editor |

| Argument                                     | Optional | Туре    | Description                                                    |
|----------------------------------------------|----------|---------|----------------------------------------------------------------|
| <default_value></default_value>              |          | String  | Default property value                                         |
| [-valid_characters_regex<br><regex>]</regex> | Υ        | String  | Regular expression for checking validity of the property value |
| [-min_characters<br><number>]</number>       | Υ        | Integer | Minimum number of characters allowed                           |
| [-max_characters<br><number>]</number>       | Υ        | Integer | Maximum number of characters allowed                           |
| [-description <text>]</text>                 | Y        | String  | Tool-tip / documentation description                           |
| [-enabled <state>]</state>                   | Y        | Boolean | Flag to enable/disable property                                |
| [-ip_name <ip_name>]</ip_name>               | Y        | String  | IP name associated with this property                          |

The add\_ip\_string\_property is used to define an IP string property.

#### Example

```
add_ip_string_property "example_string_property_1" "Example String Property 1
Label" "Default Value" -min_characters "2" -max_characters "32"
-valid_characters_regex "[a-zA-Z0-9].*" -description "Long description text for
tooltip" -enabled "true"
```

## add\_ip\_to\_gui

add\_ip\_to\_gui <ip\_name>

| Argument            | Optional | Туре   | Description            |
|---------------------|----------|--------|------------------------|
| <ip_name></ip_name> |          | String | IP generator tool name |

### Description

The add\_ip\_to\_gui is required to be called once, at the end of the IP generator tool definition TCL file. This sends the new definition to the GUI.

#### Example

add\_ip\_to\_gui "Example Soft IP"

## create\_ip

create\_ip <ip\_name> <library> <version>

Create the top-level IP generator tool definition.

| Argument            | Optional | Туре   | Description            |
|---------------------|----------|--------|------------------------|
| <ip_name></ip_name> |          | String | IP generator tool name |
| <library></library> |          | String | IP Library             |
| <version></version> |          | String | IP definition version  |

### Description

The create\_ip creates the top-level IP generator tool definition. If this is called a second time, it wipes out the existing IP generator tool definition. This lets you "source" this TCL script multiple times in an ACE session when you are developing the IP generator tool.

### Example

create\_ip "Example Soft IP" "Speedster7t" "1.3"

## get\_ip\_include\_paths

```
get_ip_include_paths [-ip_name <ip_name>]
```

| Argument                       | Optional | Туре   | Description                           |
|--------------------------------|----------|--------|---------------------------------------|
| [-ip_name <ip_name>]</ip_name> | Y        | String | IP name associated with this property |

### Description

The get\_ip\_include\_paths is used to obtain a list of include paths defined for the output file. This is optional, and is used by any built-in output file generator TCL procedures..

#### Example

```
set includePaths [get_ip_include_paths]
foreach p $includePaths {
        puts $out_file "\`include \"$p\""
}
```

### get\_ip\_macro\_name

get\_ip\_macro\_name [-ip\_name <ip\_name>]

| Argument                                  | Optional | String | Description                           |
|-------------------------------------------|----------|--------|---------------------------------------|
| <pre>[-ip_name <ip_name>]</ip_name></pre> | Y        | String | IP name associated with this property |

### Description

The get\_ip\_macro\_name is used to get the declared macro name. This is optional, and is used by any built-in output file generator TCL procedures.

#### Example

```
set macroName [get_ip_macro_name]
```

## get\_ip\_ports

get\_ip\_ports

### Description

The get\_ip\_ports returns a TCL associative array of all attributes for all IP generator ports. The following attributes are returned for each port: port\_name, signal\_group, direction, width, diagram\_side, description, exposed, tieoff, typedef and clock\_domain.

### Example

```
proc ace_ip::outputVerilogIpPorts {output_file} {
    upvar $output_file out_file
    array set ipgenPorts [ace_ip::get_ip_ports]
    set numPorts [array size ipgenPorts]
    set idx 0
    foreach key [array names ipgenPorts] {
        array set ipPort $ipgenPorts($key)
        set portName $ipPort(port_name)
        set direction $ipPort(direction)
```

```
set width $ipPort(width)
    set desc $ipPort(description)
    set l ""
    if {$direction == "in"} {
        if \{ width > 1\} {
            set w [expr $width - 1]
            set l " input \[$w:0\] $portName"
        }
        if {$width == 1} {
            set l " input $portName"
        }
    }
    if {$direction == "out"} {
        if {$width > 1} {
            set w [expr $width - 1]
            set l " output \[$w:0\] $portName"
        }
        if {$width == 1} {
            set l " output $portName"
        }
    }
    if {$idx < [expr $numPorts - 1]} {</pre>
        puts $out_file " $l, \/\/$desc"
    } else {
        puts $out_file " $l \/\/$desc"
    }
    incr idx
}
```

## get\_ip\_property\_attributes

```
get_ip_property_attributes [-property <property_name>]
```

| Argument                                       | Optional | Туре   | Description         |
|------------------------------------------------|----------|--------|---------------------|
| [-property<br><property_name>]</property_name> | Υ        | String | ACXIP property name |

## Description

The get\_ip\_property\_attributes is used to get a TCL associative array of all the attributes of an IP property. For every property, the following common attributes are returned: name, label, default\_value, description, enabled, verilog\_param, to\_upper, num\_bits, format and alt\_param\_name. Additional property attributes are also returned based on property type. If no property name is passed, a TCL associative array of all properties with their respective attributes is returned.

}

#### Example

```
proc ace_ip::outputVerilogMacroParameterList {acxip output_file} {
   upvar $output_file out_file
   upvar $acxip acxip_data
   array set ipProperties [ace_ip::get_ip_property_attributes]
    set vCounter 0
    foreach key [array names ipProperties] {
        array set ipProp $ipProperties($key)
        set isVerilogParam $ipProp(verilog_param)
        if {$isVerilogParam == "true"} {
            incr vCounter
        }
   }
   if {$vCounter > 0} {
        set idx 0
        foreach key [array names ipProperties] {
            array set ipProp $ipProperties($key)
            set isVerilogParam $ipProp(verilog_param)
            set altParamName $ipProp(alt_param_name)
            set toUpper $ipProp(to_upper)
            set numBits $ipProp(num_bits)
            set verilogFormat $ipProp(format)
            if {$isVerilogParam == "true"} {
                set paramName $key
                if {[string trim $altParamName] != 0} {
                    set paramName $altParamName
                }
                if {$toUpper == "true"} {
                    set paramName [string toupper $paramName]
                }
                set val $acxip_data($key)
```

```
if {$verilogFormat == "unquoted_string"} {
                    # Pass value as-is
                } elseif {$verilogFormat == "quoted_string"} {
                    set val "\"$val\""
                } elseif {$verilogFormat == "sized_hex"} {
                    set val "$numBits\'h$val"
                } elseif {$verilogFormat == "sized_binary"} {
                    set val "$numBits\'b$val"
                } elseif {$verilogFormat == "sized_decimal"} {
                    set val "$numBits\'d$val"
                }
                set includeComma [expr $idx != $vCounter]
                ace_ip::writeVerilogParam out_file $val $paramName $ipProp(label)
$includeComma
                incr idx
            }
        }
    }
}
```

## get\_ip\_property\_value

get\_ip\_property\_value <name>

| Argument      | Optional | Туре   | Description         |
|---------------|----------|--------|---------------------|
| <name></name> |          | String | ACXIP property name |

#### Description

The get\_ip\_property\_value is used to get ACXIP property value. This command can only be used inside the update IP configuration and output file generation callbacks.

#### Example

```
if {[ace_ip::get_ip_property_value "intParam1"] <= [ace_ip::get_ip_property_value
"intParam2"]} {
    ace_ip::add_ip_rule_message "intParam1" "Rule check example" "Error" "Integer
Param 1 must be greater than Integer Param 2. Please fix this."
}
```

## remove\_ip\_gui\_control

```
remove_ip_gui_control <name> <page>
```

| Argument      | Optional | Туре   | Description         |
|---------------|----------|--------|---------------------|
| <name></name> |          | String | ACXIP property name |
| <page></page> |          | String | IP GUI page name    |

#### Description

The remove\_ip\_gui\_control is used to remove a dynamic GUI IP control. A GUI IP control is dynamic if it is added inside the update IP configuration callback. The remove function only removes a control if it exists, otherwise it silently succeeds.

### Example

```
for {set i $acxip(num_lanes)} {$i < 32} {incr $i} {
    remove_ip_gui_control "top_level_int_a_property_index$i" "Overview"
}</pre>
```

## remove\_ip\_gui\_group

```
remove_ip_gui_group <acxip_file_path> <name>
```

| Argument      | Optional | Туре   | Description      |
|---------------|----------|--------|------------------|
| <name></name> |          | String | Group name       |
| <page></page> |          | String | IP GUI page name |

The remove\_ip\_gui\_group is used to remove a dynamic GUI IP group. A GUI IP group is dynamic if it is added inside the update IP configuration callback. The remove function only removes a group if it exists, otherwise it silently succeeds. It also removes any GUI controls that are mapped to the removed group.

#### Example

```
for {set i $acxip(num_lanes)} {$i < 32} {incr $i} {
    remove_dynamic_ip_gui_group "group_x" "Overview"
}</pre>
```

## remove\_ip\_gui\_page

```
remove_ip_gui_page <name>
```

| Argument      | Optional | Туре   | Description |
|---------------|----------|--------|-------------|
| <name></name> |          | String | Page name   |

#### Description

The remove\_ip\_gui\_page is used to remove a dynamic GUI IP page. A GUI IP page is dynamic if it is added inside the update IP configuration callback. The remove function only removes a page if it exists, otherwise it silently succeeds. It also removes any GUI groups and controls that are mapped to the removed page.

#### Example

```
for {set i $acxip(num_lanes)} {$i < 32} {incr $i} {
    remove_ip_gui_page "Page For Lane $i"
}</pre>
```

## remove\_ip\_label

remove\_ip\_label <name>

| Argument      | Optional | Туре   | Description |
|---------------|----------|--------|-------------|
| <name></name> |          | String | Label name  |

The remove\_ip\_label is used to remove calculated values of dynamic IP labels. An IP label is dynamic if it is added inside the update IP configuration callback. The remove function only removes a property if it exists, otherwise it silently succeeds.

### Example

```
remove_ip_label "some_calculated_value"
```

## remove\_ip\_property

```
remove_ip_property <acxip_file_path> <name>
```

| Argument      | Optional | Туре   | Description         |
|---------------|----------|--------|---------------------|
| <name></name> |          | String | ACXIP property name |

### Description

The remove\_ip\_property is used to remove a dynamic IP property. An IP property is dynamic if it is added inside the update IP configuration callback. The remove function only removes a property if it exists, otherwise it silently succeeds. It also removes any GUI controls that are mapped to the removed property.

#### Example

remove\_ip\_property "some\_property"

## send\_ip\_definitions

send\_ip\_definitions

#### Description

The send\_ip\_definitions is called by the GUI after it has established the socket connection with the backend. When this command is invoked, all the IP Generator definitions present in the backend datamodel are sent to the GUI.

#### Example

send\_ip\_definitions

## send\_ip\_gui\_update

#### send\_ip\_gui\_update <acxip\_file\_path> <acxip\_data>

| Argument                            | Optional | Туре   | Description                                                                             |
|-------------------------------------|----------|--------|-----------------------------------------------------------------------------------------|
| <acxip_file_path></acxip_file_path> |          | String | ACXIP filepath                                                                          |
| <acxip_data></acxip_data>           |          | String | The updated set of ACXIP property name-<br>value pairs after the update function is run |

### Description

The send\_ip\_gui\_update sends the refresh of the C++ datamodel from the backend, over the socket to refresh the GUI.

#### Example

send\_ip\_gui\_update \$acxip\_file\_path \$acxip\_data

## set\_ip\_category

```
set_ip_category <category_list> [-ip_name <ip_name>]
```

| Argument                        | Optional | Туре   | Description                        |
|---------------------------------|----------|--------|------------------------------------|
| [-ip_name <ip_name>]</ip_name>  | Y        | String | IP name                            |
| <category_list></category_list> |          | Array  | List of IP Library View categories |

#### Description

The set\_ip\_category determines where the IP shows up in the IP Libraries View tree structure, and possibly in documentation structure.

## Example

```
set_ip_category {"Core" "Memories" "Example Sub-Category"}
```

## set\_ip\_description

```
set_ip_description <description> [-ip_name <ip_name>]
```

| Argument                       | Optional | Туре   | Description    |
|--------------------------------|----------|--------|----------------|
| [-ip_name <ip_name>]</ip_name> | Υ        | String | IP name        |
| <description></description>    |          | String | IP description |

The set\_ip\_description sets the top level description of the IP. Shows up in tool tip in IP Libraries View, and as overview text in the documentation.

#### Example

set\_ip\_description "Description of Example Soft IP for Tooltip in IP Library View,
etc"

#### set\_ip\_macro\_name

set\_ip\_macro\_name <macro\_name> [-ip\_name <ip\_name>]

| Argument                       | Optional | String | Description                           |
|--------------------------------|----------|--------|---------------------------------------|
| <macro_name></macro_name>      |          | String | IP macro name                         |
| [-ip_name <ip_name>]</ip_name> | Y        | String | IP name associated with this property |

#### Description

The set\_ip\_macro\_name is used to declare macro name. This is optional, and is used by any built-in output file generator TCL procedures.

#### Example

set\_ip\_macro\_name "ACX\_EXAMPLE\_SOFT\_IP"

### set\_ip\_property\_value

set\_ip\_property\_value <name> <value>

| Argument        | Optional | Туре   | Description          |
|-----------------|----------|--------|----------------------|
| <name></name>   |          | String | ACXIP property name  |
| <value></value> |          | String | ACXIP property value |

The set\_ip\_property\_value is used to set ACXIP property value. This command can only be used inside the update IP configuration callback.

## Example

ace\_ip::set\_ip\_property\_value "binaryParam1" \$binaryParam1

# set\_ip\_property\_verilog\_param\_attributes

set\_ip\_property\_verilog\_param\_attributes <property> [-format <format>] [verilog\_param <is\_verilog\_param>] [-to\_upper <convert>] [-alt\_param\_name
<alt\_name>] [-num\_bits <num\_bits>] [-ip\_name <ip\_name>]

| Argument                                                          | Optional | Туре    | Description                                                                                                                                                                |
|-------------------------------------------------------------------|----------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <property></property>                                             |          | String  | IP property name.                                                                                                                                                          |
| [-format <format>]</format>                                       | Y        | String  | Property representation format in Verilog<br>file. Valid formats are quoted_string,<br>unquoted_string, sized_hex, sized_binary,<br>sized_decimal.                         |
| [-verilog_param<br><is_verilog_param>]</is_verilog_param>         | Y        | Boolean | Indicates if the IP property is a Verilog parameter.                                                                                                                       |
| [-to_upper <convert>]</convert>                                   | Y        | Boolean | Convert Verilog parameter name to uppercase.                                                                                                                               |
| [-alt_param_name<br><alt_name>]</alt_name>                        | Y        | String  | Alternate Verilog parameter name. Is set to IP property name by default.                                                                                                   |
| [-num_bits <num_bits>]</num_bits>                                 | Y        | Integer | Number of bits to represent the value.                                                                                                                                     |
| [-enum_map<br><list_of_valid_values><br/>]</list_of_valid_values> | Y        | Array   | A 2-Dimensional list where each sublist<br>represents a key-value pair to provide<br>mapping of <list_of_valid_values> for an<br/>enum IP property.</list_of_valid_values> |

| Argument                       | Optional | Туре   | Description                            |
|--------------------------------|----------|--------|----------------------------------------|
| [-ip_name <ip_name>]</ip_name> | Y        | String | IP name associated with this property. |

The set\_ip\_property\_verilog\_param\_attributes is used to specify Verilog parameter attributes for an IP property.

## Example

```
ace_ip::set_ip_property_verilog_param_attributes "hexParam1" -verilog_param "false"
    -to_upper "false" -num_bits 32
# No mapping for "X" so it will pass the label i.e. the enum value specified while
    defining enumParam3.
    ace_ip::set_ip_property_verilog_param_attributes "enumParam3" -verilog_param "true"
    -format "sized_hex" -to_upper "false" -num_bits 4 -enum_map {{"ONE" "1"} {"TWO" "2"} {"
    THREE" "3"} {"FOUR" "4"} {"FIVE" "5"} {"SIX" "6"} {"SEVEN" "7"} {"EIGHT" "8"} {"NINE"
    "9"} {"TEN" "10"}}
```

# set\_ip\_resource\_count

```
set_ip_resource_count <cell> <count>
```

| Argument        | Optional | Туре    | Description        |
|-----------------|----------|---------|--------------------|
| <cell></cell>   |          | String  | Resource type name |
| <count></count> |          | Integer | Resource count     |

# Description

The set\_ip\_resource\_count is used to update resource counts. This can be set dynamically inside the autocorrect/rule check function. This is not directly exposed to the user by default (you could expose it in a Calculated Value label). This is used by ACE to rule check if the current configuration consumes more resources than the target device has available.

## Example

```
set_ip_resource_count BRAM72K [expr {$acxip_data(read_width) *
$acxip_data(addr_depth) / 72000}]
set_ip_resource_count MLP72 [expr {$acxip_data(read_width) *
$acxip_data(addr_depth) / 72000 / 2}]
```

# set\_ip\_resource\_types

```
set_ip_resource_types <list_of_cell_types> [-ip_name <ip_name>]
```

| Argument                                  | Optional | Туре   | Description                                 |
|-------------------------------------------|----------|--------|---------------------------------------------|
| [-ip_name <ip_name>]</ip_name>            | Y        | String | IP name                                     |
| <list_of_cell_types></list_of_cell_types> |          | Array  | List of Resource Types needed by this<br>IP |

# Description

The set\_ip\_resource\_types defines Resource Types needed by this IP. It determines which devices are supported. ACE looks at the primitive resource types supported (NAP\_M, BRAM72K, etc) by a given device to determine if that device can support this IP.

If no resource type is defined, then we assume it is built out of pure synthesizable logic that is supported on all devices.

# Example

```
set_ip_resource_types {"BRAM72K" "MLP72"}
```

# set\_update\_ip\_configuration\_callback

set\_update\_ip\_configuration\_callback <tcl\_proc>

| Argument              | Optional | Туре   | Description             |
|-----------------------|----------|--------|-------------------------|
| <tcl_proc></tcl_proc> |          | String | TCL proc name to be run |

 $\label{eq:configuration_callback} The {\tt set\_update\_ip\_configuration\_callback} is used to {\tt run a TCL} callback {\tt procedure}. This callback can be used to$ 

- perform version migrations
- auto-correct property values
- add/remove, update enabled state or update calculated values of IP properties
- run rule checks
- update resource counts
- define Ports for generated Verilog/VHDL and interactive diagram
- update GUI page list for dynamic pages, and add/remove controls

# Example

set\_update\_ip\_configuration\_callback example\_ip\_update\_ip\_configuration\_proc

```
proc example_ip_update_ip_configuration_proc {target_device acxip_data
acxip_file_path} {
    # Version migration
    # Example:
    if {$acxip_data(version) == "1.0"} {
        set $acxip_data(some_property) "migrated_value"
        set $acxip_data(version) "1.1"
    }
    if {$acxip_data(version) == "1.1"} {
        message "Migrating ACXIP data from version 1.1 to 1.3..."
        $acxip_data(some_property) = "migrated_value"
    } elseif {$acxip_data(version) == "1.2"} {
    } elseif {$acxip_data(version) == "1.3"} {
    } else {
        # set_ip_rule_message <ip_property_name> <title> <status> <message> [-
ip_name <ip_name>]
        set_ip_rule_message "version" "ACXIP Version Compatibility Mismatch"
"Error" "Incompatible ACXIP version detected. The version in the ACXIP file is:
$acxip_data(version). This version of the ACE software supports version 1.0 to
1.3"
    }
    # Auto-correct property values
    # Example:
    if($acxip_data(some_property) > $some_value) {
        $acxip_data(other_property) = $new_value
    }
    # Run rule checks
```

```
# Example:
   # Rule check #2
   if($acxip_data(write_width) != $acxip_data(read_width)) {
       # set_ip_rule_message <ip_property_name> <title> <status> <message> [-
ip_name <ip_name>]
       set_ip_rule_message "read_data_width" "Data width mismatch example" "Error"
"Write width must be set to the same value as Read Width. The current values are
different. Please fix this."
   }
   # Update enabled state of properties
   # Example:
   if($acxip_data(some_property) > $some_value) {
       set_ip_property_enabled_state "some_list_property" "true"
       set ip property enabled state "some int property" "false"
   }
   # Update enum item allowed values
   if($acxip_data(some_property) == "Yes") {
       set_ip_property_enum_items "some_list_property" {"NewItem" "Item1" "Item7"}
   }
   # Update Calculated Values
   # set_ip_label <name> <value> [-ip_name <ip_name>]
   set_ip_label "some_calculated_value" "New Value"
   # set_ip_label_enabled_state <name> <state> [-ip_name <ip_name>]
   set_ip_label_enabled_state "some_calculated_value" "false"
   # Update resource counts
   # This can be set dynamically inside the autocorrect/rule check function
   # This is not directly exposed to the user by default (you could expose it in a
Calculated Value label). This is used by ACE to rule check if the current
configuration consumes more resources than the target device has available.
   # set_ip_generator_resource_count <cell> <count> [-ip_name <ip_name>]
   set_ip_generator_resource_count BRAM72K [expr {$acxip_data(read_width) *
$acxip_data(addr_depth) / 72000}]
   set_ip_generator_resource_count MLP72 [expr {$acxip_data(read_width) *
$acxip_data(addr_depth) / 72000 / 2}]
#########
   # Define Ports for generated Verilog/VHDL and interactive diagram
   # add_ip_generator_port <name> <signal_group> <direction> <width>
<diagram_side> <description> [-exposed <exposed>] [-tieoff <tieoff>] [-typedef
<typedef>] [-clock_domain <domain>] [-ip_name <ip_name>]
```

```
add_ip_generator_port "ref_clk" "Clocks and Resets" "in" 1 "West" "Some
description Text for tooltip and documentation..."
    add_ip_generator_port "rstn" "Clocks and Resets" "in" 1 "West" "Some
description Text for tooltip and documentation..."
    add_ip_generator_port "data_in" "Data Interface" "in" 32 "West" "Some
description Text for tooltip and documentation..."
    add_ip_generator_port "data_out" "Data Interface" "out" 32 "East" "Some
description Text for tooltip and documentation..."
    if($condition){
        add_ip_generator_port "port_a" "Bidi Interface" "inout" 8 "West" "Some
description Text for tooltip and documentation..."
        add_ip_generator_port "port_b" "Bidi Interface" "inout" 8 "East" "Some
description Text for tooltip and documentation..."
    }
    # Add/Remove IP Properties and calculated values as necessary
    # Add function only adds the property if it doesn't already exist, otherwise it
silently succeeds
    # Remove function only removes a property if it exists, otherwise it silently
succeeds
    # Remove function also removes any GUI controls that are mapped to the removed
property
    for {set i 0} {$i < $acxip(num_lanes)} {incr $i} {</pre>
        add_ip_bool_property "some_bool_property_index$i" "Boolean Property Example
Index $i" "Yes" -description "Long description text for tooltip" -enabled "false"
        # add_ip_calculated_value <name> <gui_label> <default_value> [-description
<text>] [-enabled <state>] [-ip_name <ip_name>]
        add_ip_calculated_value "some_calculated_value_index$i" "Example Dynamic
Label Index $i" "Hello World" -description "Long description text for tooltip"
-enabled "true"
    }
    for {set i $acxip(num_lanes)} {$i < 32} {incr $i} {</pre>
        remove_ip_bool_property "some_bool_property_index$i"
        remove_ip_calculated_value "some_calculated_value_index$i"
    }
    # Update GUI page list for dynamic pages, and add/remove controls
    # Add function only adds the page if it doesn't already exist, otherwise it
silently succeeds
    # Remove function only removes a page if it exists, otherwise it silently
succeeds
    for {set i 0} {$i < $acxip(num_lanes)} {incr $i} {</pre>
        # You can put this into a separate TCL proc
        # add_ip_gui_page <name> <parent_page_name> <description> [-columns
<layout_columns>] [-ip_name <ip_name>]
        add_ip_gui_page "Page For Lane $i" "Overview" "Long description text for
page banner"
```

```
add_ip_gui_control "top_level_int_a_property_index$i" "Page For Lane $i"
-control type "combo"
        add_ip_gui_control "top_level_int_b_property_index$i" "Page For Lane $i"
-control_type "text"
        # add_ip_gui_group <name> <label> <page> [-parent <parent_group>] [-columns
<layout_columns>] [-span <column_span>] [-ip_name <ip_name>]
        add_ip_gui_group "group_x" "Example Group X" "Page For Lane $i" -columns 2
-span 1
        add_ip_gui_control "another_list_property_index$i" "Page For Lane $i"
-parent "group_x" -control_type "combo"
        add_ip_gui_group "group_a" "Example Group A" "Page For Lane $i" -parent
"group_x" -columns 1 -span 1
        add_ip_gui_group "group_b" "Example Group B" "Page For Lane $i" -parent
"group_x" -columns 1 -span 1
        # add_ip_gui_control <property_name> <page> [-parent <parent>] [-
control_type <type>] [-span <column_span>] [-ip_name <ip_name>]
        add_ip_gui_control "some_bool_property_index$i" "Page For Lane $i" -parent
"group_a"
        add_ip_gui_control "some_list_property_index$i" "Page For Lane $i" -parent
"group_b" -control_type "radio"
    for {set i $acxip(num_lanes)} {$i < 32} {incr $i} {</pre>
        # You can put this into a separate TCL proc
        # add_ip_gui_page <name> <parent_page_name> <description> [-ip_name
<ip_name>]
        remove_ip_gui_page "Page For Lane $i"
    }
    # This sends the refresh of the C++ datamodel from the backend, over the socket
to refresh the GUI
    send_ip_generator_gui_update $acxip_file_path
}
```

# update\_ip\_binary\_property

update\_ip\_binary\_property <name> [-number\_of\_bits <number\_of\_bits>] [-min <number>] [-max <number>] [-enabled <state>]

| Argument      | Optional | Туре   | Description         |
|---------------|----------|--------|---------------------|
| <name></name> |          | String | ACXIP property name |

| Argument                                               | Optional | Туре    | Description                     |
|--------------------------------------------------------|----------|---------|---------------------------------|
| [-number_of_bits<br><number_of_bits>]</number_of_bits> | Y        | Integer | Number of allowed bits          |
| [-min <number>]</number>                               | Y        | String  | Minimum allowed value           |
| [-max <number>]</number>                               | Y        | String  | Maximum allowed value           |
| [-enabled <state>]</state>                             | Y        | Boolean | Flag to enable/disable property |

The update\_ip\_binary\_property is used to update an IP binary property constraints.

## Example

```
update_ip_binary_property "example_binary_property_1" -number_of_bits 3 -min "000"
-max "111" -enabled "true"
```

# update\_ip\_bool\_property

```
update_ip_bool_property <name> [-enabled <state>]
```

| Argument                   | Optional | Туре    | Description                     |
|----------------------------|----------|---------|---------------------------------|
| <name></name>              |          | String  | ACXIP property name             |
| [-enabled <state>]</state> | Y        | Boolean | Flag to enable/disable property |

## Description

The update\_ip\_bool\_property is used to update an IP boolean property constraints.

### Example

```
update_ip_bool_property "example_bool_property_1" -enabled "true"
```

# update\_ip\_configuration

update\_ip\_configuration <ip\_name> <acxip\_data> <acxip\_file\_path>

| Argument                            | Optional | Туре   | Description                        |
|-------------------------------------|----------|--------|------------------------------------|
| <acxip_file_path></acxip_file_path> |          | String | ACXIP file path                    |
| <ip_name></ip_name>                 |          | String | IP name                            |
| <acxip_data></acxip_data>           |          | Array  | List of ACXIP property-value pairs |

The update\_ip\_configuration is called by the GUI when the user changes a property. This passes data back to the GUI via the socket to update the GUI on rule check messages, the new state of ACXIP property values, list item updates, resource counts, enabled state, etc. This function also clears all the rule check messages prior to running the callback function (including on the GUI side). This function also clears all the port definitions, and you need to add the ports each time this is called, based on configuration.

## Example

```
update_ip_configuration "Example Soft IP" {{prop1 val1} {prop2 val2} {prop3
val3}} $acxip_file_path
```

# update\_ip\_enum\_property

update\_ip\_enum\_property <name> [-items <list\_of\_valid\_values>] [-enabled <state>]

| Argument                                                  | Optional | Туре    | Description                     |
|-----------------------------------------------------------|----------|---------|---------------------------------|
| <name></name>                                             |          | String  | ACXIP property name             |
| [-items<br><list_of_valid_values>]</list_of_valid_values> | Y        | Array   | List of valid values            |
| [-enabled <state>]</state>                                | Y        | Boolean | Flag to enable/disable property |

## Description

The update\_ip\_enum\_property is used to update valid values for IP enum property. It also allows enabling/ disabling properties.

### Example

update\_ip\_enum\_property "some\_list\_property" -items {"NewItem" "Item1" "Item7"}

# update\_ip\_file\_path\_property

update\_ip\_file\_path\_property <name> [-enabled <state>] [-file\_must\_exist <exists>]

| Argument                                | Optional | Туре    | Description                                |
|-----------------------------------------|----------|---------|--------------------------------------------|
| <name></name>                           |          | String  | ACXIP property name                        |
| [-file_must_exist<br><exists>]</exists> | Y        | Boolean | Determine if file exists in the filesystem |
| [-enabled <state>]</state>              | Y        | Boolean | Flag to enable/disable property            |

## Description

The update\_ip\_file\_path\_property is used to update an IP file path property constraints.

## Example

update\_ip\_file\_path\_property "example\_filepath\_property\_1" -enabled "true"

# update\_ip\_float\_property

update\_ip\_float\_property <name> [-min <number>] [-max <number>] [-enabled <state>]

| Argument                   | Optional | Туре    | Description                     |
|----------------------------|----------|---------|---------------------------------|
| <name></name>              |          | String  | ACXIP property name             |
| [-min <number>]</number>   | Y        | Double  | Minimum allowed value           |
| [-max <number>]</number>   | Y        | Double  | Maximum allowed value           |
| [-enabled <state>]</state> | Y        | Boolean | Flag to enable/disable property |

# Description

The update\_ip\_float\_property is used to update an IP float property constraints.

### Example

update\_ip\_float\_property "example\_float\_property\_1" -enabled "true"

# update\_ip\_hex\_property

update\_ip\_hex\_property <name> [-number\_of\_bits <number\_of\_bits>] [-min <number>] [max <number>] [-enabled <state>]

| Argument                                               | Optional | Туре    | Description                     |
|--------------------------------------------------------|----------|---------|---------------------------------|
| <name></name>                                          |          | String  | ACXIP property name             |
| [-number_of_bits<br><number_of_bits>]</number_of_bits> | Υ        | Integer | Number of allowed bits          |
| [-min <number>]</number>                               | Y        | String  | Minimum allowed value           |
| [-max <number>]</number>                               | Y        | String  | Maximum allowed value           |
| [-enabled <state>]</state>                             | Y        | Boolean | Flag to enable/disable property |

# Description

The update\_ip\_hex\_property is used to update an IP hexadecimal property constraints.

## Example

```
update_ip_hex_property "example_hex_property_1" -number_of_bits 32 -min "00000000"
-max "FFFFFFFF" -enabled "true"
```

# update\_ip\_int\_property

```
update_ip_int_property <name> [-min <number>] [-max <number>] [-enabled <state>]
```

| Argument                 | Optional | Туре    | Description           |
|--------------------------|----------|---------|-----------------------|
| <name></name>            |          | String  | ACXIP property name   |
| [-min <number>]</number> | Y        | Integer | Minimum allowed value |

| Argument                   | Optional | Туре    | Description                     |
|----------------------------|----------|---------|---------------------------------|
| [-max <number>]</number>   | Y        | Integer | Maximum allowed value           |
| [-enabled <state>]</state> | Y        | Boolean | Flag to enable/disable property |

The update\_ip\_int\_property is used to update an IP integer property constraints.

### Example

```
update_ip_int_property "example_int_property_1" -min "16" -max "24" -enabled "true"
```

# update\_ip\_label

update\_ip\_label <name> [-value <value>] [-enabled <state>]

| Argument                   | Optional | Туре    | Description                     |
|----------------------------|----------|---------|---------------------------------|
| <name></name>              |          | String  | ACXIP property name             |
| [-value <value>]</value>   | Y        | String  | Calculated property value       |
| [-enabled <state>]</state> | Y        | Boolean | Flag to enable/disable property |

# Description

The update\_ip\_label is used to update an IP property calculated value.

## Example

update\_ip\_label "some\_calculated\_value" -value "New Value" -enabled false

# update\_ip\_signal\_name\_property

update\_ip\_signal\_name\_property <name> [-enabled <state>]

| Argument                   | Optional | Туре    | Description                     |
|----------------------------|----------|---------|---------------------------------|
| <name></name>              |          | String  | ACXIP property name             |
| [-enabled <state>]</state> | Y        | Boolean | Flag to enable/disable property |

The update\_ip\_signal\_name\_property is used to update an IP signal name property constraints.

## Example

```
update_ip_signal_name_property "example_signal_name_property_1" -enabled "true"
```

# update\_ip\_string\_property

update\_ip\_string\_property <name> [-min\_characters <number>] [-max\_characters
<number>] [-valid\_characters\_regex <regex>] [-enabled <state>]

| Argument                                     | Optional | Туре    | Description                                                    |
|----------------------------------------------|----------|---------|----------------------------------------------------------------|
| <name></name>                                |          | String  | ACXIP property name                                            |
| [-valid_characters_regex<br><regex>]</regex> | Υ        | String  | Regular expression for checking validity of the property value |
| [-min_characters<br><number>]</number>       | Υ        | Integer | Minimum number of characters allowed                           |
| [-max_characters<br><number>]</number>       | Υ        | Integer | Maximum number of characters allowed                           |
| [-enabled <state>]</state>                   | Υ        | Boolean | Flag to enable/disable property                                |

## Description

The update\_ip\_string\_property is used to update an IP string property.

## Example

```
update_ip_string_property "example_string_property_1" -min_characters "8"
-max_characters "24" -valid_characters_regex "[0-9].*" -enabled "false"
```

# Chapter 6 : Troubleshooting

This chapter is intended to cover some areas where users frequently report problems, along with solutions. Your Achronix FAE likely can point you to a more recent FAQ.

This chapter will also cover some known ACE issues, with current workarounds where possible.

# ACE Exit Error Codes

The following are some of the known exit codes that can be reported by ACE.

| Code | Description                                                                                                                                                                                                                            | Solution                                                                                                                                                                                                                                                                                                                                   |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | Generic error code; catchall for unexpected problem states.                                                                                                                                                                            | Contact Achronix Technical Support                                                                                                                                                                                                                                                                                                         |
| 2    | Invalid command line options for ACE or acx                                                                                                                                                                                            | See <b>Running ACE</b> (page 282) for a list of valid<br>user command-line options. Contact Achronix<br>Technical Support if problems persist.                                                                                                                                                                                             |
| 3    | License failure. ACE was unable to obtain a required license.                                                                                                                                                                          | See the ACE License & Installation Quickstart<br>Guide (UG002) for more details about<br>configuring ACE license management. Contact<br>Achronix Technical Support if problems<br>persist.                                                                                                                                                 |
| 5    | GUI startup failure: incomplete installation:<br>compatible Java release not found. This error<br>typically indicates that the included version<br>of Java used by the ACE GUI is improperly<br>configured.                            | Contact Achronix Technical Support                                                                                                                                                                                                                                                                                                         |
| 13   | GUI startup failure. This typically indicates<br>that there's a problem in Linux with the<br>LD_LIBRARY_PATH environment variable,<br>though it can also occur due to crashes when<br>loading the 64-bit WebKit2GTK+3 HTML<br>browser. | Linux users: Unset the LD_LIBRARY_PATH<br>environment variable and try running ACE<br>again. Also, ensure there is a compatible 64-<br>bit HTML browser (WebKit2 for GTK+3)<br>installed. See Linux: Incompatible Default Web<br>Browser (page 780) for more details, and if that<br>does not help, contact Achronix Technical<br>Support. |

| Code         | Description                                                                                                                                                                                                                                       | Solution                                                                                                                                                                                                                                                                               |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 100 / 101    | The GUI is attempting to workaround a<br>number of known startup issues through<br>automated forced restarts (which display<br>these exit codes). If restarts fail and the GUI<br>did not start successfully, this is an error.                   | Contact Achronix Technical Support if the GUI<br>did not start.                                                                                                                                                                                                                        |
| values ≤ 136 | Various license management error codes<br>from RLM.                                                                                                                                                                                               | See the ACE License & Installation Quickstart<br>Guide (UG002) for more details on ACE license<br>management. Contact Achronix Technical<br>Support if problems persist.                                                                                                               |
| 201          | The GUI detected a socket communication error with the acx backend.                                                                                                                                                                               | Contact Achronix Technical Support                                                                                                                                                                                                                                                     |
| 202          | When the GUI was attempting to exit<br>gracefully (due either to user request or a<br>fatal error), critical errors occurred, forcing<br>the GUI to perform a hard kill of itself.                                                                | Contact Achronix Technical Support if problems persist.                                                                                                                                                                                                                                |
| 203          | The GUI is unable to start due to underlying framework errors.                                                                                                                                                                                    | Contact Achronix Technical Support. (This is<br>most likely due to an attempt to execute ACE<br>in an unsupported OS.)                                                                                                                                                                 |
| 404          | ACE was attempted to run on an obsolete OS;<br>the GUI is known to be incompatible, so this<br>is disallowed.                                                                                                                                     | Run ACE on a supported operating system.                                                                                                                                                                                                                                               |
| 504          | An error occurred while interpreting the Tcl script file passed to ACE.                                                                                                                                                                           | The Tcl script contains errors or encountered<br>an unhandled error condition. Either fix the<br>bug in the Tcl script, or enhance the error<br>handling in the Tcl script to better handle/<br>report the error condition. Contact Achronix<br>Technical Support if problems persist. |
| 505          | No home directory is defined for the current<br>user. By default, ACE places log files and<br>occasional temp files in locations under the<br>user's home directory, so when no home<br>directory is defined, ACE is unable to proceed<br>safely. | Define a home directory for the userid which<br>starts ACE, or change to a userid with a valid<br>home directory before starting ACE. Consult a<br>local system administrator if necessary.                                                                                            |

| Code | Description                                                                                                                                                                                        | Solution                                                                                                                          |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 506  | ACE is unable to open a socket connection<br>between the GUI and the acx backend.<br>(Specifically, the acx backend is unable to<br>bind a socket port needed for<br>communications with the GUI.) | See the Troubleshooting section below titled:<br>Startup Error — ACE is Unable to Connect on<br>Port NNNN of Localhost (page 768) |
| 507  | The ACE acx backend detected an<br>unexpected GUI socket closure, likely due to<br>a fatal GUI error, when then has caused the<br>acx backend to exit.                                             | Contact Achronix Technical Support                                                                                                |

# **Duplicate Names for Arrays**

If the following error message is seen during the prepare stage of ACE, it indicates the occurrence of a duplicate net name in the RTL. The RTL must be modified to clear the error.

ERROR: int\_cnt[1] is already declared (VNLR-1044)

#### i Note

This situation only occurs when one of the duplicates is a single-dimensional array, and the other is a twodimensional array.

# **Clock Definitions/Constraints**

At least one clock must be defined. Clocks should not be redefined.

# Asynchronous Reset of I/O from the Core

If an I/O is not clocked by a boundary clock, use synchronous reset only.

# Multi-process Functionality License Requirements

Multi-process functionality requires a license for each background process; therefore users with a single license cannot access this functionality. When encountering this limit, contact your FAE for current workarounds.

#### (i) Note

Node-locked licenses support multi-process flows without issues. Floating licenses require a new license for each process.

# Non-ASCII Characters in Path

Do not use non-ASCII characters in paths. For example, if the username includes German extended characters (e.g. umlauts), Chinese, etc., ACE might function incorrectly. To remedy this, ensure that all paths only contain ASCII characters.

# Unable to Load Project: Project is Locked

#### Example error message for locked project

cmd> restore\_project "~/output/quickstart/quickstart.acxprj" -activeimpl "impl\_1"
Project: "~/output/quickstart/quickstart.acxprj" is locked by another ACE session and
cannot be loaded. This project is locked by user: Docs on host: hostname. You can use
restore\_project -force to override the lock. To manually unlock this project, delete the
lock file: ~/output/quickstart/quickstart.lock
cmd>

ACE locks the **Project File** (page 224)s every time it loads a project to prohibit corruption of the project's data. If project locks were not used, and more than one ACE session was allowed to open the same files (or write to the same files) simultaneously, the results would be inconsistent and project data files could become corrupted.

#### A Caution!

Do not use this forced unlock procedure to run multiple ACE sessions on the same project simultaneously, or file corruption might occur!

Project definitions, Implementation definitions, saved implementation states (for both normal flow and incremental compilation), log files, and output directories might get corrupted from having two or more ACE sessions writing to the same files.

Most notably, do not start another ACE session on a project while Multiprocess is already running on that same project; the Multiprocess session must own the project lock (which also locks all implementations) to ensure consistent results and avoid file corruption.

Achronix does not support simultaneously running multiple ACE sessions on the same project (directory). This is known to cause problems. Do not do this! The project lock files are there to protect users; do not attempt to bypass them.

In rare cases, ACE can crash, mistakenly leaving a project in the locked state. The easiest way to unlock a mistakenly-still-locked project (which has just failed to load in the GUI) is the following:

765

- 1. Double-check that there are no other legitimate users of the project file, including yourself in another desktop!
- 2. In the Tcl Console View (page 146), click on the empty cmd> line.
- 3. Click the up arrow (†) on the keyboard. Each click of the up arrow moves one step backwards through the Tcl command history. Keep moving backwards through the Tcl command history until the Tcl command which attempted to load the locked project is displayed. The failed command should be a call to load\_project (page 668) or restore\_project (page 689).

#### (i) Note

If you regularly load multiple Projects into ACE at the same time, you might have to go back several commands to reach the one that failed.

4. Move to the end of the Tcl command line (press the **End** key on the keyboard), press the space bar, then add the argument "-force" to the end of the command. This argument forces ACE to load (or restore) the project despite the presence of a lock, and this session of ACE re-locks the project, taking ownership using a new lock.

#### Example workaround

```
cmd> restore_project "~/output/quickstart/quickstart.acxprj" -activeimpl "impl_1"
-force
```

5. Press the Enter key to issue the Tcl command to load or restore the project.

# **Changing ACE Font Sizes**

# Fonts in Views

Some views in ACE (particularly diagrams) allow users to specify the exact font/size which will be used. These are typically defined in the ACE preferences, under **Window**  $\rightarrow$  **Preferences**  $\rightarrow$  **General**  $\rightarrow$  **Appearance**  $\rightarrow$  **Colors and Fonts**. There are categorical groupings for each such view allowing its own font and color definitions.

Views that lack their own specific font definition will inherit the font definitions in the **Basic** category, almost always using the **Dialog Font**. A very few views may also use the **Banner Font** and **Header Font** (also found in the **Basic** category) for limited rendering.

The **Dialog Font** used in most ACE views is directly inherited from the underlying GUI application framework stack, (typically called the **Application Font** in Linux/GTK, or **Message Box Font** in Windows).

The various views within ACE often accept font changes immediately, but, in some cases, it might be necessary to restart ACE to see the font changes inherited from the OS propagate completely as the new **Dialog Font** value throughout the application.

#### Caution!

It is highly recommended that a plain font (not bold, not italics) be chosen as the **Dialog Font**! There is no font naming standard followed across all OS flavors (or even within a single OS), so these plain font varieties are often called "Regular", sometimes "Book", sometimes "Medium", and sometimes don't have a particular designation.

## Linux:

The config location can vary in every Linux desktop / version / distro. In Linux, ACE uses the GTK+ widgets and fonts, so changes should be restricted to those settings.

For example, in the RHEL/CentOS 7.x KDE Plasma desktop, it can be configured from the main desktop (not ACE) menu under System Settings  $\rightarrow$  Application Appearance  $\rightarrow$  GTK+ Appearance  $\rightarrow$  GTK+ Fonts.

As another example, in the RHEL8 Gnome3 desktop, it can be configured from the Gnome Tweaks tool (gnome-tweaks), under **Tweaks**  $\rightarrow$  **Fonts**  $\rightarrow$  **Interface**.

## Windows:

In Windows 10 and 11, users are no longer allowed direct control of the font at a system-wide level through the **Control Panel**. (Though some third-party tools still allow this to be configured). Windows users will be best served by changing the **Basic**  $\rightarrow$  **Dialog Font** value directly in the ACE **Colors and Fonts** preferences, as mentioned in the beginning of this troubleshooting entry.

# Fonts in HTML Reports

The font used in the HTML Reports is directly inherited from the system's HTML browser's font settings. The system HTML browser can be Internet Explorer (Windows) or WebKit2GTK3 (Linux). The HTML reports typically use the "Proportional" (sometimes called "Web Page") font and Monospace (also called "Plain Text") font types — change these settings in the operating system's HTML browser settings to make the fonts change in the ACE HTML Report viewer.

# Unable to Initialize Reserved Module Name List

This problem is reported by the ACE GUI at startup with the following dialog.

#### (i) Note

The exact library name, "Speedster7t" in the screenshot, differs based upon the customer's specific license/installation.



Typically this error indicates that the device overlay files have been installed incorrectly. The list of reserved module names is contained in the overlay files for each Achronix device/library. In very rare cases, the file may exist in the expected location but ACE might lack read permissions for the file.

The file ACE is attempting to read should be located at:

<ace\_install\_directory>/libraries/<library\_name>/reserved\_module\_names.txt

where <ace\_install\_directory> is the directory where ACE has been installed and the ace executable is found, and <*library\_name*> is the name of the library from the error dialog (though forced to all lowercase letters).

Thus, if the Linux user "tester" has installed ACE in their home directory under

/home/tester/ace/Achronix-linux

and saw the error dialog captured above about the Speedster7t library, then ACE was unable to find (or potentially experienced permission issues when attempting to read) the file:

/home/tester/ace/Achronix-linux/libraries/speedster7t/reserved\_module\_names.txt

To solve the problem, contact Achronix technical support for help on correctly installing both ACE and the associated device overlay file(s) in the appropriate location.

# Startup Error — ACE is Unable to Connect on Port NNNN of Localhost

This problem is reported by the ACE GUI at startup with the following (rather verbose) "Startup Error" dialog:



# To Determine the Root Cause

Attempting to run ACE in batch mode (with ace -batch, see Running ACE (page 282)) can help determine the source of the problem. In batch mode, the GUI is not used; therefore, no socket connection is needed between the GUI and the acx backend.

If batch mode ACE does not start, or takes more than 60 seconds before providing the Tcl command prompt (regardless of whether or not ACE reports license errors), then there's typically a licensing configuration problem.

If batch mode ACE starts successfully in less than 60 seconds, then there is a firewall configuration problem.

In very rare cases, usually when ACE is installed in a remote NFS location with many device overlays, poor filesystem (HDD) or network (NFS) performance may also cause these timeouts. In these rare cases, simply trying to start ACE in GUI mode a second time will often succeed where the first attempt had a timeout, because for the second attempt the information will now be found in the filesystem cache in memory, which is much faster to access.

#### Caution!

Though unlikely, realize it is possible for multiple causes to occur for the same user. It might be necessary to first fix a firewall problem, and then fix a licensing problem. After attempting one kind of fix, if the dialog continues to appear, re-diagnose the problem to verify whether the same issue is still occurring, or whether a new issue is occurring but showing the same symptom.

When batch mode has started, you can exit ACE batch mode by typing "exit" or "quit" and pressing Enter.

### If it is a Firewall Problem

ACE always uses localhost (IPv4 address 127.0.0.1) TCP sockets to communicate between the ACE GUI program and the ACE backend program acx (the pure textual TCL interface when ACE is started with 'ace -b' or 'ace -batch'; see Running ACE (page 282) for details). In most cases, the required localhost sockets are already configured to be available, but in highly restricted network environments, the required localhost sockets might need special

permissions to be added to the firewall of the workstation running ACE. Obtain help from your local system administrator and/or network administrator to properly configure the firewall to allow the necessary network traffic.

| (i) Note                                                                                                             |
|----------------------------------------------------------------------------------------------------------------------|
| If the system/network administrator needs to know exactly which executables require firewall permissions, tell them: |
| (Windows)                                                                                                            |
| <pre>• <ace_install_dir>\system\gui\ACE_GUI_Launcher.exe</ace_install_dir></pre>                                     |
| <pre>• <ace_install_dir>\system\cmd64\acx.exe</ace_install_dir></pre>                                                |
| (Linux)                                                                                                              |

- <ace\_install\_dir>/system/gui/ACE\_GUI\_Launcher
- · <ace\_install\_dir>/system/classic\_gui/ACE\_GUI\_Launcher
- <ace\_install\_dir>/system/cmd64/acx

By default, ACE uses an automatically chosen unused (free) TCP port socket somewhere in the range 1024-65535. This automatically chosen port number can change every time ACE is started.

To force ACE to use a specific TCP port number (and thus require only a single hole poked in the firewall for each executable), add the "-acxport <portnumber>" commandline option when starting ACE (where <portnumber> is the desired TCP port number in decimal). Ask your network or system administrator exactly which port number should be specified — this is the same port number the administrator opened for each executable in the firewall.

Please contact Achronix Technical Support if problems persist.

In some licensing configurations, additional firewall ports might need to be opened specifically for the licensing software. Refer to the ACE Installation and Licensing Guide (UG002) for details.

The following executables may require firewall access for the licensing software:

(Windows)

 $\bigcirc$ 

```
· <ace_install_dir>\system\cmd64\acx.exe
```

```
• <ace_install_dir>\ace.exe
```

(Linux)

- · <ace\_install\_dir>/system/cmd64/acx
- <ace\_install\_dir>/ace

### If it is a Licensing Problem

A socket connection timeout can also occur when the GUI is attempting to open a connection to the acx backend before the acx backend is ready. This situation can occur if the acx backend is having trouble finding licenses for ACE itself, or for the FPGA/eFPGA devices currently installed for ACE. This long, slow license search is most often seen when ACE is configured to find its license on one or more license servers, and one of those specified servers is not actually a license server (typos and license server migrations being the frequent causes).

Refer to the ACE Installation and Licensing Guide (UG002) for details on how to determine the workstation's current RLM license configuration, and how to diagnose and fix what might be going wrong. Frequently, it is simply a matter of correcting or removing the incorrect license server setting in the "RLM\_LICENSE" environment variable. Contact Achronix Technical Support if problems persist.

#### Workaround: Extending the Timeout

This workaround is not generally recommended, but in cases where there are transient networking or license server problems, it might be necessary to extend the ACE socket initialization timeout value to be more permissive. To extend the timeout, set the environment variable "ACX\_GUI\_INIT\_TIMEOUT\_SECONDS" to a decimal number > 60. Invalid numeric values cause a non-fatal warning to be logged, and the default value of 60 seconds will be used instead. Please work with your IT department for help configuring the environment variable such that it will be set for every ACE startup.

## If it is a Filesystem or Network Performance Problem

Again, this is rarely the case – licensing configuration problems are much more likely. But if it proves to be a performance problem, installing ACE locally, particularly on an SSD (instead of an HDD), will eliminate network filesystem performance problems. If a local installation is impossible, there are some potential workarounds available.

### Workaround: Extending the Timeout

It might be necessary to extend the ACE socket initialization timeout value to be more permissive. To extend the timeout, set the environment variable "ACX\_GUI\_INIT\_TIMEOUT\_SECONDS" to a decimal number > 60. Invalid numeric values cause a non-fatal warning to be logged, and the default value of 60 seconds will be used instead. Please work with your IT department for help configuring the environment variable such that it will be set for every ACE startup.

#### Alternate Workaround: Multiple Parallel ACE Installs

Alternately, if there are too many device overlays installed at the same time (the exact value of "too many" will vary based on drive and network performance, but so far this problem has only been reported with more than six device overlays installed on a slow NFS mount), users could install ACE in two (or more) separate locations, with a subset of the device overlays applied in each install location. This would reduce the amount of device (and related license) processing that occurs at ACE startup, to the extent that a timeout will no longer occur.

# Unexpected ACE GUI problem: java.lang.NoClassDefFoundError: com/achronix/api/APIPlugin

This typically indicates that a local file cache (maintained by the frameworks underlying ACE) has become corrupted. There are a variety of potential causes, with the most frequent being if network file system (NFS) problems occur when programs (like ACE) access the user's home directory.

Thankfully the fix for ACE is relatively simple; start ACE with an additional command-line argument: "-clean". This will cause ACE to immediately discard the old file cache as it starts, and rebuild the cache from scratch. Note that it is not recommended to use the -clean option every time ACE is started, because rebuilding the cache can significantly increase ACE startup times.

#### ace -clean

If the user normally starts ACE from an application/start menu or a desktop shortcut (instead of from a command prompt), and/or the user does not know how to start ACE from the command prompt, attempt the next recommended fix, described below.

# If the problem persists after -clean, or if the command prompt is unfamiliar

There's a more drastic and thorough solution, manually deleting a sub-directory under the user's home directory. Be warned, this not only clears the cache, but also resets all ACE GUI preferences to their default values, so this is not recommended unless the "-clean" option has already been attempted.

The ACE GUI filecache is stored in the user's home directory under a sub-directory named ".achronix", with a separate sub-directory used by each version of ACE, named with the prefix "workspace\_" and the suffix being the version number of ACE. For example, when using ACE v9.1.1, the sub-directory will be named "workspace\_9.1.1"

The full path for our example would be "<*user\_home\_directory*>/.achronix/workspace\_9.1.1". Delete this subdirectory, and ACE should then be able to start normally.

### **Detailed instructions:**

- 1. Open your preferred graphical file manager.
  - a. Linux: The exact program name will vary by the user's choice of Desktop Environment, but the five most commonly used program names would probably be Files, nautilus, dolphin, thunar, or caja.
  - b. Windows: the program provided by Microsoft for all versions of Windows is File Explorer
- 2. Navigate to your home directory.
  - a. Linux: For example username "acxuser", this would typically be the directory "/home/acxuser/". (Replace "acxuser" with your own username.)
  - b. Windows: For example username "acxuser", this would typically be:

🔵 > This PC > Local Disk (C:) > Users > acxuser >

(Replace "acxuser" with your own username.)

- 3. Double-click (or expand) the sub-directory (under your home directory) named ".achronix".
- 4. Find the sub-directory under ".achronix" with the prefix "workspace\_" and the suffix matching the version of ACE that fails to start. Continuing our prior example, for ACEv9.1.1, this would be the directory name "workspace\_9.1.1".

Right-click that workspace directory and in the resulting context menu, choose "Delete".

The ACE workspace directory (containing the corrupted file cache) has now been deleted/cleaned. The next time ACE is started, the file cache (and the rest of the workspace) will be recreated from scratch, with default values.

(If the same error message occurs the next time ACE is started, even after you've deleted the workspace directory, contact Achronix technical support.)

# Multiprocess Summary Report Shows "No Timing Results Found" for Successfully Run Implementations with Existing Timing Reports

In cases of high network file system read/write latency, it is possible that the multiprocess system might not find the required timing information within the allowed period after the external process has completed execution (most likely to occur when using external job submission systems). Sometimes the file writes occurring on the remote machine might be cached for a while, and not immediately written to the NFS drive, so that when the ACE Multiprocess system notices that the spawned process has completed, it does not find the needed timing information on the NFS drive. Therefore, the file read attempt times out, and Multiprocess gives up looking.

For these cases, there is a user preference on the Multiprocess: Configure Custom Job Submission Tool Preference Page (page 209) called Allowed seconds of NFS write latency. To fix the problem, increase the value of this preference to allow more time between the completion of the implementation's flow process and when ACE gives up looking for the expected timing information for that completed implementation.

# Windows: ACE Incorrectly Reports Read/Write File Permission Problems

In some cases, the ACE GUI might report a file permissions error when attempting to read or write a file on a network drive, when the permissions should actually allow the attempted read or write. As a workaround, please move the affected project to a local, non-network drive location.

# Windows: ACE GUI Shown as "Not Responding"

In rare cases, when the Floorplanner Perspective is first changed, the ACE GUI window can become solid grey, and the title bar can change to read something like "ACE - Achronix CAD Environment - *designName* - *implementationName* - *(deviceName)* - *(Not Responding)*". When this problem has been reported, it has always been the case that the Floorplanner is taking too long to repaint.

The Windows operating system requires that applications check-in every five seconds, or the application is deemed non-responsive. Non-responsive applications are given a figurative kick-in-the-pants by Windows, and asked to repaint the screen. When the screen paint itself is taking more than five seconds, as can happen with poor Floorplanner Optimization settings, an application can be forced into an effective infinite-loop of paint requests from the operating system.

If, in Windows, it is ever noticed that the ACE GUI is being called non-responsive by Windows (check the application title bar), ACE has most likely entered this looped painting state. To escape this state, change back to the Project perspective (or any other perspective without the Floorplanner view visible), then navigate to the the Floorplanner View Optimizations Preference Page (page 203), (Window  $\rightarrow$  Preferences  $\rightarrow$  Floorplanner View Optimizations) and ensure that Enable Incremental Rendering and Render large areas as smaller tiled areas are both enabled for the current design's complexity level.

#### (i) Note

Both are enabled by default for everything except trivial designs. Press the **Restore Defaults** button to return to the default settings. If both are already enabled, and the non-responsive state still occurs, please call Achronix Technical Support for guidance on further Floorplanner Optimization tweaks.

# Windows: Garbage sometimes appears in the Floorplanner View during panning operations (and remains after panning is completed)

In some cases customers are reporting Floorplanner render errors during/after panning operations.

While Achronix works to fix these rendering errors, there are two potential workarounds to mitigate the render problem.

- Whenever render errors appear in the Floorplanner, first ensure the Floorplanner View has the application focus, then press the backtick (\*) key on the keyboard to force the Floorplanner to perform a complete repaint of the full render area.
- In the Floorplanner preferences (Window → Preferences → Floorplanner View Optimizations) enable the When panning, show only background layer checkboxes for both the High and Medium complexity columns. Now, when the panning operation completes, the full view will be automatically re-rendered, eliminating any mid-pan render errors.

# Windows: ACE Startup Error Due to Missing DLL Component in Windows 10

In some Windows 10 configurations, the following error dialog might appear when invoking the ACE GUI. This error occurs due to a missing DLL component from the Visual Studio redistributable installer. This situation can be resolved by reinstalling the vc\_redist.x64.exe executable. This executable can be downloaded from the following link: https://www.microsoft.com/en-ca/download/details.aspx?id=48145.

| 0 | Startu | p Error                                                                                                                 | × |
|---|--------|-------------------------------------------------------------------------------------------------------------------------|---|
|   |        | The ACE backend process terminated unexpectedly with a return code of -1073741515 before a<br>connection could be made. |   |
|   |        | Shutting down.                                                                                                          |   |
|   |        |                                                                                                                         |   |
|   |        | Close                                                                                                                   |   |

Figure 325 • ACE Startup Error

# Windows: The icons and buttons in ACE are too small

There are two main ways to deal with this. You can ask Windows to scale everything, which will affect all applications (not just ACE), and if that's not good enough, you can additionally make just ACE further alter the icon (and potentially font) scaling.

# Asking Windows to upscale images and fonts for all applications

See the Microsoft documentation here for related information: https://support.microsoft.com/en-us/windows/ make-text-and-apps-bigger-c3095a80-6edd-4779-9282-623c4d721d64

# Asking just ACE to upscale images and fonts

ACE already scales fonts (and to a lesser extent images) according to what Windows tells it to do, following the settings from the OS, as described above. But by default ACE uses a very coarse scaling granularity for images, and only doubles or triples icon sizes (like 200% or 300%), and does not upscale images/icons by smaller fractions (like 125% or 150%). This is because the fractional scaling can reportedly cause the (Eclipse) frameworks underlying ACE to crash with some video drivers. Thus to maximize stability, ACE disables framework-based fractional scaling by default.

Windows itself has more advanced scaling in the Compatibility Settings area which some users may prefer, but this can also make fonts and images blocky or blurry, so ACE does not enable these settings by default either.

Users having trouble due to the icons/buttons being too small may choose to try either alternate scaling option below (or both in combination) **at their own risk**.

# Asking Windows to alter the scaling settings for just ACE (which may make text and fonts blurry/blocky)

Close ACE if it is running. Open **Windows Explorer** and navigate to the directory where ACE was installed. (By default this will be C:\Program Files\Achronix CAD Environment) In that directory find the ace executable, right-click that file, and select **Properties**. A dialog titled **ace.exe Properties** will open. Turn to the **Compatibility** tab, and near the bottom of the dialog press the **Change high DPI settings** button, which will cause a new smaller dialog to appear, also titled **ace.exe Properties**. Near the bottom of this dialog select the checkbox **Override high DPI scaling behavior. Scaling performed by:** and then in the combobox below, select the value **System (Enhanced)** instead of the default value of **Application**. Press the **OK** button to close the small properties dialog, and then press the **OK** button to close the larger properties dialog as well. Start ACE, and observe that image and font scaling may now occur in a more granular/fractional fashion, though things may now be blurry and/or blocky.

| General                           | Compatibility                                                                | Security         | Details   | Previous Versions                                                                                                                                                                                                                               |                                                                                          |  |  |
|-----------------------------------|------------------------------------------------------------------------------|------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|--|--|
|                                   | ogram isn't worki<br>the compatibility                                       |                  |           | arsion of Windows, try<br>ace.exe Properties                                                                                                                                                                                                    |                                                                                          |  |  |
| Run                               | compatibility tro                                                            | ubleshoote       | r         | ace.exe Properties                                                                                                                                                                                                                              | ,                                                                                        |  |  |
| How do                            | l choose compa                                                               | atibility settir | igs manua | Choose the high DPI settings for this program.                                                                                                                                                                                                  |                                                                                          |  |  |
| Compatibility mode                |                                                                              |                  |           | Program DPI                                                                                                                                                                                                                                     | Use this setting to fix scaling problems for this program instead of the one in Settings |  |  |
|                                   |                                                                              |                  |           | instead of the one in Settings                                                                                                                                                                                                                  |                                                                                          |  |  |
| Wind                              | ows 8                                                                        |                  |           | Open Advanced scaling settings                                                                                                                                                                                                                  |                                                                                          |  |  |
| 8-bit (                           | gs<br>duced color mo<br>(256) color<br>n in 640 x 480 sc<br>sable fullscreen | reen resolu      |           | changes after you sign in to Windows. Windows can<br>this scaling problem for this program by using the DP<br>set for your main display when you open this program<br>Use the DPI that's set for my main display when<br>I signed in to Windows | 'I that's                                                                                |  |  |
|                                   | n this program a                                                             | Is an admin      | istrator  | High DPI scaling override                                                                                                                                                                                                                       |                                                                                          |  |  |
| Register this program for restart |                                                                              |                  |           | Override high DPI scaling behavior.<br>Scaling performed by:                                                                                                                                                                                    | Override high DPI scaling behavior.                                                      |  |  |
|                                   | Change high D                                                                | )PI settings     |           | Application                                                                                                                                                                                                                                     |                                                                                          |  |  |
| •                                 | Change settings                                                              | for all users    | 6         | Application<br>System<br>System (Enhanced)                                                                                                                                                                                                      | ancel                                                                                    |  |  |

#### Figure 326 • Screenshot Showing the Sequence to Change the DPI Settings

To revert this change, disable this supplemental scaling functionality and return ACE to the default behavior:

- 1. Close ACE if it is running.
- 2. Open **Windows Explorer** and navigate to the directory where ACE was installed. (By default this will be C: \Program Files\Achronix CAD Environment)
- 3. In that directory find the ace executable, right-click that file, and select **Properties**. A dialog titled **ace.exe Properties** will open.
- 4. Turn to the **Compatibility** tab, and near the bottom of the dialog press the **Change high DPI settings** button, which will cause a new smaller dialog to appear, also titled **ace.exe Properties**. Near the bottom of this dialog change the setting **System (Enhanced)** back to the default of **Application**, and then deselect (uncheck) the checkbox **Override high DPI scaling behavior. Scaling performed by:**.
- 5. Press the **OK** button to close the small properties dialog, and then press the **OK** button to close the larger properties dialog as well.

The next time ACE is started the scaling will be back to the default behavior.

# Enabling ACE's application framework's fractional scaling (fonts remain crisp, but icons may become blurry and ACE may experience instability with some video drivers)

Close all running instances of ACE. Open the file

<ace\_installation\_directory>\system\gui\ACE\_GUI\_Launcher.ini in a text editor (like notepad), and at the
bottom of the file add a new line:

Add the following new line to the bottom of the file ACE\_GUI\_Launcher.ini

-Dswt.autoscale=quarter

And then save the changes to the file. Note that saving the file may require Administrator access; work with IT or MIS personnel to make this change if required.

The next time ACE is started, this will allow ACE to scale images and icons to the more granular fractional values requested by Windows, like 125%, 150%, 175%, 200%, 225%, etc.

If after making this change, some images within ACE vanish, or if ACE experiences crashes (or even silently vanishes), simply remove that new line from the bottom of the ACE\_GUI\_Launcher.ini file to return to the prior (much more stable) behavior.

# Linux: Resource Limits: ACE Reports an OutOfMemory Error, But There is Plenty of Free Memory Available

#### (i) Note

When an OutOfMemory error is reported by ACE, always verify that there is sufficient physical and virtual memory available to run ACE. Running out of physical or virtual memory is the true cause of the error message in >95% of the cases reported.

Consult an Achronix FAE if the ACE memory requirements are unknown for the available licensed Achronix target devices.

There are several types of resource exhaustion in Linux that can be reported as an OutOfMemoryError. Insufficient thread and/or file resources may have similar error reports in some cases.

In some OS configurations, Linux can create a new thread for each file opened, so even when thread resource limits are mentioned in the detailed error message, it could be a case where the file limits (max files open simultaneously) are set too low for the user.

A quick fix attempt would be, before starting ACE, close all other running programs which could have files open. If this works, then the file limits are very likely the problem. But even if this doesn't help on the first attempt, the root problem could still be due to file limits.

In the bash shell, (other shells use different, but often similar, commands,) this is typically managed with the 'ulimit' command. All current ulimit settings can be queried using 'ulimit -a', or query just the open file limit with 'ulimit -n'.

To see if a higher file limit helps, if (for example) the current open files value is 1000, try raising it to 2000, then run ACE. To increase the file limit in this way using the bash shell, use the command 'ulimit -n 2000'. It might be possible to remove the limit entirely with 'ulimit -n unlimited'. (Again, users of other shells need to use a different command.)

It is highly recommended that these file limit changes be performed under the supervision of the system administrator. System administrators often apply upper bounds for such ulimit assignments, and individual users cannot exceed those upper bounds without system administrator assistance.

If raising the open files limit does allow ACE to launch correctly, the new raised limit should be applied to the user's '~/.bashrc' (or similar) files loaded at shell startup, again with help from the system administrator if necessary. (Alternately, if permissions allow it, create a script used to start ACE. In that script, the file limit could be temporarily raised before starting ACE, and then lowered again when ACE completes execution.

# Linux: In the TWM Window Manager, the First Time the ACE GUI is Started After Installation, the ACE Window is So Small Users Might Not See it

Currently, twm is ignoring the ACE GUI's attempts to set its own initial application window size and location. After ACE is installed (and until the window is moved and resized), the ACE window is in the upper-left corner of the screen, with tiny dimensions (we've seen it as small as 7 pixels wide by 7 pixels tall). This tiny window is often not noticed, especially if there already is a minimized application icon in that region of the screen.

When ACE is running in that tiny window, the ACE window can be moved and enlarged in the same manner as with any other running application window in twm.

ACE does not support the twm standard of choosing the application window's position and dimensions at startup with command-line arguments. Instead, ACE remembers the position and dimensions at application shutdown, and the next time the application is started, ACE returns to that same position and dimension from the last ACE session.

# Linux: Odd Behavior When Using X DISPLAY Forwarding if the X Client and X Server Are More than One Major Revision Apart

When running the ACE GUI, the host workstation and display workstation must be at most one OS major revision apart (RHEL7 can talk to RHEL8, but RHEL7 should not talk to RHEL9).

RHEL only supports X DISPLAY redirection across adjacent major operating system revisions. There are known problems when (for example) applications like the ACE GUI are running on RHEL7 but having their X DISPLAY redirected to a RHEL9 workstation, or vice-versa. Users attempting to bridge multiple OS revisions in this way see GUI painting errors and mouse handling errors, especially for drag-and-drop operations. Some users have also reported hung GUIs and application crashes when they attempted to host ACE on RHEL7 and display on RHEL9.

Because the operating system vendor does not support this behavior, Achronix is unable to support it.

# Linux: ACE Menus Do Not Show Icons Next to the Action Names

Most actions within ACE are intended to have an associated graphical icon. This icon is able to be displayed in the drop-down menus within ACE. If no icons are displayed next to actions in menus, this behavior is caused by a GTK+ configuration that has disabled the icons.

To re-enable icons for all GTK+ applications (not just ACE), the following command should reset the display. As this issue is the result of GTK+ functionality, and not ACE functionality, this tweak is not officially supported by Achronix.

gconftool-2 --type boolean --set /desktop/gnome/interface/menus\_have\_icons true

# Linux: ACE Ignores LD\_LIBRARY\_PATH

In the majority of cases, the ACE GUI crashes when it encounters custom/obsolete libraries through an assigned LD\_LIBRARY\_PATH environment variable.

Because of this, by default ACE intentionally ignores preassigned LD\_LIBRARY\_PATH values when it starts.

#### A Caution!

Achronix does not support ACE when forced to run using LD\_LIBRARY\_PATH.

**At your own risk**, add the command-line argument "-enable\_ld\_library\_path" to force ACE to keep the preassigned LD\_LIBARY\_PATH value at startup.

./ace -enable\_ld\_library\_path

# Linux: ACE forces the use of the GDK X11 rendering engine even while running under Wayland

Technically this is not a bug, but an intentional design choice. But because some users prefer the new features in Wayland despite the known stability of X11 on all Achronix-supported versions of Linux, we'll include an entry for this detail.

At present, the Eclipse framework underlying ACE has a high number of bugs when rendering natively under Wayland. Mouse actions, particularly relating to drag-and-drop, are especially problematic. Custom diagram rendering performance (as used in the Floorplanner, for example) has been observed to be much slower under Wayland.

To work around these limitations while the Eclipse framework developer community learns how to best use GTK/ GDK under Wayland, Achronix currently forces ACE to render in GTK/GDK using X11 programming interfaces at all times, even while running on Wayland. If users really want to allow the Eclipse frameworks underlying ACE to render GTK/GDK natively under Wayland, they do so at their own risk – this is unsupported by Achronix due to all the known framework issues.

#### UNSUPPORTED call to allow ACE to use the known-buggy Wayland GTK/GDK rendering

./ace -allow\_wayland

Note that using the above startup command does not force ACE to use Wayland. There's a large number of details that must already be in place before using Wayland rendering is even possible, which are outside the scope of this document. When ACE is started in this manner, the Eclipse frameworks underlying ACE will automatically choose whether to use X11 or Wayland based on a number of factors, also beyond the scope of this document. This command simply ensure ACE will no longer enforce the use of X11 rendering in all cases.

To help convince any optimists that it truly is a bad idea to start ACE this way, the list of the Eclipse framework's Wayland bugs can be viewed online at the links below.

(recently reported issues:)

https://github.com/eclipse-platform/eclipse.platform.swt/issues?q=is%3Aissue+label%3AWayland+

(older issues:)

https://bugs.eclipse.org/bugs/buglist.cgi?

When viewing the issues lists, readers should keep in mind that the current ACE release is using Eclipse framework version 4.28, also known as version 2023-06.

# Linux: Incompatible Default Web Browser

| 🖸 64-bit | HTML Browser not available                                                                                                                                                |     | × |  |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|---|--|
|          | ACE could not find a compatible 64-bit embeddable HTML browser on your<br>system.<br>Please read the ACE Release Notes for the workarounds available on your<br>platform. |     |   |  |
|          | Cle                                                                                                                                                                       | ose |   |  |

At startup, ACE tries to find a compatible 64-bit embeddable HTML browser already installed on the system for ACE to use to display HTML reports and help content. If no such embeddable browser is detected within the Linux installation, ACE shows the warning dialog above and reverts to a primitive fallback HTML browser (which has slightly reduced functionality and known stability issues on some platforms, but is still better than nothing)

RHEL/CentOS v7.9 and RHEL/Rocky v8.x, SUSE15, Ubuntu 20.04LTS, and Ubuntu22.04LTS customers are not expected to experience any problems with web browser support. Customers running on unsupported Linux distros might need to perform additional steps to ensure ACE has a compatible web browser framework available if the fallback (reduced-functionality) browser proves to be unstable.

# Solution

To solve reported web browser incompatibility problems, work with your IT department to install an ACE-compatible 64-bit web browser in your distribution.

For all Achronix-supported Linux operating systems, any WebKit2GTK packages compiled for GTK+3 support are expected to work, regardless of version number, though the latest versions from the official distro repositories are expected to be the fastest and most stable.

#### A Caution!

#### ACE Linux web browser support requires GTK+3 and WebKit2

Starting in ACE v8.4, ACE is no longer compatible with GTK+2. In Linux ACE requires GTK+3. GTK+4 is not yet supported.

Starting in ACE v8.4, ACE is no longer compatible with WebKit (unofficially also known as WebKit1). In Linux ACE requires WebKit2 (the successor to WebKit).

## Details

#### GTK+2

Starting in ACEv8.4, ACE no longer supports GTK+2.

#### GTK+3

For GTK+3 Linux distros (like RHEL/CentOS7 and later, SUSE15 and later, and Ubuntu 20.04LTS and later), with the assistance of a system administrator, install a GTK+3 compatible version of WebKit2GTK (*not* WebKitGTK).

These are expected to be the following package names, all of which are available within the official distribution repositories and are often installed by default.

- (RHEL/CentOS7) a package named "webkitgtk4.x86\_64", which contains WebKit2 compiled for GTK+3
- (RHEL/Rocky8) a package named "webkit2gtk3", which contains WebKit2 compiled for GTK+3
- (SUSE15) a package with a name starting with "libwebkit2gtk-4.0", which contains WebKit2 compiled for GTK+3
- (Ubuntu, all supported versions) a package with a name starting with "libwebkit2gtk-4.0", which contains WebKit2 compiled for GTK+3

#### GTK+4

ACE does not support GTK+4 at this time.

#### When Nothing Else Works

When nothing else works, or when all the available GTK+3 versions of WebKit2 fail to be found or start (due to crashes), one more choice exists. An ancient fallback HTML3 browser is shipped within ACE. This fallback browser appears to be stable on supported Linux distros (while using X11), but it has reduced functionality and performance, renders without antialiasing (the fonts often look ugly), the fonts can be illegible (too small) on HiDPI monitors, it occasionally might not show the entire report on the first try (though scrolling the report or resizing the report usually causes it to fully paint), and it does not directly support the Wayland display server (instead of X11).

ACE automatically tries this fallback browser when it cannot find any compatible embeddable browser within the OS. But if it finds a compatible browser (that subsequently crashes), ACE might not get a chance to automatically try the fallback browser.

It is possible to force the use of the fallback browser, which can get around crashes in the various WebKit and/or GTK frameworks. Start ACE with the appropriate argument to force the use of the fallback browser.

#### Starting ACE while forcing the use of the (reduced functionality) fallback HTML browser

#### ./ace -force\_fallback\_html\_browser

(i) Note

This fallback browser is NOT an ideal solution. It is always a much better idea to work with the local IT/MIS support team to get the latest stable version of WebKit2 and GTK+3 installed and working together on the Linux workstation instead.

#### A Caution!

Do not use both -allow\_wayland and -force\_fallback\_html\_browser at the same time

The fallback html browser is known to have multiple display and mouse interaction errors if you try using both -allow\_wayland and -force\_fallback\_html\_browser at the same time. (ACE defaults to disallowing Wayland rendering in favor of X11 rendering, so the -force\_fallback\_html\_browser argument is expected to work in all cases, as long as -allow\_wayland is not used at the same time.)

# Additional Information

## RHEL/CentOS7

RHEL/CentOS7 includes versions of WebKit2GTK+3 (the package "webkit4.x86\_64") within the official release repositories. These are compatible with ACE when running on RHEL/CentOS7. These packages are often installed by default, and must be installed for full functionality to be available in ACE.

## RHEL8

RHEL8 includes versions of WebKit2GTK+3 (the package "webkit2gtk3.x86\_64") within the official release repositories. These are compatible with ACE when running on RHEL8. These packages are often installed by default, and must be installed for full functionality to be available in ACE.

## WebKit and WebKitGTK Technical Details

There are two main APIs for WebKit development. These are known as WebKit2 (the latest edition), and its predecessor known as WebKit (also sometimes referred to for clarity as WebKit(1) or WebKit[1]). There are many released versions of each, including (confusingly) WebKit(1) version 2.x.y, which is incompatible with WebKit2.

Versions of WebKit and WebKit2 can be compiled to support GTK+2 or GTK+3, and recent versions of WebKit2 may also support GTK+4, which are then all grouped under the WebKitGTK name/prefix in some distros like RHEL7. (Other Linux distributions including RHEL8 have chosen a clearer delineation by using the names WebKitGTK and WebKit2GTK.)

Over time, WebKit for GTK has been made available as a multitude of different package names on Linux, corresponding to the various combinations of support for GTK+2/GTK+3/GTK+4 and WebKit(1)/WebKit2, and recently (on SUSE and Ubuntu) with differing versions of an underlying package called libsoup. The most common known package/library names are listed below for supported versions of Linux. Names which are struck are known to not work with ACE.

- webkitgtk: WebKit(1) compiled for GTK+2 (found in non-official community repositories for RHEL7)
- webkitgtk2: WebKit2 compiled for GTK+2 (only briefly available for RHEL7; this appears to have been a short-lived option during the very early development of WebKit2)
- webkitgtk3: WebKit(1) compiled for GTK+3 (found in the official RHEL7 repositories)
- webkitgtk4: WebKit2 compiled for GTK+3 (found in the official RHEL7 repositories; this is the WebKitGTK package most actively developed/supported for RHEL7/CentOS7)
- webkit2gtk3: WebKit2 compiled for GTK+3 (found in the official RHEL8 and RHEL9 repositories; this is the WebKitGTK package most actively developed/supported for RHEL/Rocky8 and RHEL/Rocky9)
- libwebkit2gtk-4\_0 and libwebkit2gtk-4.0: WebKit2 compiled for GTK+3 using libsoup2 (found in the official SUSE 15 and Ubuntu repositories). This is the preferred version to be used with ACE on these distros.
- libwebkit2gtk-4\_1 and libwebkit2gtk-4.1: WebKit2 compiled for GTK+3 using libsoup3 (found in the official SUSE 15 and Ubuntu 22.04LTS repositories). ACE has not yet been tested with this library.
- libwebkit2gtk-5.0: WebKit2 compiled for GTK+4 (found in the official SUSE 15 repositories)

## **Other Linux Distros**

#### Note

#### For unsupported Linux distros:

Alternate distributions of Linux may use different package naming schemes than those shown above.

The naming standards for WebKitGTK packages targeting GTK+2, GTK+3, GTK+4, WebKit, and WebKit2 are nonobvious, and are thus difficult to understand. It is unfortunately very easy to confuse versions of WebKitGTK(1) v2.x with versions of WebKit2GTK, even though they're incompatible.

A package management tool (like 'yum' on RHEL, 'zypper' on SUSE, or 'apt' on Ubuntu) is the best way to research these versions/dependencies, as well as perform the eventual package installation.

A website that can assist with the navigation of the confusing WebKitGTK names and versions is https://pkgs.org/ download/webkitgtk. At that site, search for "webkit2gtk" in your chosen Linux distribution, find one that works with GTK+3, and then install it with the local package management tool appropriate for your Linux distro.

# Linux: ACE Requires an Unusually Large Amount of Virtual Memory (Due to WebKit2)

In Linux, the Eclipse framework underlying ACE uses the WebKit2GTK+3 HTML browser framework. This framework uses large amounts of virtual memory (sometimes more than 100GB), apparently as part of the browser's javascript security model. At the present time, there appears to be no way for Achronix to ask/force WebKit2 to use less virtual memory in ACE.

# Linux: ACE forces the use of the Adwaita GTK+3 Theme; Can I Change This?

The Eclipse GUI framework underlying ACE only guarantees correct behavior and appearance on GTK+3 when the Adwaita GTK+3 theme is in use. Thus ACE is only officially supported running on the Adwaita GTK+3 theme. Because the Adwaita GTK+3 theme is available by default on all supported Linux distributions, this restriction is not expected to be a problem in most cases.

# Themes

ACE currently always uses the GTK+3 widgets library in Linux, regardless which desktop environment and/or window manager is being used. The GTK+3 widgets support theme customization. Thus the look and feel of ACE can be modified by changing what is called the "application GTK widgets theme/style/appearance" (the exact name varies based on distro/version/desktop) setting in Linux. By default, to ensure accurate rendering and behavior, as well as optimal rendering performance, ACE forces itself to use the Adwaita theme, even if another theme has been explicitly chosen for other GTK+3 applications running on that Linux desktop.

#### Caution!

The default GTK+3 theme "Adwaita" is the only theme supported by ACE.

The Eclipse GUI framework underlying ACE only guarantees correct behavior and appearance in Linux when the Adwaita GTK+3 theme is in use. Thus ACE is also only officially supported in Linux when running on the Adwaita GTK+3 theme. At startup, ACE overrides the user/system GTK+3 theme choice and forces itself to use Adwaita, even if the user has chosen a different theme to be used by all GTK+3 applications. Because Adwaita is the default GTK+3 theme provided by the GTK team themselves, and because Adwaita ships as a part of GTK+3 by default, this restriction is not expected to be a problem for ACE users on Achronix-supported Linux distros.

At this time, the default GTK+3/Gnome theme "Adwaita" is the only supported GTK+3 Theme choice for ACE.

Customers running Linux distributions other than RHEL and/or SUSE (and their respective clones), which all use Adwaita by default, might also have good results with whatever GTK+3 Theme is enabled by default with their distro, but this is only recommended if the preferred Adwaita theme is not available.

When trying alternate themes, Achronix requires that GTK+ v3.22 or later be used with ACE, because those GTK+ versions are reportedly the "final, stable" versions of GTK+3, and are thus the most stable. All releases of GTK+3 prior to v3.22 were considered by the GTK+ team to be (unstable) development releases.

By starting ACE with the command-line argument -keep\_user\_gtk\_theme, ACE stops enforcing the usage of the Adwaita theme, and allows the use of alternate system GTK+3 themes. Be warned that the use of alternate GTK+3 themes can cause illegible foreground/background color combinations, graphical performance issues, drag-and-drop issues, loss of accessibility functionality (like screen readers), and in rare cases can even cause ACE to crash. In all cases that were backtracked to the Themes frameworks, when the user reverted back to allowing ACE to use the (default) Adwaita theme, these problems did not reoccur in ACE.

### Changing the GTK+3 Theme

#### (i) "Dark" themes are not supported in ACE.

At this time, ACE does not support any dark themes. Customers desiring ACE support for dark themes should request "dark theme support" as an ACE feature enhancement so it can be prioritized appropriately.

The exact setting to change the GTK application widgets theme varies by Linux distribution and version, as well as by desktop manager and version.

Under CentOS7 Gnome, for example:

Gnome Tweak Tool  $\rightarrow$  Appearance  $\rightarrow$  Theme  $\rightarrow$  GTK+

Under CentOS7 KDE, for example:

System Settings  $\rightarrow$  Application Appearance  $\rightarrow$  GTK+ Appearance  $\rightarrow$  GTK+ Styles  $\rightarrow$  Widget Style

Under CentOS7 MATE, for example:

System  $\rightarrow$  Preferences  $\rightarrow$  Look and Feel  $\rightarrow$  Appearance  $\rightarrow$  Theme  $\rightarrow$  Customize...  $\rightarrow$  Controls

Consult with your local System Administrator for additional details regarding the configuration of GTK+3 and themes for your local Linux installation.

### Animations and Other Effects

While desktop, application/window, and widget animations can improve the feel of applications for some users, other users want to avoid the negative performance impacts.

Animations and special effects are not managed by ACE itself. Often these are controlled within the Desktop Environment, Compositor, and/or Window Manager (exact locations of these settings vary significantly, with some settings available only through the manual editing of Linux configuration files), and some animations may vary even with the user's choice of GTK Theme.

Under CentOS7 Gnome, for example, animations settings can be found at:

#### Tweak Tool $\rightarrow$ Appearance $\rightarrow$ Enable animations

Under CentOS7 KDE, for example, multiple animation settings can be found at:

#### System Settings $\rightarrow$ Desktop Effects

Consult with your local System Administrator for additional details regarding the configuration of desktop, application, and widget animations and special effects for your local Linux installation.

# Linux: Views and Editors Detach when Dragged Instead of Docking in the Workbench

There is currently a known GTK theme bug (*Linux-only*) in the Eclipse application frameworks underlying ACE that causes view/editor tab docking (including tab re-arrangement) to fail when the Help Window is used. This bug can occur even when the Help Window is minimized; some part of the underlying frameworks is remembering the window size/location despite minimization.

This bug currently appears to be dependent upon which GTK Theme is being used by the Linux window manager. (This theme choice is configured outside ACE.) We have not yet heard any reports of the bug being observed when the system default GTK themes (Adwaita on RHEL/CentOS7 and RHEL8) were in use.

There are three workarounds to allow docking when this bug occurs:

- Close the Help Window while performing the view/editor tab movement operations, and then re-open the Help Window when the movements are completed. (Minimizing the Help Window is not enough. The Help Window must be closed.)
- Shrink and move both the ACE window and the Help Window to a size/location where they do not intersect, then change the view/editor tab locations within the Workbench, then restore the desired Workbench and Help window sizes/locations.
- Work with the local Linux system administrator to change the GTK theme being used, or try to update to a newer/patched version of the chosen GTK theme.
   Same versions of the Clearlocke and Clider themes seem most likely to exhibit the problem.

Some versions of the Clearlooks and Glider themes seem most likely to exhibit the problem.

See the previous section titled Themes (page 784) for more information on choosing an alternative theme in Linux.

# Linux: CDE: Dialogs and Wizards Sometimes Appear Behind the Main ACE Window, Especially After Minimize/Maximize

This problem has only been observed at sites running an X server on RHEL/CentOS and the X client on CDE running within SunOS/Solaris. *This configuration is not officially supported*. (Achronix does not support running ACE where either the X server or the X client are on anything except supported operating systems. See the release notes accompanying ACE to determine the exact supported OS versions for a given ACE release.)

CDE has known inter-window focus issues when displaying GTK applications using the default CDE configuration. This problem is not unique to ACE, nor is it something over which ACE has any control whatsoever.

As an example, IBM tools also experience similar problems. A good description of a fix for the issue is in the IBM support forums at: http://www-1.ibm.com/support/docview.wss?uid=swg21124274.

#### Note

#### Paraphrased workaround from the IBM support forums:

Basically, the problem is caused by an awkward default setting of CDE that allows modal dialogs to be hidden behind other (parent) windows.

To replace this default setting with a more sane one, the following line needs to be added to \$HOME/.Xdefaults:

Dtwm\*secondariesOnTop: True

After that, reload the Xdefaults and restart the window manager. Finally, it might be necessary to also update **CDE Style Manager**  $\rightarrow$  **Windows** where "**Allow Primary windows on top**" should not be enabled (uncheck the checkbox).

If this specific workaround from IBM tech support does not solve the problem in the local CDE configuration, please perform a web search (using similar terminology) with the assistance of a local system administrator to find and apply the fix/workaround for the local Linux window manager configuration.

#### Caution!

Achronix does not support running ACE on any combinations of Solaris/SunOS/CDE. Consult with a local System Administrator before making these or similar changes on SunOS or Solaris or CDE.

# Linux: "Failed to create the part's controls": Some Views and IP Editors may fail to initialize

When this problem occurs, an error message will appear similar to the following screenshot:

| Failed to  |            |
|------------|------------|
| create the | Details >> |
| part's     | Decuns     |
| controls   |            |

The problem has only been observed on older versions of RHEL/CentOS7 (versions prior to RHEL/CentOS7.7), and only with specific Desktop or Window Managers, and only at very high resolutions (when GTK+3 font scaling may become enabled). The error currently appears to be related to bugs in the various graphical library dependencies provided by Linux itself (these are not shipped within ACE).

All customers experiencing the problem have reported that upgrading the version of their preferred Desktop or Window Manager, or changing to another Desktop or Window Manager, or upgrading to newer releases of RHEL/ CentOS7 (versions 7.7 or later) has fixed their problem and allowed all ACE Views and IP Editors to once again work as expected.

# Upgrading an ACE Installation

#### (i) Note

This is also supposed to be covered in the ACE Installation Guide (UG002).

### On Windows

Each version of ACE should ideally be installed into a new, empty directory! Never install ACE in the same directory as a prior install, unless that prior version has already been uninstalled first.

- 1. Disconnect any USB Bitporters.
- 2. (If a node-locked license is being used for ACE:) Copy the license/\*.lic file from the ACE installation directory to another location (somewhere not under the ACE installation directory).
- 3. Optionally, uninstall the prior version of ACE.
- 4. Install the desired version of ACE to a new directory.
- 5. (If a node-locked license is being used for ACE:) Copy the license/\*.lic file back to the proper location within the new ACE installation directory.
- 6. Re-connect any USB Bitporters.
- 7. Run ACE.

### On Linux

Each version of ACE must be installed into a new, empty directory! Never install ACE in the same directory as a prior install.

- 1. Create a new directory to contain the new version of ACE.
- 2. Untar ACE into the new directory.
- 3. Run ACE.

### GUI Problems after Upgrading?

In rare cases after an upgrade, (almost always when a different version of ACE is mistakenly installed on top of an existing prior installation,) ACE GUI errors or crashes might occur, especially in the IP Editors.

If you do not wish to perform an uninstall/reinstall of ACE, the following steps often solve the problem:

- 1. Delete the ".eclipse" subdirectory (the leading '.' is important!) in the your home directory.
  - (Windows:) typically "C:\Users\username\.eclipse\"
  - (Linux:) typically "/home/username/.eclipse/"

#### A Caution!

This subdirectory is hidden in Linux; if unsure what this means or how to find it, please ask your system administrator for help.

2. Try running ACE again

If problems persist:

- 1. Contact Achronix Technical Support, providing the following log files along with a description of the problem encountered:
  - (Windows):
    - i. "C:\Users\username\.achronix\ace\_timestamp.log" where timestamp is year\_month\_day\_hour\_minute\_second. (Typically the crash occurred in the most recent log file.) For example:
       "C:\Users\patsmith\ achronix\ace\_2018\_12\_02\_16\_06\_58\_log"
      - "C:\Users\patsmith\.achronix\ace\_2018\_12\_02\_16\_06\_58.log"
    - ii. "C:\Users\username\.achronix\workspace\_version\framework\.metadata\.log" where version is the version of ACE which is being run, and framework is the Eclipse framework version underlying ACE. For example:

```
"C:\Users\patsmith\.eclipse\workspace_7.1\e46\.metadata\.log"
```

- ∘ (Linux)
  - i. "\home\username\.achronix\ace\_timestamp.log" where timestamp is year\_month\_day\_hour\_minute\_second. (Typically the crash occurred in the most recent log file.) For example:
     "\home\patemith\ achronix\ace\_2018\_12\_02\_16\_06\_58\_log"
    - "\home\patsmith\.achronix\ace\_2018\_12\_02\_16\_06\_58.log"
  - ii. "\home\username\.achronix\workspace\_version\framework\.metadata\.log" where version is the version of ACE which is being run, and framework is the Eclipse framework version underlying ACE. For example:

"\home\patsmith\.eclipse\workspace\_7.1\e46\.metadata\.log"

- 2. Delete the ".achronix" subdirectory (the leading '.' is important!) in your home directory.
- 3. Run ACE

# Chapter 7 : Revision History for ACE

# **Revision History**

| Version | Date        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.0     | 02 Jul 2016 | Initial Speedcore document release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1.0     | 02 Jul 2016 | Initial Speedcore document release.         Additions:         • Added new tasks detailing Automatic Flop Pushing into I/O Pins (page 452) and Working with Virtual I/O (page 460).         • Added the page Filter Properties (page 264) showing all supported filters for the Search Filter Builder Dialog (page 189), and the find (page 638), and filter (page 637) Tcl commands.         • Added new Speedster16t IP Configuration Editor sections         • Added JTAG support for FTDI FT2232H (in addition to Bitporter)         • Added Strict Flow Mode in addition to Evaluation and Normal modes to the Options View (page 100)         • Added new Task content with additional info about Highlighting Objects in the Floorplanner View (page 342), and updated cross-references for Views providing Highlight functionality.                                                                                                        |
| 1.1     | 30 Oct 2016 | <ul> <li>Added the page Detecting Changes to Project Source Files (page 323)</li> <li>Integrated the formerly standalone Incremental Compile Tutorial into this guide, under Using Incremental Compilation (Partitions) (page 404)</li> <li>Updates: <ul> <li>Updated the Options View (page 100) to reflect the latest implementation options.</li> <li>The Clock Domains View (page 21), Clock Regions View (page 25), Partitions View (page 111), and Placement Regions View (page 114) have all been updated to mention support for new actions, and dynamic per-device site type columns</li> <li>Updated the Floorplanner View (page 45) to reflect the device awareness for Labels and Tooltips in the fly-out palette.</li> <li>Split the Tcl Command Reference (page 580) into two sections: SDC Commands (page 580) and ACE Tcl Commands (page 610).</li> </ul> </li> <li>Renamed all occurrences of "SnapShot" to "Snapshot"</li> </ul> |

| Version | Date        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.1     | 30 Oct 2016 | <ul> <li>Removals:</li> <li>In the Critical Path Diagram View (page 34), the Layers choices specific to obsolete fabrics have been removed. Associated screenshots and text were be updated.</li> <li>Obsolete commands were removed from the ACE Tcl Commands. (page 610)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1.2     | 30 Nov 2016 | Additions:         • Concepts (page 6): Added ECC support to the Speedster16t BRAM Configuration Editor and Speedster16t FIFO Configuration Editor.         • Tcl Command Reference (page 580): Added a new Tcl commands category, Interactive Timing Commands. (page 603)         Updates:         • Concepts (page 6):         • In the Floorplanner View (page 45), the choice "IO Port Names" has been readded to the Labels and Tooltips options for eFPGA/Speedcore products.         • Misc flop pushing clarifications in the Options View (page 100) and Automatic Flop Pushing into I/O Pins (page 452) pages.         • Enhanced the description of strict mode error checking on the Flow Mode (page 243) page.         • Tcl Command Reference (page 580): Clarified when the "p:" port name may be used with the set_placement (page 714) Tcl command. |
| 1.2.1   | 23 Dec 2016 | <ul> <li>Updates:</li> <li>Tasks (page 282): <ul> <li>Minor updates for clarity on Automatic Flop Pushing into I/O Pins (page 452).</li> <li>Removed references to obsolete Bitporter and acx_stapl_player Software Release Notes (RN007).</li> </ul> </li> <li>Tcl Command Reference (page 580): <ul> <li>Added details to get_pins (page 587).</li> <li>Corrected error in set_clock_latency (page 591).</li> <li>Add details for the option -cpu_width <int> to write_bitstream (page 720).</int></li> </ul> </li> <li>Concepts (page 6): Removed references to obsolete Bitporter and acx_stapl_player Software Release Notes (RN007).</li> <li>Views (page 16): Added details on the CPU Bus Width option under the Options View. (page 100)</li> </ul>                                                                                                         |

| Version   | Date        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2.0_beta  | 01 Feb 2017 | <ul> <li>Additions:</li> <li>Troubleshooting (page 762): added section about ACE startup errors regarding localhost TCP ports.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2.0_beta2 | 28 Feb 2017 | <ul> <li>Additions: <ul> <li>Concepts (page 6):</li> <li>Added seventeen new Bitstream generation Implementation Options to the Options View (page 100) for Speedcore eFPGAs (two options specific to Speedster FPGAs were hidden).</li> <li>Added new preferences to the Project Management Preference Page (page 217) to disable and/or change the frequency of project source file consistency checks.</li> </ul> </li> <li>Updates: <ul> <li>Tasks (page 282): Updated Automatic Flop Pushing into I/O Pins (page 452): the port attribute syn_useiff should no longer be used.</li> <li>Tcl Command Reference (page 580): <ul> <li>add_project_constraints (page 610) now supports filtering constraints by corner, temperature, and voltage.</li> <li>run_stapl_action (page 790) now supports STAPL variable initialization overrides with the new -defines option.</li> <li>write_bitstream (page 720) now supports configurable bit widths for CPU Mode formatted output files.</li> <li>Updated help text for get_pins (page 587), set_clock_latency (page 591), set_equivalent_pins. (page 711)</li> </ul> </li> </ul></li></ul> |
| 2.0       | 02 May 2017 | <ul> <li>Additions:         <ul> <li>Added details regarding Target Device property to the following IP configuration pages: Speedster16t Shift Register Overview Page, Speedster16t ROM Overview Page, Speedster16t DSP FIR Filter Overview Page, Speedster16t BRAM Overview Page, Speedster16t LRAM Overview Page, Speedster16t LRAM FIFO Overview Page, and Speedster16t FIFO Overview Page</li> <li>Tcl Command Reference (page 580):</li></ul></li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Version | Date        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |             | Additions:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2.5     | 01 Jul 2017 | <ul> <li>Views (page 16): Added new Implementation Options "Move Flip-flop Reset",<br/>"Pad Flop Pushing Clock Type", and "Report all temperature corners" to the<br/>Options View (page 100).</li> </ul>                                                                                                                                                                                                                                                                                               |
|         |             | <ul> <li>Tcl Command Reference (page 580): Added create_boundary_pins (page 620), export_partition (page 636), get_ace_ext_dir (page 642), get_ace_ext_lib (page 642), get_flow_steps (page 647), get_report_sweep_temperature_corners (page 660).</li> </ul>                                                                                                                                                                                                                                           |
| 2.0     | 01001201/   | Updates:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|         |             | <ul> <li>Concepts (page 6): New IP Configuration Dialog (page 180) now prohibits IP<br/>module name collisions with Achronix's reserved module names.</li> </ul>                                                                                                                                                                                                                                                                                                                                        |
|         |             | <ul> <li>Concepts (page 6): The Flow Steps (page 235) page now includes a table of flow<br/>step names and IDs.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                              |
|         |             | <ul> <li>Concepts (page 6): The Speedster16t BRAM Configuration Editor now supports<br/>"Simple Dual Port with Soft ECC".</li> </ul>                                                                                                                                                                                                                                                                                                                                                                    |
|         |             | Additions:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|         |             | <ul> <li>Tcl Command Reference (page 580): Added get_partition_names (page 653),<br/>move_project_netlists (page 670), write_partition_blackbox (page 722),<br/>write_partition_db (page 722).</li> </ul>                                                                                                                                                                                                                                                                                               |
|         |             | Updates:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|         | 24 Sep 2017 | Concepts (page 6):                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2.9     |             | <ul> <li>The Multiprocess Summary Report (page 256) now supports the Timing<br/>Analysis "Report all temperature corners" implementation option, and<br/>shows additional columns of timing data for each reported PVT<br/>combination. Peak memory usage is now reported alongside the<br/>runtimes. Clarity of results is improved in cases where the report contains<br/>a mix of Sign-Off timing data for some implementations and Post-Route<br/>timing data for other implementations.</li> </ul> |
|         |             | <ul> <li>The Snapshot Debugger View (page 141) has been significantly updated to<br/>reflect the latest Snapshot Version 3 enhancements.</li> </ul>                                                                                                                                                                                                                                                                                                                                                     |
|         |             | <ul> <li>Configure JTAG Connection Preference Page (page 193) updated with<br/>details regarding multi-device scan chains.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                   |
|         |             | <ul> <li>Tasks (page 282): The entire section regarding Running the Snapshot         Debugger (page 363) has been updated to reflect the latest Snapshot Version 3             enhancements. These include new features like: Startup Trigger; Edge             Triggering; configurable monitor, trigger, and stimuli widths; Repetitive Trigger             mode; etc. For complete details, see the Snapshot User Guide appropriate to             each Achronix device family.     </li> </ul>      |

| Version | Date        | Description                                                                                                                                                                                                                                                                                       |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |             | Additions:                                                                                                                                                                                                                                                                                        |
|         |             | <ul> <li>Concepts (page 6): Added supplemental information describing Timing Across<br/>All Temperature Corners (page 266)</li> </ul>                                                                                                                                                             |
|         |             | <ul> <li>Tcl Command Reference (page 580): Added new commands:<br/>export_all_partitions (page 636), generate_route_delay_table (page<br/>641), insert_delay (page 666)</li> </ul>                                                                                                                |
|         |             | Updates:                                                                                                                                                                                                                                                                                          |
|         |             | Concepts (page 6):                                                                                                                                                                                                                                                                                |
|         |             | <ul> <li>On the Configure JTAG Connection Preference Page (page 193), corrected<br/>misleading information regarding multi-device scan chains, and removed<br/>now-obsolete configuration settings (for pod type and connection type).</li> </ul>                                                 |
|         |             | <ul> <li>Removed now-obsolete information from the Options View (page 100)<br/>regarding JTAG configuration settings.</li> </ul>                                                                                                                                                                  |
|         |             | <ul> <li>In the Flow View (page 55), added the Warning icon to the icons table. The<br/>icon is primarily used to indicate out-of-sync files, as described in<br/>Detecting Changes to Project Source Files (page 323).</li> </ul>                                                                |
|         |             | Tasks (page 282):                                                                                                                                                                                                                                                                                 |
| 2.10    | 24 Dec 2017 | <ul> <li>The Configuring the JTAG Connection (page 359) page was updated to<br/>further clarify details regarding multi-device scan chains, and to remove<br/>mention of now-obsolete configuration settings (for pod type and<br/>connection type).</li> </ul>                                   |
|         |             | <ul> <li>The Generating Timing Reports (page 352) page was updated with<br/>additional information about multiple temperature corners and related Tcl<br/>commands.</li> </ul>                                                                                                                    |
|         |             | <ul> <li>The Running Multiple Flows in Parallel (page 307) page was updated to<br/>clarify why external job submission systems must use synchronous/<br/>blocking commands, and why asynchronous/non-blocking commands can<br/>potentially cause serious problems.</li> </ul>                     |
|         |             | <ul> <li>The Single-Process Incremental Compile Tutorial (page 408) was updated<br/>for clarity</li> </ul>                                                                                                                                                                                        |
|         |             | • The Snapshot Design Flow (page 364) received an updated diagram                                                                                                                                                                                                                                 |
|         |             | <ul> <li>Tcl Command Reference (page 580): Updated create_boundary_pins (page 620),<br/>create_flow_step (page 621), export_partition (page 636),<br/>run_fpga_download (page 691), save_properties (page 708),<br/>write_partition_blackbox (page 722), write_partition_db (page 722)</li> </ul> |
|         |             | • Troubleshooting (page 762): enhanced information regarding ACE error codes                                                                                                                                                                                                                      |

| Version | Date        | Description                                                                                                                                                                                                                                                                 |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |             | Additions:                                                                                                                                                                                                                                                                  |
|         |             | Concepts (page 6):                                                                                                                                                                                                                                                          |
|         |             | <ul> <li>Added new page describing various supported ACE Verilog Attributes (page 259) that can be applied to instances, nets, pin, ports, or other objects in the ACE datamodel.</li> </ul>                                                                                |
|         |             | <ul> <li>Described the new Properties View (page 127)</li> </ul>                                                                                                                                                                                                            |
|         |             | <ul> <li>Added a description of the Implementation Options Report (page 258)</li> </ul>                                                                                                                                                                                     |
|         |             | Tasks (page 282)                                                                                                                                                                                                                                                            |
|         |             | <ul> <li>Added content regarding Applying and Checking Properties (page 356)</li> </ul>                                                                                                                                                                                     |
|         |             | Tcl Command Reference (page 580):                                                                                                                                                                                                                                           |
|         |             | <ul> <li>Added new Tcl commands get_clock_regions (page 644),<br/>get_clock_region_bounds (page 644), get_file_line (page 647),<br/>get_regions (page 660), get_region_bounds (page 659), report_coverage (page<br/>679)</li> </ul>                                         |
|         |             | <ul> <li>Added new Interactive Timing Commands (page 603) pages for<br/>check_timing and report_clock. Reminder: these are stand-alone timer<br/>commands, enabled only after prepare_sta (page 605) is run, and disabled<br/>after reset_sta (page 609) is run.</li> </ul> |
| 3.0     | 19 Aug 2018 | Updates:                                                                                                                                                                                                                                                                    |
|         |             | Concepts (page 6):                                                                                                                                                                                                                                                          |
|         |             | <ul> <li>The JTAG Browser View was updated to include a new "Word Step" field.</li> </ul>                                                                                                                                                                                   |
|         |             | <ul> <li>Corrected the Critical Path Diagram View (page 34) to reflect the removal of<br/>the now-obsolete Layers section of the palette</li> </ul>                                                                                                                         |
|         |             | <ul> <li>The configuration of the Floorplanner View (page 45)'s Route Rendering<br/>Mode has been moved from the view's fly-out palette to the Floorplanner<br/>View Colors and Layers Preference Page (page 198)</li> </ul>                                                |
|         |             | <ul> <li>Clarified how the 1 icon in the Flow View (page 55) relates to Detecting<br/>Changes to Project Source Files (page 323)</li> </ul>                                                                                                                                 |
|         |             | <ul> <li>Documented the new ease-of-use feature/button (         Multiprocess View (page 75) allowing users to re-open a pre-existing     </li> <li>Multiprocess Summary Report (page 256).</li> </ul>                                                                      |
|         |             | <ul> <li>For the Options View (page 100), updated the listings of common options,<br/>and improved the content describing the Tcl interactions for viewing/<br/>changing implementation options in general</li> </ul>                                                       |
|         |             | <ul> <li>Improved the description of the Power Dissipation Report (page 246),<br/>including clarification of the ramifications of Timing Across All<br/>Temperature Corners (page 266)</li> </ul>                                                                           |

| Version | Date        | Description                                                                                                                                                                                                                                                                                                               |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |             | Updates (cont.):                                                                                                                                                                                                                                                                                                          |
|         |             | <ul> <li>The Projects View (page 120) gained a new action: Reload Project ( ); added a<br/>screenshot and description showing how disabled constraints will be greyed out<br/>in this view; clarified details regarding the load order of constraint files.</li> </ul>                                                    |
|         |             | Tasks (page 282):                                                                                                                                                                                                                                                                                                         |
|         |             | <ul> <li>Clarified details regarding Adding Source Files (page 296) to ACE projects,<br/>how the source file load order may be changed, and the ways in which<br/>constraint files may be enabled/disabled (instead of added/removed) for<br/>implementations</li> </ul>                                                  |
|         |             | <ul> <li>Mentioned that it is also possible to disable constraint files in<br/>implementations, instead of completely Removing Source Files (page 300)<br/>from projects</li> </ul>                                                                                                                                       |
|         |             | <ul> <li>Enhanced the instructions for Assigning Placement Region<br/>Constraints (page 398)</li> </ul>                                                                                                                                                                                                                   |
| 3.0     | 19 Aug 2018 | <ul> <li>Renamed the section 'Getting Floorplanner Object Tooltips' to Choosing<br/>Floorplanner Object Tooltips (page 341) for clarity</li> </ul>                                                                                                                                                                        |
|         |             | <ul> <li>Enhanced the descriptions of Loading Projects (page 294) to cover both GUI<br/>and Tcl interactions, with new explanations of project locking and lock files.</li> </ul>                                                                                                                                         |
|         |             | <ul> <li>Added more thorough discussion of the license ramifications of Running<br/>Multiple Flows in Parallel (page 307), and added a cautionary note describing<br/>how multiple implementations can unexpectedly generate identical results<br/>after upgrading ACE, along with the recommended fix.</li> </ul>        |
|         |             | Tcl Command Reference (page 580):                                                                                                                                                                                                                                                                                         |
|         |             | <ul> <li>Updated report_timing with newly supported command line options.</li> </ul>                                                                                                                                                                                                                                      |
|         |             | <ul> <li>Renamed 'display_rtl' to display_netlist (page 628) which will better<br/>reflect the command's actual functionality</li> </ul>                                                                                                                                                                                  |
|         |             | • <b>Troubleshooting</b> (page 762): updated discussion of project locking and when forcing locked projects to load is acceptable; updated descriptions of font management; updated content for ACE startup error diagnosis (firewall vs license issues); added new content regarding missing icons for actions in menus. |

| Version | Date        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |             | ACE v7.0 is the first combined release, supporting both Speedster FPGA devices<br>and Speedcore eFPGA devices. Rather than parallel releases, there is now a single<br>release, thus the change in numbering schemes (to be more in sync with the<br>higher-versioned Speedster software, which was in the 6.x release sequence).                                                                                                                                                                                                                                                                                                                                               |
|         |             | Additions:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|         |             | <ul> <li>Tasks (page 282): added several pages describing the ACE help system:<br/>Accessing Help (page 468); added a new page about Detaching Views and<br/>Editors (page 288); added a new page describing Multiprocess Batch Mode (page<br/>317) (using the new run_multiprocess (page 693) Tcl command), including the<br/>new seed sweep functionality</li> </ul>                                                                                                                                                                                                                                                                                                          |
|         |             | <ul> <li>ACE Tcl Commands (page 610): added new command run_multiprocess (page 693)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7.0     | 07 Dec 2018 | • <b>Troubleshooting</b> (page 762):added a section regarding changing Linux GTK theme and animation settings to affect the render performance as well as the look and feel of the ACE GUI; added a section describing the known (GTK theme-dependent) bug where views/editors may detach (instead of move) while the Help Window is open;added a section about the impacts of Linux resource limits;added a section about the twm Window Manager in Linux;added a section regarding Linux LD_LIBRARY_PATH concerns;added a section about dialogs in the CDE Window Manager                                                                                                     |
|         |             | Updates:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|         |             | <ul> <li>Concepts (page 6):The Floorplanner View (page 45) has changed the presentation of routing errors (open connections, open pins, and route overflows); the Critical Path Diagram View (page 34) now has right-click context menu items similar to the other views within the Floorplanner Perspective; the Options View (page 100) section was updated to match the latest lists of options, but now includes only those options which are common to all target devices – implementation options which are unique to specific libraries or devices will now be documented elsewhere, including within the on-demand Implementation Options Report (page 258).</li> </ul> |
|         |             | • Tasks (page 282):The Moving and Docking Views and Editors (page 287) page<br>and Rearranging Tabbed Views and Editors (page 288) page have been re-titled<br>and have had their content updated to reflect that Editors can now be moved<br>around just like Views. The user feedback has changed during movement and<br>docking, and the descriptions/tables have been updated accordingly.                                                                                                                                                                                                                                                                                  |

| Version | Date        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7.0     | 07 Dec 2018 | <ul> <li>Updates (cont.):</li> <li>ACE Tcl Commands (page 610):added "-verbose" option to:<br/>add_region_find_insts (page 613), add_region_insts (page 614),<br/>create_region (page 624), and remove_region_insts (page 677); find (page 638)<br/>added "-warning" and "-error" options; run_generate_fullchip_sim (page 692)<br/>added "-modelsdir" option; set_false_path (page 596) has improved description<br/>of various options; add_region_find_insts (page 613), add_region_insts (page<br/>614), create_region (page 624), and remove_region_insts (page 677) added a new<br/>"-clocks_only" option; remove_region_insts (page 677) added a new "-<br/>flops_only" option; run_insert_holdbuffers (page 693) added a new option "-<br/>io_buffers".</li> <li>Troubleshooting: (page 762) the Linux web browser section has been updated to<br/>reflect the change from the Mozilla XulRunner to the WebKitGTK+ HTML<br/>browser framework</li> <li>Removals:</li> <li>Deleted Concepts and Tasks pages made obsolete by the updated GUI<br/>frameworks: "Fast Views", "Opening Perspectives"</li> </ul> |
| 7.1     | 27 Mar 2019 | <ul> <li>Additions: <ul> <li>Advanced Concepts (page 259): added a new page describing ECO Commands (page 268)</li> </ul> </li> <li>Updates: <ul> <li>Reports (page 244): updated information on the Implementation Options Report (page 258) page to improve clarity and accuracy</li> <li>Views (page 16): added info to the Properties View (page 127) page covering double-click shortcut gestures and context-menu actions; updated the table of Actions to match the latest functionality on the Projects View (page 120) page</li> <li>Tasks (page 282): updated content on the Multiprocess Batch Mode (page 317) page for improved clarity</li> <li>Troubleshooting (page 762): removed obsolete content and updated content for new potential problems and workarounds, now that ACE has added official support for GTK3 and WebKit2 (both new as of this release, see new content for technical details)</li> </ul> </li> </ul>                                                                                                                                                                          |

| Version | Date        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7.2     | 06 Jun 2019 | <ul> <li>Updates:</li> <li>Tcl Command Reference (page 580): Updated the descriptions for all SDC Commands (page 580), and provided/updated usage examples where applicable. To avoid command naming collisions with other tools, updated the names and descriptions for the Interactive Timing Commands (page 603).</li> <li>Views (page 16): updated the Netlist Browser view (page 81) actions table, adding missing actions and updating icons that have changed; updated the Floorplanner View (page 45) to mention the new Allow Tooltips toggle checkbox; updated the Critical Paths View (page 39) to mention the new Show Clock Paths action; updated the Multiprocess view (page 75) page, updating the screen shot and the text to include the new Seed Sweep functionality; updated the Flow View (page 55) page, updating the screen shot and icon images to match recent updates.</li> <li>Advanced Concepts (page 259): updated the ECO Commands (page 268) section, moving each related dialog into its own page and updating screen shots</li> <li>Troubleshooting (page 762): updated the section about Themes to explain that ACE will now enforce the usage of the Adwaita theme when running on</li> </ul> |
| 8.0     | 17 Sep 2019 | <ul> <li>GTK3.14+ (to maximize performance and stability).</li> <li>Additions: <ul> <li>Concepts (page 6): added pages for the new I/O Designer Toolkit Views (page 62) and Generate I/O Ring Design Files Dialog (page 175).</li> <li>ACE Tcl Commands (page 610): added new command: generate_soc_design_files (renamed generate_ip_design_files (page 641) in the 8.1 release).</li> </ul> </li> <li>Updates: <ul> <li>Concepts: The Projects View (page 120) page removed the obsolete Remove All Projects action and added the new actions to Clone IP and Rename IP.</li> <li>Tasks (page 282): The Single-Process Incremental Compile Tutorial (page 408) content has had its formatting tweaked.</li> <li>ACE Tcl Commands (page 610): The interactive timing command report_checks (page 606) removed the unsupported argument "-input_pins". The interactive timing command reset_sta (page 609) had a typo in the examples.</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                   |

| Version | Date        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8.1     | 24 Jan 2020 | <ul> <li>Additions:</li> <li>Concepts (page 6): What was previously a single I/O Designer View (with multiple inner tabs) has now been split into multiple independent-but-related views, grouped under the I/O Designer Toolkit Views (page 62) page. The new pages are for the I/O Core Pin Assignment View (page 66), I/O Layout Diagram View (page 68), I/O Package Diagram View (page 65), I/O Pin Assignment View (page 66), and I/O Utilization View (page 65), I/O Pin Assignment View (page 66), and I/O Utilization View (page 64). (As a reminder, these I/O Designer Toolkit views are only relevant for Achronix Speedster7t FPGAs such as the AC7t1500.)</li> <li>Troubleshooting (page 762): Added a section dealing with the most common symptom of improperly installed device overlays: Unable to initialize reserved module names list.</li> <li>Updates:</li> <li>Concepts (page 6): updated I/O Designer Toolkit Views (page 62) page with info about cloning and double-clicking.</li> <li>ACE Tcl Commands (page 610): The command generate_soc_design_files was renamed generate_ip_design_files (page 641). The command run_unroute (page 705) has gained arguments to deal with regions.</li> </ul> |
| 8.1.1   | 21 Feb 2020 | <ul> <li>Updates:</li> <li>ACE Tcl Commands (page 610): The command run_insert_holdbuffers (page 693) was updated to support a new optional argument: "-typebased_buffers".</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| Version | Date        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |             | Additions:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|         |             | <ul> <li>Concepts (page 6): Added info about 'Add [copies of] IP to another project' to<br/>Projects View (page 120). Added info about "active editor highlighting" to I/O<br/>Layout Diagram View (page 68). Added info about 'Remap Port/Signal Name' to<br/>I/O Pin Assignment View (page 66), I/O Core Pin Assignment View (page 66).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                |
|         |             | <ul> <li>ACE Tcl Commands (page 610): added new commands: get_fanout (page 790),<br/>run_multiprocess_iterator (page 696)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|         |             | Updates:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 8.2     | 17 Jul 2020 | <ul> <li>ACE Tcl Commands (page 610): the run_multiprocess (page 693) command has a<br/>new flag -create_option_sets; the save_placement (page 707) command<br/>can now save placement of just a subset of the design, using the new option<br/>-instances; the run_insert_holdbuffers (page 693) command has a new<br/>option -typebased_buffers.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                       |
|         |             | <ul> <li>Concepts (page 6): The Multiprocess Summary Report (page 256) is now automatically sorted by quality of results, instead of alphabetically. The Multiprocess View (page 75) (and run_multiprocess (page 693)) can now optionally generate customized option sets for any chosen template implementation. The Netlist Browser View (page 81) now has convenience filters to hide instances of the cell types of boundary pins, power, and ground. The Save Placement Dialog (page 185) can now optionally accept Tcl lists (or Tcl statement that generate lists) of Instance names whose placements shall be saved, and can be pre-populated from the Search View (page 133) and the Selection View (page 137).</li> </ul> |
|         |             | <ul> <li>Tasks (page 282): The Single-Process Incremental Compile Tutorial (page 408) has<br/>been updated to improve phrasing/clarity.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Version | Date        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |             | Additions:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|         |             | <ul> <li>Concepts (page 6): created a page for the new Create a SecureShare Zip File<br/>Dialog (page 164)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|         |             | <ul> <li>Tasks (page 282): created a page for Using the ACE SecureShare Tool to Create<br/>a Support Zip File (page 471)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|         |             | <ul> <li>ACE Tcl Commands (page 610): added get_best_multiprocess_impl (page 644),<br/>report_performance (page 682),</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|         |             | Updates:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 8.3     | 16 Dec 2020 | <ul> <li>Concepts (page 6): The old "global" option sets have been removed in favor of<br/>the improved custom-generated option sets based on design analysis; the<br/>Multiprocess View (page 75) and Active Project and Implementation (page 231)<br/>pages have been updated accordingly. Added more details about Log<br/>Files (page 233) generated during Multiprocess.</li> </ul>                                                                                                                                                                                                                                                                 |
|         |             | <ul> <li>Tasks (page 282): Misc clarifications for Multiprocess Batch Mode (page 317),<br/>option set updates for the Attempting Likely Optimizations Using Option<br/>Sets (page 392).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|         |             | <ul> <li>ACE Tcl Commands (page 610): remove_impl (page 674) now supports working on<br/>a list of impls instead of just a single impl; clarified help text for<br/>run_multiprocess (page 693) and run_multiprocess_iterator (page 696);</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                     |
|         |             | Additions:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|         |             | <ul> <li>Concepts (page 6): added a page to describe the new NoC Performance<br/>View (page 89)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|         |             | ACE Tcl Commands (page 610): added new commands:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|         | 11 Mar 2021 | get_compatible_placements (page 645), move_partition ,<br>process_move_partition , redirect (page 672)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|         |             | Updates:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|         |             | <ul> <li>Concepts (page 6): Under ACE Verilog Attributes (page 259), renamed</li> <li>"ace_useioff" to "syn_useioff"; on the Perspectives (page 6) page described the new NoC Performance Perspective;</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 8.3.2   |             | • Tasks (page 282): The Automatic Flop Pushing into I/O Pins (page 452) page was updated to use the latest Verilog attributes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|         |             | <ul> <li>ACE Tcl Commands (page 610): renamed "report_regions" to<br/>report_clock_regions (page 678), the add_project_ip (page 611) and<br/>remove_project_ip (page 675) commands now require Tcl lists of acxip<br/>filenames to improve behavior with paths containing spaces;<br/>apply_placement (page 615) and set_placement (page 714) now accept partition<br/>names (to be used in combination with move_partition-); the<br/>report_checks (page 606) command now supports a new option "-<br/>unconstrained"; report_impl_options (page 680) now supports new arguments<br/>"-hide_values", "-show_standard", and "-diff_options";</li> </ul> |

| Version | Date        | Description                                                                                                                                                                                                                                                    |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |             | Additions:                                                                                                                                                                                                                                                     |
|         |             | <ul> <li>ACE Tcl Commands (page 610): Added new<br/>commands create_equivalent_regions (page 620),<br/>remove_project_constraints_pvt (page 675), and untar (page 719).</li> </ul>                                                                             |
|         |             | Concepts (page 6): Added a new Advanced Concept description for Fabric<br>Clusters (page 281).                                                                                                                                                                 |
|         |             | Updates:                                                                                                                                                                                                                                                       |
|         |             | <ul> <li>SmartSupport<sup>™</sup> has been renamed SecureShare<sup>™</sup>, affecting several pages.</li> </ul>                                                                                                                                                |
|         |             | • The Create Placement Region Dialog (page 171) concept and Creating a New Placement Region (page 395) task have been updated to reflect new functionality, allowing (not just instance placement, but also) routing to be restricted to the placement region. |
|         |             | Concepts (page 6): The NoC Performance View (page 89) now supports drag-<br>scrolling.                                                                                                                                                                         |
|         |             | ACE Tcl Commands (page 610):                                                                                                                                                                                                                                   |
| 8.5     | 03 Aug 2021 | <ul> <li>The get_property (page 658) command has been updated with a new "-<br/>object_type" argument.</li> </ul>                                                                                                                                              |
|         |             | <ul> <li>The message (page 668) command now allows console logging support to<br/>be toggled on and off.</li> </ul>                                                                                                                                            |
|         |             | <ul> <li>The report_checks (page 606) command now warns that the report<br/>generated by this command may include less information than the regular<br/>Timing Report.</li> </ul>                                                                              |
|         |             | • The restore_project (page 689) description has been updated for clarity.                                                                                                                                                                                     |
|         |             | <ul> <li>The set_clock_type (page 710) command now supports a new "-batch"<br/>argument.</li> </ul>                                                                                                                                                            |
|         |             | <ul> <li>The set_partition_info (page 713) command arguments and descriptions<br/>have been updated for clarity.</li> </ul>                                                                                                                                    |
|         |             | <ul> <li>The write_bitstream (page 720) command has new arguments "-max_size"<br/>and "-two_stage".</li> </ul>                                                                                                                                                 |
|         |             | • <b>Troubleshooting</b> (page 762): Commentary regarding now-obsolete/unsupported Windows7 and CentOS6 (along with the associated GTK2 details) have been removed.                                                                                            |

| Version | Date        | Description                                                                                                                                                                                                                                                                                                                                       |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |             | Additions:                                                                                                                                                                                                                                                                                                                                        |
|         |             | <ul> <li>ACE Tcl Commands (page 610): added new commands optimize_tile (page 671) ,<br/>regenerate_all_ip_design_files (page 672)</li> </ul>                                                                                                                                                                                                      |
|         |             | Updates:                                                                                                                                                                                                                                                                                                                                          |
|         | 20 Oct 2021 | <ul> <li>Lots of pages throughout the document have been updated with very minor<br/>edits to improve grammar and clarity of phrasing, as well as fixing typos.</li> </ul>                                                                                                                                                                        |
|         |             | <ul> <li>Concepts (page 6): The Views (page 16) page has been updated to note that the<br/>view context menu icon used by all Views has changed from a tiny down-arrow<br/>to a vertical elipsis – (most View screenshots have not yet been updated to<br/>reflect this icon change).</li> </ul>                                                  |
| 8.6     |             | <ul> <li>ACE Tcl Commands (page 610): The set_partition_info (page 713) command<br/>gained a new argument -exclusive_placement. The set_placement (page 714)<br/>command gained a new argument -auto_place_neighbors. The<br/>run_secureshare (page 699) command removed the argument -no_archive and<br/>gained the argument -wizard.</li> </ul> |
|         |             | Deletions:                                                                                                                                                                                                                                                                                                                                        |
|         |             | <ul> <li>Removed remaining content regarding the (no longer supported) 22i and 16t IP<br/>Configuration Editors.</li> </ul>                                                                                                                                                                                                                       |
|         |             | <ul> <li>Removed remaining content regarding the (no longer supported) JTAG<br/>Browser View and JTAG Diagram View.</li> </ul>                                                                                                                                                                                                                    |

| Version | Date        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |             | <ul> <li>Additions:</li> <li>A new Clusters View (page 30) has been added to the Floorplanner Perspective.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|         |             | Updates:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|         | 25 May 2022 | <ul> <li>Concepts (page 6): The Properties View (page 127) has gained an action/dialog to<br/>Save Changed Properties. The Create Placement Region Dialog (page 171) has<br/>been updated with new groupings for the available Region Alignments and<br/>Region Types, with new options for each. The Floorplanner View (page 45) can<br/>now show Cluster information in the tooltips. The NoC Performance View (page<br/>89) now includes tooltip information reporting the comparative "blocked" and<br/>"transferred" percentages for the "trying" times, and includes a brief table<br/>describing the Preferences for this view.</li> </ul> |
| 8.7     |             | <ul> <li>Tasks (page 282): The Creating a New Placement Region (page 395) page has been<br/>updated to show the latest Region Alignment (-snap) and Region Type (-type)<br/>choices for the associated dialog.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                         |
|         |             | ACE Tcl Commands (page 610):                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|         |             | <ul> <li>The create_region (page 624) command has been updated with new options         -snap [none tiles fabric_clusters clock_regions] and         -type [inclusive keepout soft]. The former -snap_to* and         -soft options are now deprecated.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                |
|         |             | $\circ$ The highlight (page 665) command has added a new option -clear.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|         |             | <ul> <li>The set_region_bounds (page 716) command has been updated with new<br/>options - snap [none tiles fabric_clusters <br/>clock_regions] and -type [inclusive keepout soft].</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| Version | Date        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |             | Additions:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|         |             | <ul> <li>Concepts: Added a page for the new Load Acxdb Dialog (page 178). Added a page<br/>for the new NoC Time Slice View (page 97). Added a page for the new Plot<br/>SerDes Diagram Dialog (page 181). Added a page for the Configure Clock Pre-<br/>Routes Dialog (page 159).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                         |
|         |             | <ul> <li>Tasks: Added a new page for Cleaning Projects (page 303) under Working with<br/>Projects and Implementations (page 293). Added a new page for Plotting SerDes<br/>Receiver Diagrams Using JTAG (page 476)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|         |             | <ul> <li>ACE Tcl Commands: added new commands add_clock_preroute (page 610),<br/>remove_clock_preroute (page 673), save_clock_preroute (page<br/>705), clean_project (page 616), get_compatible_ordering_codes (page 644),<br/>get_pvt_corners (page 659), is_labmode (page 667), set_region_type (page 717)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                              |
|         |             | <ul> <li>Note: Early access support for Partial Reconfiguration has been added,<br/>relevant documentation will be included in a future release.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|         |             | Updates:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 8.8     | 18 Jul 2022 | <ul> <li>Concepts: The Netlist Browser View (page 81) has three new boolean toggle filters for the Instance Names column for Constants, Duplicates/Clones, and Feedthroughs. The Clock Regions View (page 25), Clusters View (page 30), Partitions View (page 111), and Placement Regions View (page 114) now display and allow configuration of Clock Pre-Route information when relevant. The NoC Performance View (page 89) page was updated with the latest changes to the related preferences. The Floorplanner View Colors and Layers Preference Page (page 198) was updated to reflect the Always Show Highlighted Instances option, as well as the latest locations/names of several preferences.</li> </ul> |
|         |             | <ul> <li>Tasks: Updated the Running ACE (page 282) page to reflect the changes to Lab<br/>Mode functionality (lab mode now allows a restricted subset of Tcl<br/>functionality, specifically the commands necessary for JTAG operations).<br/>Added a section describing ACE Startup Arguments to the Running ACE (page<br/>282) page. Updated Running the Entire Flow (page 305) to mention the new Load<br/>Acxdb Dialog (page 178) which can appear when a run is canceled.</li> </ul>                                                                                                                                                                                                                            |
|         |             | <ul> <li>Troubleshooting: Added a new section describing a "Failed to create the part's<br/>controls" error message, along with a workaround. Added a new section about<br/>font and image scaling (for high resolution/DPI monitors) in Windows.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|         |             | <ul> <li>ACE Tcl Commands: The create_region (page 624) command has a new -<br/>pr_zone argument to designate partial reconfiguration zones. The<br/>get_regions (page 660) commands has a new -verbose argument to print region<br/>information. The load_flowscripts (page 667) command has a new -bitstream<br/>argument to load only those scripts relevant to bitstream manipulations. The<br/>move_partition command's arguments have changed.</li> </ul>                                                                                                                                                                                                                                                      |

| Version | Date        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8.8     | 18 Jul 2022 | <ul> <li>Deletions:</li> <li>ACE Tcl Commands: The obsolete process_move_partition command has been removed; use set_placement (page 714) -partition instead.</li> <li>Minor enhancements to document style added throughout.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 9.0     | 10 Feb 2023 | <ul> <li>Additions: <ul> <li>Tasks: Added new section for the Partial Reconfiguration Tutorial (page 479)(s)</li> <li>ACE Tcl Commands: Added new commands get_synprj_from_project (page 62), move_relative_paths (page 671), run_generate_final_reports (page 692), save_partition_placements (page 706)</li> </ul> </li> <li>Updates: <ul> <li>Concepts: On the Flow Steps (page 235) page, added the new flow step named 'Generate Final Reports'. Updated Design Completion Steps (page 241) page to add description for the new flow step 'Generate Final Reports'. Updated Clock Domains View (page 21), Clock Regions View (page 134) with refreshed screenshots and descriptions for the new functionality to support Partial Reconfiguration. Updated the Save Placement Dialog (page 185) page to reflect the latest options.</li> <li>Tasks: Updated the Multiprocess task page Running Multiple Flows in Parallel (page 307) to mention node-locked license management; the page previously only mentioned floating license concerns.</li> <li>ACE Tcl Commands: add_clock_preroute (page 610) has a new argument -data_region; add_project_netlist (page 620) has a new argument -impl; create_boundary_pins (page 620) has a new argument -impl; create_boundary_pins (page 620) has a new argument -syn; the help content for report_checks (page 600) has been tweaked to improve clarity; report_power (page 684) now has added support for saif files; report_routing (page 684) has a new argument -wl; source_encrypted (page 717) has a new argument -ullar; write_bitstream (page 720) has a new argument -pcie; write_partition_db (page 722) has a new argument -include_pr_zone;</li> </ul> </li> <li>Throughout the document, hyperlinks that point outside the document have been updated to static text to prevent outside content from appearing in the GUI help. Throughout the document, content has been removed; use set_placement (page 714) -partition instead.</li> </ul> |

| Version        | Date                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Version<br>9.1 | Date<br>26 Apr 2023 | Description         Additions:         • Concepts: Created a new page describing the Project concept of Port Mapping<br>Files (page 230) (as used in IO Designer). Created info covering the new I/O<br>Designer Preference Page (page 207), new Netlist Browser Preference<br>Page (page 211), and new NoC Performance View Preference Page (page 212).         • ACE Tcl Commands (page 610): Added new command<br>remap_partial_bitstream (page 672)         Updates:         • Concepts: Updated the Save Placement Dialog (page 185) page to reflect the<br>latest options. Updated the Configure Clock Pre-Routes Dialog (page 159) to<br>reflect the latest functionality. |
| 0.1            |                     | <ul> <li>Troubleshooting (page 762): Removed info related to obsolete versions of Windows. Updated Linux usage directions for the fallback html browser (to improve functionality under Wayland). Updated Windows info related to upgrading ACE and multiple parallel installs of ACE.</li> <li>ACE Tcl Commands (page 610): Updated the arguments for run_timing_analysis (page 703); Clarified the usage description of set_partition_force_changed (page 712).</li> <li>Throughout the document, content has been edited to improve clarity and consistency.</li> </ul>                                                                                                        |

| Version | Date        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |             | <ul> <li>Additions:</li> <li>Concepts: Created a page describing the Create a New Flow Step dialog (page 163). Created a page describing the new Register Browser View (page 131).</li> <li>Tasks: Created a new page Viewing the Captured VCD Waveform (page 377) to better describe the uses of the VCD Waveform Editor (page 11). Created a new page describing the creation (and removal) of Custom Flow Steps (page 329).</li> <li>Updates:</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 9.2     | 27 Oct 2023 | <ul> <li>Concepts: Updated the Download View (page 43) page to reflect the changes that occurred as the bitstream files migrate from STAPL *. j am files to simpler *.hex files: the lists of procedures and actions are no longer relevant. Updated the Configure JTAG Connection Preference Page (page 193) to remove mentions of the obsolete Bitporter pod, now mentioning the newer Bitporter2 pod and FTDI FT2232H/FT4232H connectivity options. Updated Save Placement Dialog (page 185) page to reflect the latest options, and to ensure the field names in the dialog are consistent with the arguments for the Tcl command save_placement (page 707). Updated the VCD Waveform Editor (page 11) page with the new actions to copy signal name or value to the clipboard, as well as mentioning all the new waveform color and font preferences, with an updated screenshot showing the current default colors and the new signal row highlight color, as well as a new screenshot example showing users how to achieve a green-on-black color configuration (similar to a traditional oscilloscope) using the new per-flow-step error count tracking and filtered error message dialog. Updated the Projects View (page 120) page to include the new context menu actions for report grouping and filtering. Updated the Project Management Preference Page (page 217) with a new screenshot and descriptions of each available setting. Floorplanner View (page 45) was updated with a new dedicated Panning Tool, a quick toggle between placement/panning modes, and automatic panning during drag-and-drop operation. Floorplanner View Colors and Layers Preference Page (page 68) now mentions the support for double-click and drag-and-drop operations. The list of supported filters (used in the find (page 638) and filter (page 637) Tcl commands, and in the Search View (page 133)) has been updated on the Filter Properties (page 264) page.</li> </ul> |

| Version | Date       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9.2 2   | 7 Oct 2023 | <ul> <li>Updates (cont.):</li> <li>Tasks: Updated the Programming a Device using JTAG in the Download<br/>View (page 389) page and child pages (Selecting a Bitstream File (page 390),<br/>Selecting Bitstream Programming Options (page 391), and Downloading the<br/>Bitstream to the Target Device (page 391) to reflect the changes/simplifications<br/>to the Download view's functionality as part of the migration from<br/>STAPL * . j am files to * . hex files. Updated the Configuring the JTAG<br/>Connection (page 359) page now that STAPL files, the acx_stapl_player, and<br/>the classic Bitporter(1) pod are deprecated, mentioning the replacements<br/>instead where relevant. Updated the Snapshot-related Collecting Samples of<br/>the User Design (page 375) page to mention the need for JTAG preferences to be<br/>pre-configured before use, and to reflect the migration from using STAPL to the<br/>new Tcl jtag:: libraries, and the related impact to manual connection<br/>management. Floorplanner Panning (page 339) was updated to mention the new<br/>Pan/Place toggle behavior, the new dedicated Panning Tool, and the new<br/>support for panning during drag-and-drop. The Running ACE (page 282) page now<br/>describes how to use the optional ACE_INIT_SCRIPT functionality.</li> <li>Tcl Command Reference (page 580): The display_file (page 627) command now<br/>supports an optional -search argument -noimpl. The logging command<br/>message (page 668) supports a new argument -noimpl. The logging rommand<br/>message (page 668) supports a new argument -noimpl. The logging command<br/>message (page 668) supports a new argument -noimpl. The logging command<br/>message (page 668) supports a new argument -noimpl. The logging command<br/>message (page 669) supports a new argument sport show to deal with a sport sport spile (the standard ACE log file is used instead during the download).<br/>The run_fing_analysis (page 703) command supports new arguments<br/>for -voltage and -grade. The set_clock_type (page 710) command supports a<br/>new option -data_column. The write_bitstream (page 720) command now<br/>creates *. hex files instead of STAPL</li></ul> |

| Version | Date        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10.0    | 16 Apr 2024 | Additions: <ul> <li>Tcl Command Reference: A new suite of commands under the ace_ip:: namespace has been added under the heading Tcl Commands for the IP Generator Plugin Framework (page 723). New commands in the ace:: namespace have also been added in several categories, including for project source files: add_project_source_files (page 612), get_project_source_files (page 657), enable_project_source_file (page 635), disable_project_source_file (page 627), remove_project_source_file (page 676), import_synplify_project_file (page 665), move_project_source_file (page 670); for implementation options and (new) project options: create_option_sets (page 622), get_project_option_is_supported_and_enabled (page 649), get_project_option_is_supported_and_enabled (page 656), get_project_option_is_supported_and_enabled (page 657), get_project_option(page 688), set_project_option(page 688), reset_project_option (page 688), set_project_option (page 688), reset_project_option (page 688), set_project_option (page 686); for the flow: run_synthesis (page 702), run_simulation (page 701); for timing analysis get_path_ids (page 654), get_worst_path (page 664), is_timing_met (page 667); and other misc: source_secure (page 718), write_aeskey_efuse_bitstream (page 719).</li> </ul> |
|         |             | <ul> <li>Updates:</li> <li>Major updates throughout the document to reflect the changes for the new Unified ACE flow: new Synthesis and Simulation Flow Steps (page 235), restructured flow and related changes to the Flow View (page 55), new Project Options/Impl Options infrastructure with related changes to the Options View (page 100) and Configuring Project and Implementation Options (page 303), new ACE project file structure with related changes to the Projects View (page 120), related new features and actions throughout ACE, etc.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|         |             | • The ACE Quickstart Tutorial (page 3) was updated to reflect the major changes for the Unified ACE flow, particularly to the Projects View.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Version | Date        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | 16 Apr 2024 | <ul> <li>Updates (cont.):         <ul> <li>Concepts: The Tcl Console View (page 146) has been rebuilt to significantly improve performance, and has gained many new features. The Snapshot Debugger View (page 141) is now aware of changes to the pwd from the Tcl console when calculating paths relative to the Working Directory. The VCD Waveform Editor (page 11) now has additional abilities to expand and collapse buses, as well as a button to reset the table and waveform to default contents. The associated Add Signals to Waveform Viewer Dialog (page 150) was also updated with new bus and bus bit handling details. The pages for Flow Mode (page 243), IP Configuration Steps (page 238), Place and Route Steps (page 239), Design Completion Steps (page 241), Timing Report (page 245), and Multiprocess Summary Report (page 256) were all updated to reflect the current handling of PVT corners.</li> <li>Tasks: Many new features are described When Configuring Advanced</li> </ul> </li> </ul> |
| 10.0    |             | Options (page 373) for the Snapshot Debugger View, paths relative to the<br>Working Directory now take the Tcl interpreter's pwd into account. The<br>Viewing the Captured VCD Waveform (page 377) information has been updated<br>with the changes to bus and bit handling. The pages for Timing Across All<br>Temperature Corners (page 266), Generating Timing Reports (page 352), and<br>Running Multiple Flows in Parallel (page 307) were updated to reflect the current<br>handling of PVT corners.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|         |             | • Throughout the document, content has been edited and some screenshots have been updated to improve clarity and consistency. Additionally, the documentation framework has been updated, so there are likely to be minor formatting changes throughout the document as well.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|         |             | Deletions:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|         |             | <ul> <li>Tcl Command Reference: The following commands have been removed:<br/>get_fanout, get_pod_names, get_stapl_actions,<br/>run_stapl_actions,</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Version         | Date                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Version<br>10.1 | Date<br>13 Aug 2024 | Updates:<br>• Concepts: The VCD Waveform Editor (page 11) now supports tooltips in the<br>waveform area, which display the signal, value, and time under the mouse<br>cursor. The I/O Layout Diagram View (page 68) page was updated to more<br>clearly show how related preferences are split between two preference pages.<br>The Critical Paths View (page 39) now includes screenshot examples showing<br>the new buttons/functionality to left-align and right-align the textual content<br>from the Source and Destination columns. The Projects View (page 120) now<br>has a new feature to open selected files with user-selected external editors,<br>and has added new actions to expand-all and collapse-all descendant branches<br>in the tree. The Tcl Console View (page 146) now includes buttons/actions to re-<br>issue a prior command, and to use the multi-line editor to modify a prior<br>command before issuing the edited version. The NoC Performance View (page |
|                 |                     | <ul> <li>89) now includes a screenshot of the preference page allowing edits of the fonts and colors used in the view.</li> <li>Tasks: The Viewing the Captured VCD Waveform (page 377) page was updated to mention the new waveform tooltip support. The page "Automatic Flop Pushing into I/O Pads" has been renamed Automatic Flop Pushing into I/O Pins (page 452) and has received significant edits to bring it up to date.</li> <li>Tcl Reference: Many Tcl commands have had arguments added, removed, or modified: apply_placement (page 615), check_project_status (page 615), redirect (page 672), write_bitstream (page 720)</li> <li>Throughout the document, content has been edited and some screenshots have been updated to improve clarity and consistency.</li> </ul>                                                                                                                                                                                                  |