



# Raptor Design Suite

## User's Guide

## ***Legal Disclaimer***

© Rapid Silicon 2024

The information contained herein is for informational and promotional purposes only. No claims, representations or warranties or guarantees, whether express or implied, are made by Rapid Silicon as to the suitability, safety, reliability, durability, and performance of any of our companies' products or services for any particular purpose. Rapid Silicon does not assume any liability whatsoever arising out of the application or use of any product or circuit.

Rapid Silicon accepts no liability whatsoever regarding the suitability, safety, reliability, durability, and performance of any of our companies' products or services. Any specifications and information provided are indicative only. Potential buyers shall not rely on any information provided herein and shall not rely on data and performance specifications or parameters provided by Rapid Silicon.

Rapid Silicon does not grant, explicitly or implicitly, to any party any patent rights, licenses, or any other IP rights, whether with regard to such information itself or anything described by such information. Information provided in this document is proprietary to Rapid Silicon, and Rapid Silicon reserves the right to make any changes to the information in this document or to any products and services at any time without notice.

## Table of Contents

|           |                                                                                  |    |
|-----------|----------------------------------------------------------------------------------|----|
| 1         | <a href="#">Using the Raptor Design Suite</a>                                    | 8  |
| 1.1:      | <a href="#">Raptor Design Suite Features</a>                                     | 8  |
| 1.2:      | <a href="#">Raptor Design Suite Tools</a>                                        | 8  |
| 1.2.1:    | <a href="#">Project and Tcl Modes</a>                                            | 9  |
| 1.2.2:    | <a href="#">Launching the Raptor Design Suite</a>                                | 9  |
| 1.2.2.1:  | <a href="#">Working with the Raptor Design Suite</a>                             | 9  |
| 1.2.2.2:  | <a href="#">Working with TCL</a>                                                 | 10 |
| 1.2.3:    | <a href="#">Welcome Page</a>                                                     | 10 |
| 1.3:      | <a href="#">Using the Raptor Design Suite Viewing Environment</a>                | 10 |
| 1.3.1:    | <a href="#">Menu Bar</a>                                                         | 11 |
| 1.3.2:    | <a href="#">Main Tool Bar</a>                                                    | 11 |
| 1.3.3:    | <a href="#">Task Manager</a>                                                     | 11 |
| 1.3.4:    | <a href="#">Layout</a>                                                           | 12 |
| 1.3.5:    | <a href="#">Project Status Column in Task Window and Progress Bar</a>            | 14 |
| 1.3.6:    | <a href="#">Creating Projects</a>                                                | 14 |
| 1.3.6.1:  | <a href="#">Creating Projects Using TCL Commands</a>                             | 14 |
| 1.3.6.2:  | <a href="#">Creating an RTL Project Using the Raptor Design Suite</a>            | 15 |
| 1.3.6.3:  | <a href="#">Creating a Gate-Level (GL) Project Using the Raptor Design Suite</a> | 24 |
| 1.3.6.4:  | <a href="#">Creating Project with Simulation</a>                                 | 29 |
| 1.3.6.5:  | <a href="#">Compilation Logs</a>                                                 | 33 |
| 1.3.6.6:  | <a href="#">Compilation Messages</a>                                             | 37 |
| 1.3.6.7:  | <a href="#">Compilation Reports</a>                                              | 37 |
| 1.3.6.8:  | <a href="#">Compilation Compute Usage</a>                                        | 39 |
| 1.3.7:    | <a href="#">Configuration Project Settings</a>                                   | 40 |
| 1.3.8:    | <a href="#">IP Configurator</a>                                                  | 40 |
| 1.3.9:    | <a href="#">Rapid eFPGA Configurator</a>                                         | 45 |
| 1.3.10:   | <a href="#">Editing Properties</a>                                               | 50 |
| 1.3.11:   | <a href="#">Using the Text Editor</a>                                            | 52 |
| 1.3.11.1: | <a href="#">Text Editor Commands</a>                                             | 52 |
| 1.3.11.2: | <a href="#">Opening a Text File</a>                                              | 53 |
| 1.3.11.3: | <a href="#">Creating a New Text File</a>                                         | 53 |

|                                                                               |    |
|-------------------------------------------------------------------------------|----|
| 1.3.11.4: <a href="#">Using third-party editors with Raptor project files</a> | 53 |
| <b>2 Raptor Synthesis</b>                                                     | 56 |
| 2.1: <a href="#">Introduction</a>                                             | 56 |
| 2.1.1: <a href="#">Using Synthesis</a>                                        | 56 |
| 2.1.2: <a href="#">Running Synthesis</a>                                      | 56 |
| 2.1.3: <a href="#">Incremental Synthesis</a>                                  | 56 |
| 2.1.4: <a href="#">Analyzing Synthesis Results</a>                            | 56 |
| 2.1.5: <a href="#">Exploring the Logic</a>                                    | 57 |
| 2.1.6: <a href="#">Multi-Threading in RTL Synthesis</a>                       | 57 |
| 2.2: <a href="#">Synthesis Attributes</a>                                     | 57 |
| 2.2.1: <a href="#">Supported Attributes</a>                                   | 57 |
| 2.2.1.1: <a href="#">FULL_CASE (Verilog Only)</a>                             | 57 |
| 2.2.1.2: <a href="#">PARALLEL_CASE (Verilog Only)</a>                         | 57 |
| 2.3: <a href="#">HDL Coding Techniques</a>                                    | 58 |
| 2.3.1: <a href="#">Advantages of VHDL</a>                                     | 58 |
| 2.3.2: <a href="#">Advantages of Verilog</a>                                  | 58 |
| 2.3.3: <a href="#">Advantages of SystemVerilog</a>                            | 58 |
| 2.3.4: <a href="#">Flip-Flops, Registers, and Latches</a>                     | 58 |
| 2.3.5: <a href="#">Latches</a>                                                | 59 |
| 2.3.6: <a href="#">Shift Registers</a>                                        | 59 |
| 2.3.6.1: <a href="#">Static Shift Register Elements</a>                       | 59 |
| 2.3.7: <a href="#">Dynamic Shift Registers</a>                                | 59 |
| 2.3.8: <a href="#">Multipliers</a>                                            | 59 |
| 2.3.9: <a href="#">Memories</a>                                               | 59 |
| 2.4: <a href="#">VHDL-2008 Hardware Language Support</a>                      | 64 |
| 2.4.1: <a href="#">Setting up Raptor to use VHDL-2008</a>                     | 65 |
| 2.5: <a href="#">Verilog Language Support</a>                                 | 65 |
| 2.6: <a href="#">SystemVerilog Support</a>                                    | 65 |
| 2.7: <a href="#">Mixed Language Support</a>                                   | 65 |
| 2.8 <a href="#">Litex Support</a>                                             | 65 |
| 2.8.1: <a href="#">Litex SoC Integration</a>                                  | 65 |
| 2.8.2.1: <a href="#">Litex_soc Command</a>                                    | 65 |

|                                                     |            |
|-----------------------------------------------------|------------|
| 2.8.2: <a href="#">Litex Simulation</a>             | 66         |
| 2.8.2.1: <a href="#">litex_sim Command</a>          | 66         |
| 2.8.3: <a href="#">Adding Custom IP</a>             | 67         |
| 2.8.4: <a href="#">Raptor IP Catalog</a>            | 68         |
| 2.8.5.: <a href="#">IP Catalog Simulations</a>      | 69         |
| <b>3 <a href="#">Raptor Place and Route</a></b>     | <b>71</b>  |
| 3.1: <a href="#">Introduction</a>                   | 71         |
| 3.2: <a href="#">P&amp;R Methodology</a>            | 71         |
| 3.3: <a href="#">Use P&amp;R</a>                    | 71         |
| 3.3.1: <a href="#">General Options</a>              | 71         |
| 3.3.2: <a href="#">Filename Options</a>             | 72         |
| 3.3.3: <a href="#">Netlist Options</a>              | 72         |
| 3.3.4: <a href="#">Packing Options</a>              | 74         |
| 3.3.5: <a href="#">Placer Options</a>               | 77         |
| 3.3.6: <a href="#">Timing-Driven Placer Options</a> | 80         |
| 3.3.7: <a href="#">Router Options</a>               | 82         |
| 3.3.8: <a href="#">Timing-Driven Router Options</a> | 85         |
| 3.3.9: <a href="#">Analysis Options</a>             | 89         |
| 3.3.10: <a href="#">Congestion Mitigation</a>       | 90         |
| 3.4: <a href="#">Use Pin Location Constrains</a>    | 91         |
| <b>4 <a href="#">Raptor Timing Analysis</a></b>     | <b>94</b>  |
| 4.1: <a href="#">STA Methodology</a>                | 94         |
| 4.2: <a href="#">Using STA</a>                      | 94         |
| 4.2.1: <a href="#">SDC Commands</a>                 | 94         |
| <b>5 <a href="#">Device Configuration</a></b>       | <b>108</b> |
| 5.1: <a href="#">Raptor Device Programmer GUI</a>   | 108        |
| 5.2: <a href="#">FPGA Device Configuration</a>      | 108        |
| 5.3: <a href="#">Flash Programming</a>              | 108        |
| 5.4: <a href="#">OTP Programming</a>                | 111        |

|        |                                                                     |     |
|--------|---------------------------------------------------------------------|-----|
| 5.5    | <a href="#">Other Programmer Commands</a>                           | 113 |
| 5.5.1: | <a href="#">list_cable</a>                                          | 113 |
| 5.5.2: | <a href="#">list_device</a>                                         | 114 |
| 5.5.3: | <a href="#">fpga_status</a>                                         | 114 |
| 6      | <a href="#">OCLA Debugger</a>                                       | 115 |
| 6.1:   | <a href="#">OCLA Debugger Tcl Command</a>                           | 115 |
| 6.1.1: | <a href="#">Detect JTAG cable</a>                                   | 115 |
| 6.1.2: | <a href="#">Detect OCLA Device</a>                                  | 115 |
| 6.1.3: | <a href="#">Load OCLA debug information from a design</a>           | 115 |
| 6.1.4: | <a href="#">Configure OCLA</a>                                      | 117 |
| 6.1.5: | <a href="#">Configure OCLA Trigger</a>                              | 117 |
| 6.1.6: | <a href="#">Modify and delete existing trigger configuration</a>    | 119 |
| 6.1.7: | <a href="#">Start OCLA and visualize sample waveform in GTKWave</a> | 120 |
| 6.2:   | <a href="#">Emulate-IO (EIO) Support</a>                            | 121 |
| 6.2.1: | <a href="#">Inspect EIO Input &amp; Output signal information</a>   | 122 |
| 6.2.2: | <a href="#">Read EIO Input IO state</a>                             | 122 |
| 6.2.3: | <a href="#">Configure EIO Output IO state</a>                       | 123 |
| 7      | <a href="#">Using Tcl Scripting</a>                                 | 124 |
| 7.1:   | <a href="#">Tcl Overview</a>                                        | 124 |
| 7.2:   | <a href="#">Loading and Running Tcl Scripts</a>                     | 125 |
| 7.2.1: | <a href="#">Automatically Load Tcl Scripts</a>                      | 125 |
| 7.2.2: | <a href="#">Invoking a Tcl Script at Power-up</a>                   | 125 |
| 7.2.3: | <a href="#">Tcl Script Source Command</a>                           | 125 |
| 7.2.4: | <a href="#">Adding Constraints to Tcl Scripts</a>                   | 126 |
| 7.3:   | <a href="#">Writing a Tcl Script</a>                                | 126 |
| 7.3.1: | <a href="#">Adding Arguments to a Tcl Script</a>                    | 126 |

|                                                                              |     |
|------------------------------------------------------------------------------|-----|
| 7.3.2: <a href="#">Types of Variables</a>                                    | 126 |
| 7.4: <a href="#">Loop Control and Iteration</a>                              | 126 |
| 7.5: <a href="#">Error Handling</a>                                          | 126 |
| 7.5.1: <a href="#">Corner Cases and Incorrect Script Usage</a>               | 126 |
| 7.5.2: <a href="#">Tcl Script Errors</a>                                     | 126 |
| 7.6: <a href="#">Interfacing to External Programs</a>                        | 126 |
| 7.7: <a href="#">Tcl Commands</a>                                            | 127 |
| 7.8: <a href="#">Using RapidGPT in Raptor</a>                                | 127 |
| <br>8 <a href="#">Examples</a>                                               | 134 |
| 8.1: <a href="#">Tcl Examples</a>                                            | 134 |
| 8.2: <a href="#">Project Examples</a>                                        | 135 |
| 8.3: <a href="#">Example Designs</a>                                         | 135 |
| <br>9 <a href="#">Formal Verification</a>                                    | 136 |
| 9.1 <a href="#">Formal Verification Using VHDL</a>                           | 136 |
| 9.2 <a href="#">Formal Verification Using Verilog</a>                        | 137 |
| 9.3 <a href="#">Formal Verification Using Formality</a>                      | 138 |
| 9.4 <a href="#">View Raptor Post-Synthesis Verilog Netlist in StarVision</a> | 139 |
| 9.5 <a href="#">MVP Support</a>                                              | 141 |
| <br><a href="#">Appendix A Raptor Design Suite Installation Guide</a>        | 142 |
| A.1 <a href="#">Installing Raptor</a>                                        | 142 |
| A.2 <a href="#">Verify the Installation</a>                                  | 143 |

# 1 Using the Raptor Design Suite

The Raptor Design Suite is an integrated user design environment that provides an end-to-end system-on-chip design environment based on open-source tooling, allowing users to review the code used to implement their design. Further, users can suggest optimizations and new features within the open-source community.

For automation and ease-of-use, the Raptor design suite provides both a project-based GUI-based design cockpit, as well as a robust Tcl scripting environment. Users can switch between the GUI environment and the Tcl scripting environment at will and even automate the GUI experience using Tcl scripts.

## 1.1 Raptor Design Suite Features

The Raptor design suite is accessible through Tcl, allowing design changes to elements such as configuration, constraints, or settings to be performed in real time.

The Raptor design suite includes the following features:

- Register transfer level (RTL) design in VHDL, Verilog, and SystemVerilog
- Synthesis
- Easy integration of Intellectual Property (IP) for third-party cores
- Place and route\*
- Static timing analysis (STA)\*
- Performs Behavioral, functional, and timing simulation\*

\* The Gemini device (1GE100-ES1 and timing model currently available in the Raptor design suite version 0.5 is a placeholder to evaluate the software flow only. This version is not intended for design purposes. However, it can be used to evaluate the software flow and usability.

## 1.2 Raptor Design Suite Tools

The Raptor design suite is based on the following tools.

**Table 1. Raptor Design Suite Tools**

| Tool           | Name                 | Source Location                                                                               |
|----------------|----------------------|-----------------------------------------------------------------------------------------------|
| FOEDAG         | GUI Toolkit          | <a href="https://github.com/os-fpga/FOEDAG">https://github.com/os-fpga/FOEDAG</a>             |
| LiteX          | IP Integration       | <a href="https://github.com/enjoy-digital/litex">https://github.com/enjoy-digital/litex</a>   |
| Yosys          | Synthesis            | <a href="https://github.com/YosysHQ/yosys">https://github.com/YosysHQ/yosys</a>               |
| ICARUS Verilog | Synthesis (Verilog)  | <a href="https://github.com/steveicarus/iverilog">https://github.com/steveicarus/iverilog</a> |
| GHDL           | Synthesis (VHDL)     | <a href="https://github.com/ghdl/ghdl">https://github.com/ghdl/ghdl</a>                       |
| ABC            | Sequential Synthesis | <a href="https://github.com/berkeley-abc/abc">https://github.com/berkeley-abc/abc</a>         |
| VPR            | Place & Route        | <a href="https://github.com/verilog-to-routing">https://github.com/verilog-to-routing</a>     |
| OpenFPGA       | Bitstream Generation | <a href="https://github.com/lnis-uofu/OpenFPGA">https://github.com/lnis-uofu/OpenFPGA</a>     |
| Verilator      | Simulation           | <a href="https://github.com/verilator/verilator">https://github.com/verilator/verilator</a>   |
| OpenOCD        | Device Programmer    | <a href="https://github.com/openocd-org/openocd">https://github.com/openocd-org/openocd</a>   |

## 1.2.1 Project and Tcl Modes

There are two design flow modes available in the Raptor Design Suite:

- Project mode
- Tcl mode

In Project mode, a project is created within the Raptor design suite using GUI. This approach automatically saves the design at regular intervals. It also automatically manages the source files and generates reports as necessary.

Tcl mode is executed using Tcl commands or scripts. In Tcl mode, the user still has full control of the design flow as with Project mode, but the Raptor design suite does not automatically manage source files or report the design state. Rather, the Raptor design suite can be opened at each stage of the design in order to manage the source files and perform design analysis. In Tcl mode the active design has an in-memory presentation that is "session persistent", so any changes are automatically passed forward in the flow. It also allows the user to update to constraint files or design checkpoints.

In both modes, the Raptor Design Suite supports the following features:

- Design source file list definition (RTL files, include paths, libraries...)
- Status reports on running tasks
- Automatically generated standard reports
- Persistent project settings and design configuration
- Experimentation with synthesis runs
- Definition, usage, and management of constraint sets
- Creation of report (rpt) files generated for each compilation step
- Easy integration and configuration of third-party IP

## 1.2.2 Launching the Raptor Design Suite

The Raptor Design Suite currently supports Linux and can be invoked using one of the following methods:

- Project mode
- Tcl mode

### 1.2.2.1 Working with the Raptor Design Suite

#### *Setting up the Raptor Design Suite Environment*

Prior to launching the Raptor design suite, the appropriate environment must be set up. This process has been simplified with a script provided in the Raptor design suite install directory. Users can source the Raptor OS environment setup script using the following command

```
$ source <install_path>/raptorenv_lin64.sh
```

#### *Launching the Raptor Design Suite from the Command Line on Linux*

Enter the following command at the command prompt:

```
raptor (GUI mode)
raptor --batch (Batch mode)
```

### 1.2.2.2 Working with TCL

When using the Raptor design suite in Tcl mode, the Tcl commands can be executed using either of the following methods:

- Enter individual Tcl commands from a Tcl shell outside of the Raptor design suite.
- Run Tcl scripts from the Raptor Design Suite Tcl console within the Raptor GUI (see [Figure 6](#)).

#### ***Launching the Raptor Design Suite Tcl Shell***

The following commands can be used to invoke the Raptor Design Suite Tcl shell at the Linux command prompt:

```
raptor --batch
```

This command enters the Tcl prompt

```
#
```

#### ***Launching the Raptor Design Suite Using a Batch Tcl Script***

The Raptor design suite can be invoked in batch mode by supplying a Tcl script. Use the following command at the Linux command prompt.

To launch the GUI driven by script:

```
raptor --script <path-to-tcl-script>
```

To launch Raptor for regressions (where the script will run and exit upon completion), i.e., batch driven by script:

```
raptor --batch -script <path-to-tcl-script>
```

### 1.2.3 Welcome Page

When you open the Raptor design suite, the Welcome page appears as shown in [Figure 1](#). The Raptor Design Suite Welcome page assists in creating and opening projects or example designs.



**Figure 1. Raptor Design Suite Welcome Page**

### 1.3 Using the Raptor Design Suite Viewing Environment

This section contains general information on the terminology, layout, and project features of the Raptor design suite in project mode using the GUI

### 1.3.1 Menu Bar

The main menu bar in [Figure 2](#) provides access to Raptor design suite commands.



[Figure 2. Raptor Design Suite Menu Bar](#)

### 1.3.2 Main Tool Bar

The main tool bar in [Figure 3](#) provides one-click access to the most used commands in the Raptor design suite such as save and stop.



[Figure 3. Raptor Design Suite Main Tool Bar](#)

### 1.3.3 Task Manager

The Task Manager provides access to commands as shown in [Figure 4](#).

| Task                                |                 |            |
|-------------------------------------|-----------------|------------|
| Run                                 | Task            | Fmax (MHz) |
| <input checked="" type="checkbox"/> | IP Generate     | ---        |
| <input checked="" type="checkbox"/> | Analysis        | ---        |
| <input checked="" type="checkbox"/> | Simulate RTL    | ---        |
| <input checked="" type="checkbox"/> | Synthesis       | ---        |
| <input checked="" type="checkbox"/> | Simulate Gate   | ---        |
| <input checked="" type="checkbox"/> | Packing         | ---        |
| <input checked="" type="checkbox"/> | Placement       | ---        |
| <input checked="" type="checkbox"/> | Routing         | ---        |
| <input checked="" type="checkbox"/> | Simulate PNR    | ---        |
| <input checked="" type="checkbox"/> | Timing Analysis | ---        |
| <input checked="" type="checkbox"/> | Power           | ---        |
| <input checked="" type="checkbox"/> | Bitstream       | ---        |

[Figure 4. Raptor Design Suite Task Manager](#)

### 1.3.4 Layout

The Raptor design suite provides predefined window layouts to facilitate various tasks in the design process. The user can move the windows to a desired location such as moving task window to the right of the design window. An empty project view is shown in [Figure 5](#).



**Figure 5. Raptor Design Suite Layout Selector**

[Figure 6](#) shows an example project (and2\_gemini) with all main views highlighted. Each number in the figure is described below.



**Figure 6. Example Project View**

1. IP Configurator. Configure and generate IPs for project. Refer [Section 1.3.8 “IP Configurator”](#) for details.
2. RapidGPT chat window. Refer [Section 7.8 Using RapidGPT in Raptor](#) for details.
3. Editor. Text editor to view and edit text-based source files.
4. Design file browser. Once design files are added while creating a project or later using the project settings, they can be viewed here. Right click on each will open provide users various ways to modify the design.
5. Hierarchical viewer.

- 5.1. View instances and module names defined in the project. Figure X shows an example and right-clicking allows user to go to the definition/instantiation of the instance.

```
<top>
<instance name 1>: <module name>
<instance name 2>: <module name>
    <instance name 1>: <module name>
    <instance name 2>: <module name>
<instance name 3>: <module name>
```



**Figure 7. Hierarchical Viewer**

- 5.2. Note: Known issue with “Go to definition” context menu such that it takes user to the end of module definition.

6. Explorer. Filesystem explorer for navigating the project folder (default) and other locations as needed.
7. Properties. File location information about the open file that one is editing, including line numbers will be displayed in the editor window.
8. Task. Displays sequential tasks in the compilation of the design intended from source files displayed.
9. Compute usage. Performance metrics for each compilation tasks.
10. Reports for tasks as applicable.
11. Messages for tasks as applicable.
12. Tcl Console. Tcl interpreter built-into the Raptor design suite. Refer to the Tcl section for detailed commands available

### 1.3.5 Project Status Column in Task Window and Progress Bar

The project status column displays the current status of the active design compilation in the Task window as shown in [Figure 8](#). Each number in the figure is further described below.



**Figure 8. Project Status Column in Task Window and Progress Bar**

1. Green bar for a successful compilation step.
2. Loading symbol for an active compilation step.
3. Red bar for a failed compilation step.
4. Checkbox to show enable/disable status.
5. Status of tasks in progress.

### 1.3.6 Creating Projects

The Raptor design suite contains a 'New Project' option to easily create different types of projects. To open this wizard, select File → Project → New, then specify the project location and name to create the project.

#### 1.3.6.1 Creating Projects Using TCL Commands

In addition to using the wizard described above, you can create a project using Tcl commands. Commands can be:

- Entered in the Tcl Console of the Raptor design suite
- Sourced directly from a Tcl file

Passed in a tcl file to raptor invocation as a CLI option raptor --script <tcl file> An example script is shown below.

```

#
D
e
s
i
g
n

create_design and2_gemini
add_design_file -
V_2001 ./rtl1/and2.v
set_top_module and2
add_constraint_file
constraints.sdc
# Device target

target_device 1GE100-ES1

# Compilation
analyze
synthesize delay
packing
place
route
sta
bitstream

```

### 1.3.6.2 Creating an RTL Project Using the Raptor Design Suite

Follow the steps below to create a project using the Raptor design suite.

A new project can be created using the menu shown below, or via the Welcome page shown in [Figure 1](#).



**Figure 9. Create a New Project**

The project wizard will guide the user through each step shown below. The following steps show how to create a project using the example design “and2\_gemini” bundled with Raptor.

1. Project Directory: Set a project name and location as shown in Figure 10.

**NOTE:** The user must have read and write permissions to the project directory location



Figure 10. Project Directory Page

2. Type of Project: User can skip the design sources and add them later using the source view. Refer to [Figure 11](#)

**NOTE:** Default type of project is RTL



**Figure 11. Type of Project**

3. Add Design Files: Various methods to add design files are described in **Figure 12**



**Figure 12. Add Design Files**

4. Create a source file with supported file type as shown in **Figure 13**.



**Figure 13. Create a Source File**

5. The user can select a directory to scan for supported source files. Raptor will recursively search through the folder and add the supported source files to the project.



**Figure 14. Scan for Supported Source Files**

6. The user can also add individual source files using the "Add File" option as shown in Figure 15.



**Figure 15. Add Individual Source Files**

7. Once the design files have been added, the wizard shows the file(s) that will be added to the project. The user is also presented with various options as shown in [Figure 16](#).



**Figure 16. Add Files to the Project**

8. Add Design Constraints: Similarly, the user can add or skip design constraint files as shown in [Figure 17](#).



**Figure 17. Add Design Constraints**

9. Select Target Device: Select the supported target device in Raptor as shown in [Figure 18](#).



**Figure 18. Select the Target Device**

10. Summary: Displays the summary of project for user to finish the project creation process as shown in [Figure 19](#).



**Figure 19. New Project Summary**

11. The user can also edit the settings as shown below after a project has been created as shown in [Figure 20](#).



**Figure 20. Edit Project Settings**

12. Compile the design: Hit the play button from Menu tool bar to start the compilation as shown in Figure 21.



Figure 21. Compile the Design

13. Compilation in progress: During compilation, messages will be printed to the Tcl console. The task view's status column shows the current compilation step and a progress bar on top right is active until completion as shown in Figure 22.



Figure 22. Compilation in Progress

14. Stop the compilation: The user can choose to stop the compilation by hitting the red Stop button in the tool bar. After stopping the user must clean the step at which the compilation was stopped before restarting the compilation from that stopped step as shown in Figure 23.



**Figure 23. Stop the Compilation**

15. Successful compilation: Once the compilation is finished, the user will see the bit generation completion message and all status in task view will be green as shown in Figure 24.



**Figure 24. Successful Compilation**

### 1.3.6.3 Creating a Gate-Level (GL) Project Using the Raptor Design Suite

1. Create a new project (Refer new project section)



Figure 25. Create new GL project

2. Select the project type as GL project as shown below.



**Figure 26. Select GL project type**

3. Add a Gate-Level Verilog netlist file (.v)

**NOTE:** We only support one type of .edif, .edf, eblif, .v for this project type.



**Figure 27. Add supported GL netlist file**

4. Add other files as needed. We will add one constraint file and then select the target device.



Figure 28. Add supported GL netlist file



**Figure 29. Select Target Device for GL project**

5. Review the project summary and hit “Finish”



**Figure 30. GL Project Summary**

6. Go through different compilation steps or use the run button to go through available tasks sequentially.

#### 1.3.6.4 Creating Project with Simulation

Raptor provides simulation option in between compilation tasks as shown in [Figure 4](#). Each simulation option can be configured separately using respective settings option in the task manager.

- Simulate RTL
- Simulate Gate
- Simulate PNR

For the and2\_gemini RTL example shown in Section 1.3.6.3 above, a user can add simulation files either during the project creation stage or using the project settings as shown below.



The following button can be used to run the design compilation tasks along with the simulation ones.



By default, all simulation tasks are enabled but a user can enable or disable them using the checkbox.

Once the simulation is complete, open the waveform file from the right click menu.

To generate waveforms, the testbench is expected to contain:

- \$dumpvars statement for Icarus
- C waveform dump statement for Verilator (See Verilator documentation)
- command line options (Simulation runtime option) for GHDL.



Raptor Design Suite supports three native simulators:

| Simulator                                                                                                                                                                                                                                               | Supported HDL            | Reference Link                                                                                |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-----------------------------------------------------------------------------------------------|
| Icarus Verilog ( <b>Iverilog</b> )                                                                                                                                                                                                                      | Verilog                  | <a href="#">Icarus Verilog</a>                                                                |
| Verilator                                                                                                                                                                                                                                               | Verilog & System Verilog | <a href="#">Overview — Verilator 5.007 documentation</a>                                      |
| GHDL                                                                                                                                                                                                                                                    | VHDL                     | <a href="#">Quick Start Guide — GHDL 0.36-dev documentation (gritbub-ghdl.readthedocs.io)</a> |
| <b>Note:</b>                                                                                                                                                                                                                                            |                          |                                                                                               |
| <ul style="list-style-type: none"> <li>- Raptor UI by default is configured to use <b>Iverilog</b> to compile and simulate the design for functional simulations.</li> <li>- Mix HDL language is not supported by Raptor's native simulators</li> </ul> |                          |                                                                                               |

#### How to select the simulator for your design simulations:

- Select the edit setting of Simulator RTL option, this will allow user to select between three different simulators



**Note:** simulator by default create simulation waveform in **.fst** file format in project repo, user should use GTKWAVE to load simulation waveform manually.

The file extension of the filename used in the “Waveform file” field (Or the “simulate” Tcl command) dictates the waveform file format. All formats are supported by GTKWave.

.fst for FST

.vcd for VCD

.ghw for GHW (GHDL format)

**TCL Commands:**

| Tcl Command                    | Arguments                                                               | Description                                                                                                                                                                                        |
|--------------------------------|-------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| set_top_testbench              | <module>                                                                | Sets the top level testbench module/entity.                                                                                                                                                        |
| simulation_options <simulator> | <task>                                                                  | Sets the simulator specific options for the specified simulator task<br>Compilation, elaboration, simulation                                                                                       |
| simulate <level>               | <level><br>rtl<br>gate<br>Pnr<br>?<simulator>?<br>?<waveform_file.ext>? | Simulates the design and testbench.<br><br>RTL simulation<br>Post-synthesis simulation<br>Post place and route simulation<br>verilator, ghdl, icarus (Default)<br>.ext supported: .fst, .vcd, .ghw |
| wave_*                         |                                                                         | All wave commands will launch the GTKWave process if one has not been launched already.                                                                                                            |
| wave_cmd ...                   |                                                                         | Sends given tcl commands to the GTKWave process. See the GTKWave documentation at:<br>Gtkwave::: commands                                                                                          |
| wave_open                      | <filename>                                                              | Load a given file in the GTKWave process.                                                                                                                                                          |
| wave_refresh                   |                                                                         | Reloads the current active wave file.                                                                                                                                                              |
| wave_show                      | <signal>                                                                | Add the given signal to the GTKWave window and highlight it.                                                                                                                                       |
| wave_time                      | <time>                                                                  | Set the primary marker to <time>. Time units can be specified, without a space. For example: wave_time 100ps.                                                                                      |

**1.3.6.5 Compilation Logs**

While compiling the project, each compilation step generates a log. It's a \*.rpt file holding task-specific information. Logs for each task are stored in their respective folders under the project directory.

Below in **Figure 31**, shown is an example for the synthesis.rpt log file location under the project directory.



**Figure 31. Opening a Log Manually**

Logs can also be opened via the RMB menu of the corresponding cell as shown in **Figure 32**.



**Figure 32. Opening a Log Via the RMB Menu**

Log action is only available in the task column and corresponds to the selected task. Its name structure is as follows:

View <TaskName> Logs

Subtasks may also create log files. If they don't, Log action corresponds to the parent action, which creates the \*.rpt log.

**NOTE:** In the current Raptor implementation, subtasks do not create log files.

In case a log file cannot be located, the action will be disabled. It may happen if:

- The action hasn't been run yet
- The log file wasn't created (due to task failure or permission access)
- An action was executed
- The file was manually removed or cleaned



Figure 33. View IP Generate Logs

Triggering a log action opens the log file in the application editor as shown in [Figure 34](#) for synthesis log file



Figure 34. Open Task Log in Application Editor

Table 2 shows an overview of all tasks log files.

**Table 2: Tasks Log Files Overview Screen**

| Task                 | File                | Status        |
|----------------------|---------------------|---------------|
| IP Generate          | ip_generate.rpt     | Not Available |
| Analysis             | analysis.rpt        | Available     |
| Synthesis            | synthesis.rpt       | Available     |
| Packing              | packing.rpt         | Available     |
| Placement            | placement.rpt       | Available     |
| Routing              | routing.rpt         | Available     |
| Timing Analysis      | timing_analysis.rpt | Available     |
| BitStream Generation | bitstream.rpt       | Available     |

### 1.3.6.6 Compilation Messages

Important messages from each task log are available under the messages tab as shown in Figure 35.



**Figure 35. Compilation Messages**

Messages can be expanded or collapsed as shown below in Figure 36. For example, the message highlighted under the Synthesis task, when double-clicked, opens the synthesis log file, and takes user to that line without the need for explicit search through the rpt file.



**Figure 36. Expanding and Collapsing Messages**

### 1.3.6.7 Compilation Reports

As shown in Table 2 (Task logs) above, the reports for some of the compilation tasks are also available by right-clicking on the task.

Figure 37 shows an example of a synthesis report.



Figure 37. Example of a Synthesis Report

Some tasks might have multiple reports. Figure 38 is an example of two reports available under the synthesis task.



Figure 38. Viewing Multiple Reports

Reports for each task can also be accessed via the Report panel as shown in Figure 39 below.



Figure 39. Reports panel

### 1.3.6.8 Compilation Compute Usage



Figure 40. Enable Compute Usage View

| Console              | Messages    | Reports         | Compute usage |
|----------------------|-------------|-----------------|---------------|
| Compute usage        |             |                 |               |
| Task                 | Duration, s | Utilization, MB |               |
| Analysis             | 0.068       | 65.9141         |               |
| Simulate RTL         | N/A         | N/A             |               |
| Synthesis            | 8.178       | 102.727         |               |
| Simulate Gate        | N/A         | N/A             |               |
| Packing              | 23.425      | 1344.85         |               |
| Placement            | 167.469     | 1344.82         |               |
| Routing              | 81.86       | 1344.82         |               |
| Simulate PNR         | N/A         | N/A             |               |
| Timing Analysis      | 21.344      | 1344.82         |               |
| Bitstream Generation | N/A         | N/A             |               |

**Figure 41. View Compute usage for current compilation process once completed**

Understanding the data in the table:

1. Result is available only after task successfully done.
2. Result is N/A in case:
  - a. Task was cleaned
  - b. Task was skipped because of no design change.
  - c. Project was opened.
3. For simulation task:
  - a. Duration is a sum of three (elaboration, compile and simulate)
  - b. Utilization is maximum of three (elaboration, compile and simulate)

### 1.3.7 Configuration Project Settings

The project settings can be configured using the Settings dialog box. These settings include:

- General settings
- Synthesis
- IP integration
- Simulation
- Elaboration
- Implementation
- Bit-stream

### 1.3.8 IP Configurator

The Raptor IP configurator is used to generate IPs. The IP configurator must be enabled to view the IP catalog. The IP configurator can be enabled as shown in [Figure 42](#).



Figure 42. Enable IP Configurator

This action opens the list of IPs from the Raptor IP Catalog as shown in [Figure 43](#). The right side of the figure shows a list of the available IP's. Once you single click the IP a dialogue box appears at the bottom that provides basic IP information at the bottom.

The screenshot shows two panels from the Raptor Catalog. The top panel, titled 'IP Index', lists various IP cores under the heading 'Available'. One item, 'axil\_eio\_v1\_0', is highlighted with a blue selection bar. The bottom panel, titled 'IP Description/Details', provides specific information for the selected 'axil\_eio\_v1\_0' core, including its name, version, interface, and a detailed description.

| IP Index                    |  |
|-----------------------------|--|
| Available                   |  |
| ahb2axi_bridge_v1_0         |  |
| axi_async_fifo_v1_0         |  |
| axi_cdma_v1_0               |  |
| axi_cdma_v2_0               |  |
| axi_crossbar_v1_0           |  |
| axi_crossbar_v2_0           |  |
| axi_dma_v1_0                |  |
| axi_dram_v1_0               |  |
| axi_fifo_v1_0               |  |
| axi_interconnect_v1_0       |  |
| axi_ram_v1_0                |  |
| axi_register_v1_0           |  |
| axi2axilite_bridge_v1_0     |  |
| axil_crossbar_v1_0          |  |
| axil_crossbar_v2_0          |  |
| <b>axil_eio_v1_0</b>        |  |
| axil_ethernet_v1_0          |  |
| axil_gpio_v1_0              |  |
| axil_interconnect_v1_0      |  |
| axil_quadspi_v1_0           |  |
| axil_tmp_sensor_v1_0        |  |
| axil_uart16550_v1_0         |  |
| axis_adapter_v1_0           |  |
| axis_async_fifo_v1_0        |  |
| axis_broadcast_v1_0         |  |
| axis_fifo_v1_0              |  |
| axis_interconnect_v1_0      |  |
| axis_pipeline_register_v1_0 |  |
| axis_ram_switch_v1_0        |  |
| axis_switch_v1_0            |  |
| axis_uart_v1_0              |  |
| boot_clock_v1_0             |  |
| ...                         |  |

| IP Description/Details |                                                                                                                                                                                                                                       |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Name:                  | EIO                                                                                                                                                                                                                                   |
| Version:               | V1_0                                                                                                                                                                                                                                  |
| Interface:             | AXI4-Lite                                                                                                                                                                                                                             |
| Description:           | The Emulate-IO core is an AXI4-Lite compliant IP that offers input and output probes to sample and drive signals on FPGA fabric. The core provides an AXI4-slave interface that can be used to control the emulated IOs in real time. |

Figure 43. List of Raptor Catalog IP's

Select the IP from the list of available IPs by double clicking the IP in the list, a configuration window appears in front of you that can be used to configure the selected IP and provide the output module name for the IP you want to generate. At the bottom of the configure IP window you see a summary tab where you can see the configuration you are doing in run time, once you are satisfied that you have configured the IP correctly, click **Generate IP** in the lower right-hand corner of [Figure 44](#).

Using this configure IP window you can access IP documentation, location and block diagram by clicking the respective buttons or images.



**Figure 44. IP Configuration Window**

Clicking on the Generate IP button above creates the IP in your Raptor project as shown in [Figure 45](#).



**Figure 45. Create IP in the Raptor Project**

After this you can add this generated IP part of your Raptor project using the Add Design Files option in the project wizard.

**Note:** All Soft IP collaterals are located in the Raptor Install area path: <Raptor Installation area>/share/raptor/IP\_Catalog

| File Type                        | Path of Directory                                                 |
|----------------------------------|-------------------------------------------------------------------|
| Verilog file                     | ./IP_Catalog/rapidsilicon/ip/<IP_Name>/<IP_Version>/src           |
| Simulation scripts               | ./IP_Catalog/rapidsilicon/ip/<IP_Name>/<IP_Version>/sim           |
| Timing Constraints               | ./IP_Catalog/rapidsilicon/ip/<IP_Name>/<IP_Version>/sdc           |
| IP User Guide                    | ./IP_Catalog/rapidsilicon/ip/<IP_Name>/<IP_Version>/doc           |
| LiteX Integration Python wrapper | ./IP_Catalog/rapidsilicon/ip/<IP_Name>/<IP_Version>/litex_wrapper |

### 1.3.9 Rapid eFPGA Configurator

#### Introduction to Rapid eFPGA Configurator

The Rapid eFPGA Configurator (REC) represents industry's first-of-its-kind eFPGA design solution based on our Vega FPGA platform. It's a tool integrated into the Raptor Design Suite to overcome the limitations of traditional eFPGA development methodologies.

REC offers granular control over critical resources such as Digital Signal Processors (DSPs), Block RAMs (BRAMs), Logic Elements (LEs), and Configurable Logic Blocks (CLBs). This unique level of control allows the creation of eFPGA instances perfectly tailored to your specific project requirements, eliminating wasted resources, and achieving optimal performance.

#### Using the Rapid eFPGA Configurator

1. The Rapid eFPGA Configurator integrates with the Raptor Design Suite, ensuring a streamlined user experience. To initiate the configuration process, navigate to the Tools menu within the Raptor Design Suite. Within this menu, you will find a designated option for the rapid eFPGA configurator. Selecting this option will launch the configurator tool:



2. Having launched the Rapid eFPGA Configurator from the Tools menu, you'll be presented with a dedicated dialog box for designing your eFPGA. This interactive interface serves as the canvas upon which you'll define the precise resource allocation for your project. To streamline the process and prevent potential errors, the tool incorporates a validation system. As you make selections, the configurator automatically performs real-time checks to ensure the validity of your input. This safeguard helps to eliminate the possibility of creating an eFPGA with incompatible inputs.

**Note:**

- Until all status is "Pass", one cannot create the device
- Fabric requires CLB >= 75%

3. Once you have launched the dialog box, you now need to proceed with allocating desired resources for your eFPGA. Once you've completed filling in the parameters, press "OK" to create your customized device. Below is an example of valid user input parameter:



4. Now you have created your custom eFPGA device using Rapid eFPGA Configurator, you can proceed to use it for your designs following two primary methods:
- For a project already created, use the project settings to navigate to the eFPGA device created above. For this, right click on the project name -> Project Settings -> Select Target Device -> Look for the eFPGA device by filtering through the series (Vega), Family (Vega), and Package (EFPGA).



- For a new project, while creating the project you will land on the “Select Target Device” screen. Click the “Create” button to bring up the eFPGA configurator page.

A sample device created with the following steps above is presented below. This device can be edited or removed using the “Edits” or “Remove” button:



You have now successfully created a custom eFPGA device tailored to your project's specific needs. You can use this device to compile your designs using Raptor Design Suite compilation flow.

5. The Raptor Design Suite offers two distinct compilation options (as shown in figure), empowering you to select the approach that best aligns with your workflow needs:



- a) **"Run Compilation Only"**: This option prioritizes efficiency, focusing solely on translating your design files into a hardware-executable format. Selecting this option initiates the compilation process, generating the necessary files to implement your design onto the custom eFPGA device within your SoC. This approach caters to scenarios where you prioritize rapid compilation and immediate hardware deployment.
- b) **"Run Compilation + Simulation"**: For a more comprehensive verification process, the suite offers the "Run Compilation + Simulation" option. This approach initiates a two-step process
  - I) **Compilation**: Like the "Run Compilation Only" option, the suite translates your design files into a hardware-executable format.
  - II) **Simulation**: Along with compilation, the suite simulates the behavior of your design on the custom eFPGA device within a virtual environment. This simulation provides valuable insights into the functionality of your design before actual hardware deployment. Selecting this option ensures a higher degree of confidence in your design's correctness before committing to hardware implementation.

The users can refer to the Raptor User Guide (RUG) for a detailed explanation of each compilation step.

6. Having successfully compiled your design to leverage the custom eFPGA device, you may now delve into the details of its implementation. The PnR view offers a comprehensive perspective on the internal layout of your design within the custom eFPGA device. The PnR view can be analyzed by right clicking on the "Routing" from the compilation task menu and choosing "PnR View"



The PnR view window is displayed for you to analyze the layout. Users can zoom in and out using the controls on the PnR view window.



### 1.3.10 Editing Properties

The synthesis and placement tasks have settings that can be edited via the “Edit settings...” button via RMB on that task in the Task Window as shown in [Figure 46](#) or using the three vertical dots next to task .



**Figure 46.** Edit Setting in Task Window

The synthesis settings can then be edited by selecting the options shown in [Figure 47](#).



**Figure 47.** Edit the Synthesis Settings

The placement settings can be edited by selecting the options shown in [Figure 48](#).



**Figure 48. Edit Placement Settings**

### 1.3.11 Using the Text Editor

The Raptor design suite has integrated [Monaco Editor](#) that supports:

1. Code folding
2. Syntax checking and highlighting
3. Errors and warning indications

#### 1.3.11.1 Text Editor Commands

For various text editor commands please refer the [accessibility guide](#) to use the commands as part of the Command Palette.

ip c

### 1.3.11.2 Opening a Text File

Files can be opened from the menus via File → Open File as shown in [Figure 49](#).



[Figure 49. Opening an Existing Text File](#)

### 1.3.11.3 Creating a New Text File

A new file can be created from the menus via File → New as shown in [Figure 50](#).



[Figure 50. Creating a New Text File](#)

A new file can also be created by clicking the "New" button in the tool bar as shown in [Figure 51](#).



[Figure 51. Click the Blue Folder Button to Create a New Text File](#)

### 1.3.11.4 Using third-party editors with Raptor project files

Users can configure Raptor to edit the project files using third-party editors available on the user OS.



**Figure 52. Set-up Third Party Editors using the Preferences Option**

Set up the editors as shown below. Note that the editors must be available on the path for Raptor to find them.



**Figure 53. Set-up gedit editor on Ubuntu**



Figure 54. Open any project file using gedit

```

`timescale 1ns / 1ps
/////////////////////////////////////////////////////////////////
// Rapid Silicon Raptor Example Design
// and2_verilog
// and2.v - Top-level file of simple 2-input AND gate //
/////////////////////////////////////////////////////////////////

module and2 (
    input a,
    input b,
    input clk,
    input reset,
    output reg c = 1'b0
);

    reg a_reg, b_reg = 1'b0;

    always@(posedge clk)
        if (reset) begin
            a_reg <= 1'b0;
            b_reg <= 1'b0;
            c <= 1'b0;
        end else begin
            a_reg <= a;
            b_reg <= b;
            c <= a_reg & b_reg;
        end
endmodule

```

Figure 55. Interact with the project file opened with gedit

Note: In a future release, we plan to embed the third-party editors within Raptor windowing system itself.

## 2 Raptor Synthesis

### 2.1 Introduction

Synthesis is the process of converting an RTL design into a gate-level representation.

As mentioned in [Section 1.2.1 “Project and Tcl Modes”](#), there are two design flow modes available in the Raptor design suite:

- Project mode
- Tcl mode

In Project mode, a project is created using the Raptor EDA tool using the GUI. This approach automatically saves the design at regular intervals. It also automatically manages the source files, and also generates reports as necessary.

Tcl mode is executed using Tcl commands or scripts. In Tcl mode, the user still has full control of the design flow as with Project mode, but the Raptor EDA tool does not automatically manage source files or report the design state. Rather, in Tcl mode, the Raptor EDA tool can be opened at each stage of the design in order to manage the source files and perform design analysis and constraints assignments.

#### 2.1.1 Using Synthesis

The Raptor design suite includes a synthesis tool used to synthesize the design. The tool manages the run data automatically and allows for repeated run attempts with various RTL source versions and target devices.

This section describes how to use the Raptor design suite to set up and run Raptor synthesis.

#### 2.1.2 Running Synthesis

A *run* defines and configures the various aspects of the design that are used during synthesis. A *synthesis run* defines the following:

- Target device during synthesis
- Synthesis constraint to be applied
- Launching a synthesis run
- Controlling the synthesis results

#### 2.1.3 Incremental Synthesis

Raptor synthesis can be run incrementally. In this mode, the tool detects when the design has changed and only then does it re-run synthesis on sections of the design that have changed.

Running in incremental synthesis mode means that for designs with small changes, the run time of the synthesis can be significantly reduced.

#### 2.1.4 Analyzing Synthesis Results

After the synthesis run is complete, the results can be viewed and analyzed using the Reports window. This window contains the results of the synthesis.

## 2.1.5 Exploring the Logic

The Raptor design suite provides one physical view of the device, the P&R view. The P&R window provides a graphical view of the device, placed logic objects, and connectivity. It can be accessed from the Task menu when routing has finished.

## 2.1.6 Multi-Threading in RTL Synthesis

ABC-DE thread count can be adjusted.

## 2.2 Synthesis Attributes

In the Raptor Design Suite, the synthesis tool supports several types of attributes. These attributes have the same syntax and the same behavior.

- If Raptor synthesis supports the attribute, it uses that attribute and creates logic that reflects the used attribute.
- If the specified attribute is not recognized by the tool, the Raptor synthesis tool passes the attribute and its value to the generated netlist.

### 2.2.1 Supported Attributes

The following subsections show examples for the FULL\_CASE and PARALLEL\_CASE attributes.

#### 2.2.1.1 FULL\_CASE (Verilog Only)

```
module top (y, a, b, c, sel);
output y;
input [1:0] sel;
input a, b, c;
reg y;

always @(a or b or c or sel)
  case (sel) // synopsys full_case
    2'b00 : y = a;
    2'b01 : y = b;
    2'b10 : y = c;
  endcase
endmodule
```

#### 2.2.1.2 PARALLEL\_CASE (Verilog Only)

```
module top (res2, res1, res0, sel);
output res2, res1, res0;
input [2:0] sel;
reg res2, res1, res0;

always @(sel) begin
  {res2, res1, res0} = 3'b0
  case2 (sel) // synopsys parallel_case
    3'b1???: res2 = 1'b1;
    3'b?1?: res1 = 1'b1;
    3'b??1: res0 = 1'b1;
  endcase
endmodule
```

---

```
    end
endmodule
```

## 2.3 HDL Coding Techniques

The Raptor design suite contains Hardware Description Language (HDL) coding techniques which let the user:

- Take advantage of the various architectural features of Rapid Silicon devices.
- Easily describe common functionality found in digital logic circuits.
- Templates are available from the Raptor design suite.

### 2.3.1 Advantages of VHDL

- Enforces stricter rules, in particular strongly typed, less permissive and error-prone
- Initialization of RAM components in the HDL source code is easier (Verilog initial blocks are less convenient)
- Package support
- Custom types
- Enumerated types

### 2.3.2 Advantages of Verilog

- C-like syntax
- More compact code
- Block commenting
- No heavy component instantiation as in VHDL

### 2.3.3 Advantages of SystemVerilog

- More compact code compared to Verilog
- Structures and enumerated types for better scalability
- Interfaces for higher level of abstraction
- Supported in Raptor synthesis

### 2.3.4 Flip-Flops, Registers, and Latches

The Raptor synthesis tool recognizes flip-flops and registers with the following control elements:

- Rising or falling-edge clocks
- Asynchronous set/reset
- Synchronous set/reset
- Clock enable

## 2.3.5 Latches

The Raptor log file reports the type and size of all confirmed latches in the design. There are also inferred latches, which are often the result of HDL coding mistakes, such as incomplete if or case statements.

## 2.3.6 Shift Registers

A Shift Register is a series of Flip-Flops organized as a serial string that allows for the propagation of data across a fixed number of latency stages. In contrast, in Dynamic Shift Registers, the length of the propagation chain varies dynamically during circuit operation.

### 2.3.6.1 Static Shift Register Elements

A static Shift Register usually involves:

- A clock
- An optional clock enable
- A serial data input
- A serial data output

## 2.3.7 Dynamic Shift Registers

A dynamic shift register is a shift register the length of which can vary dynamically during circuit operation. A dynamic shift register can be viewed as a chain of flip-flops along with a multiplexer that selects, in a given clock cycle, the stage at which data is to be extracted from the chain.

The Raptor synthesis tool can infer dynamic shift registers of any length.

## 2.3.8 Multipliers

Raptor synthesis infers multiplier macros from multiplication operators in the source code. The resulting signal width equals the sum of the two operand sizes. For example, multiplying a 16-bit signal by an 8-bit signal produces a result of 24 bits.

## 2.3.9 Memories

Raptor synthesis infers Block RAM memories for the following kinds of behavioral memory examples:

Single port RAM with asynchronous read and with read address registered

Single port RAM with synchronous read

Single port RAM with synchronous read and read address registered

Simple dual port RAM with asynchronous read and with read address registered

Simple dual port RAM with synchronous read

Simple dual port RAM with synchronous read and with read address registered

True dual port RAM with asynchronous read and with read address registered

True dual port RAM with synchronous read

True dual port RAM with synchronous read and with read address registered

Each type of memory configuration is described in the following subsections.

### 2.3.9.1 Single Port RAM with Asynchronous Read and with Read Address Registered

The code used to support the single port RAM configuration with asynchronous read with read address registered is described below.

```
module rams_sp_async_read_reg_addr_1024x32 (clk, we, addr, di, dout);
input clk;
input we;
input [9:0] addr;
input [31:0] di;
output [31:0] dout;
reg [9:0] addr_reg;
reg [31:0] RAM [1023:0];
always @(posedge clk)
begin
addr_reg <= addr;
if (we)
RAM[addr] <= di;
end
assign dout = RAM[addr_reg];
endmodule
```

### 2.3.9.2 Single Port RAM with Synchronous Read

The code used to support the single port RAM configuration with synchronous read is described below.

```
module rams_sp_sync_read_1024x32 (clk, we, addr, di, dout);
input clk;
input we;
input [9:0] addr;
input [31:0] di;
output reg [31:0] dout;
reg [31:0] RAM [1023:0];
always @(posedge clk)
begin
if (we)
RAM[addr] <= di;
else
dout = RAM[addr];
end
Endmodule
```

### 2.9.3.3 Single Port RAM with Synchronous Read and Read Address Registered

The code used to support the single port RAM configuration with synchronous read with read address registered is described below.

```
module rams_sp_sync_read_reg_addr_1024x32 (clk, we, addr, di, dout);
input clk, we;
input [9:0] addr;
input [31:0] di;
output reg [31:0] dout;
reg [9:0] addr_reg;
reg [31:0] RAM [1023:0];
always @(posedge clk)
begin
addr_reg <= addr;
if (we)
RAM[addr] <= di;
else
dout = RAM[addr_reg];
end
endmodule
```

### 2.3.9.4 Simple Dual Port RAM with Asynchronous Read and with Read Address Registered

The code used to support the simple dual port RAM configuration with asynchronous read with read address registered is described below.

```
module ram_simple_dp_async_reg_read_4096x32 (clk, we, read_addr, write_addr, din, dout);
input clk, we;
input [11:0] read_addr, write_addr;
input [31:0] din;
output [31:0] dout;
reg [31:0] ram [4095:0];
reg [11:0] read_addr_reg;
always @(posedge clk)
begin
read_addr_reg <= read_addr;
if (we)
ram[write_addr] <= din;
end
assign dout = ram[read_addr_reg];
endmodule
```

### 2.3.9.5 Simple Dual port RAM with Synchronous Read

The code used to support the simple dual port RAM configuration with synchronous read is described below.

```
module ram_simple_dp_sync_read_4096x32 (clk, we, read_addr, write_addr, din, dout);
input clk, we;
input [11:0] read_addr, write_addr;
input [31:0] din;
output reg [31:0] dout;
reg [31:0] ram [4095:0];
always @(posedge clk)
begin
if (we)
ram[write_addr] <= din;
else
dout = ram[read_addr];
end
endmodule
```

### 2.3.9.6 Simple Dual Port RAM with Synchronous Read and with Read Address Registered

The code used to support the simple dual port RAM configuration with synchronous read with read address registered is described below.

```
module ram_simple_dp_sync_reg_read_4096x32 (clk, we, read_addr, write_addr, din, dout);
input clk, we;
input [11:0] read_addr, write_addr;
input [31:0] din;
output reg [31:0] dout;
reg [31:0] ram [4095:0];
reg [11:0] read_addr_reg;
always @(posedge clk)
begin
read_addr_reg <= read_addr;
if (we)
ram[write_addr] <= din;
else
dout <= ram[read_addr_reg];
end
endmodule
```

### 2.3.9.7 True Dual Port RAM with Asynchronous Read and with Read Address Registered

The code used to support the true dual port RAM configuration with asynchronous read with read address registered is described below.

---

```

module ram_tdp_async_reg_read_4096x32 (clkA, clkB, weA, weB, addrA, addrB, dinA, dinB, doutA, doutB);
input clkA, clkB, weA, weB;
input [11:0] addrA, addrB;
input [31:0] dinA, dinB;
output [31:0] doutA, doutB;
reg [11:0] reg_addrA, reg_addrB;
reg [31:0] ram [4095:0];
always @(posedge clkA)
begin
reg_addrA <= addrA;
if (weA)
ram[addrA] <= dinA;
end
always @(posedge clkB)
begin
reg_addrB <= addrB;
if (weB)
ram[addrB] <= dinB;
end
assign doutA = ram[reg_addrA];
assign doutB = ram[reg_addrB];
endmodule

```

#### 2.3.9.8 True Dual Port RAM with Synchronous Read

The code used to support the true dual port RAM configuration with synchronous read is described below.

```

module ram_tdp_sync_read_4096x32 (clkA, clkB, weA, weB, addrA, addrB, dinA, dinB, doutA, doutB);
input clkA, clkB, weA, weB;
input [11:0] addrA, addrB;
input [31:0] dinA, dinB;
output reg [31:0] doutA, doutB;
reg [31:0] ram [4095:0];
always @(posedge clkA)
begin
if (weA)
ram[addrA] <= dinA;
else
doutA = ram[addrA];
end

```

---

```

always @(posedge clkB)
begin
if (weB)
ram[addrB] <= dinB;
else
doutB <= ram[addrB];
end
endmodule

```

### 2.3.9.9 True Dual Port RAM with Synchronous Read and with Read Address Registered

The code used to support the true dual port RAM configuration with synchronous read with read address registered is described below.

```

module ram_tdp_sync_reg_read_4096x32 (clkA, clkB, weA, weB, addrA,addrB, dinA, dinB, doutA, doutB);
input clkA, clkB, weA, weB;
input [11:0] addrA, addrB;
input [31:0] dinA, dinB;
output reg [31:0] doutA, doutB;
reg [11:0] reg_addrA, reg_addrB;
reg [31:0] ram [4095:0];
always @(posedge clkA)
begin
reg_addrA <= addrA;
if (weA)
ram[addrA] <= dinA;
else
doutA <= ram[reg_addrA];
end
always @(posedge clkB)
begin
reg_addrB <= addrB;
if (weB)
ram[addrB] <= dinB;
else
doutB <= ram[reg_addrB];
end
endmodule

```

## 2.4 VHDL-2008 Hardware Language Support

Raptor synthesis supports a synthesizable subset of the VHDL-2008 standard.

## 2.4.1 Setting up Raptor to use VHDL-2008

There are several ways to run VHDL-2008 files with Raptor. The most common is to access the Properties window and set the type as “VHDL 2008” from the drop-down menu. This will configure the Raptor tool for VHDL-2008.

The Raptor design suite supports most of the VHDL-2008 features. It covers also previous releases such as VHDL87, VHDL93, and VHDL2k.

## 2.5 Verilog Language Support

Raptor supports most Verilog 2001 synthesis constructs

## 2.6 SystemVerilog Support

The Raptor design suite supports the synthesizable subset of SystemVerilog RTL versions 2005, 2009, 2012, 2017.

## 2.7 Mixed Language Support

Raptor synthesis supports VHDL and Verilog mixed language projects.

## 2.8 Litex Support

Litex is an open-source SoC generator. It provides a convenient and efficient infrastructure to create the Gemini FPGA core to explore various digital design architectures and create full FPGA based systems.

Litex uses the **Migen** package to translate the python to HDL. Migen is a Python-based tool that automates further the VLSI design process using FHDL libraries.

Litex framework contains a pool of IP Cores that can be used standalone and with the Litex framework to build complex systems. Moreover, Litex install contains a bunch of open-source CPUs that can be plugged in the system through the python packages installed in the Litex install area.

### 2.8.1 Litex SoC Integration

Litex offers multiple command line tools. **Litex\_soc\_gen** is the command line tool used to generate an SoC with custom CPU, Interconnect and peripheral options.

#### 2.8.2.1 litex\_soc Command

The Litex SoC generation command is as follows:

```
litex_soc_gen --cpu-type=vexriscv --bus-standard=axi-lite
```



```

1 // Auto-Generated by:          // Build your hardware, easily!
2 // Device: | https://github.com/enjoy-digital/litex
3 // LiteX sha1: e83225a7
4 // Date:   2023-01-23 15:24:20
5 //
6 //
7 //
8 //
9 // Filename : litex_soc.v
10 // Device  :
11 // LiteX sha1 : e83225a7
12 // Date    : 2023-01-23 15:24:20
13 //
14
15 `timescale 1ns / 1ps
16
17 /**
18 // Module
19 /**
20
21 module litex_soc (
22     input wire      clk,
23     input wire      rst,
24     output reg      uart_tx,
25     input wire      uart_rx,
26     input wire      mmap.s_awvalid,
27     output wire     mmap.s_awready,
28     input wire [31:0] mmap.s_awaddr,
29     input wire [2:0]  mmap.s_awprot,
30     input wire      mmap.s_awvalid,
31     output wire     mmap.s_awready,
32     input wire [31:0] mmap.s_wdata,
33     input wire [3:0]  mmap.s_wstrb,
34     output wire     mmap.s_bvalid,
35     input wire      mmap.s_bready,
36     output wire [1:0] mmap.s_bresp,
37     input wire      mmap.s_arvalid,
38     output wire     mmap.s_arready,
39     input wire [31:0] mmap.s_araddr,
40     input wire [2:0]  mmap.s_arprot,
41     output wire     mmap.s_rvalid,
42     input wire      mmap.s_rready,
43     output wire [1:0] mmap.s_rresp,
44     output wire [31:0] mmap.s_rdata,
45     output wire      mmap.m_awvalid,
46     input wire      mmap.m_awready,
47     output wire [31:0] mmap.m_awaddr,
48     output wire [2:0]  mmap.m_awprot,

```

Figure 56. Litex Inputs and Outputs

## 2.8.2 Litex Simulation

The **Litex\_sim** command line tool enables the user to create a custom SoC and the verification environment for it. Below command generates an SoC with a Vexriscv CPU and an axi-lite bus structure.

### 2.8.2.1 litex\_sim Command

The Litex simulation command is as follows:

```
litex_sim_rs --cpu-type=vexriscv --bus-standard=axi-lite
```



Build your hardware, easily!

(c) Copyright 2012-2022 Enjoy-Digital  
(c) Copyright 2007-2015 M-Labs

BIOS built on Jan 20 2023 18:44:13  
BIOS CRC passed (47176748)

Litex git sha1: 611b84cc

----- SoC -----  
CPU: VexRiscv @ 1MHz  
BUS: AXI-LITE 32-bit @ 4GiB  
CSR: 32-bit data  
ROM: 128KiB  
SRAM: 8KiB

----- Boot -----  
Booting from serial...  
Press Q or ESC to abort boot completely.  
sL5DdSMmkekro  
Timeout  
No boot medium found

----- Console -----  
litex> █

Figure 57. Litex Front Page

### 2.8.3 Adding Custom IP

In order to add a custom IP as a peripheral to the system, modify the `litex_sim.py` command as shown in the example below. For this exercise a `migen` wrapper must be around the verilog.

```
# AXI RAM -----
if with_axi_ram:
    s_axi= axi.AXIInterface(data_width=32, address_width=16)
    self.submodules.axi_ram = AXIRAM(platform, s_axi)
    self.bus.add_slave("axi_ram", s_axi, region=SoCRegion(
        origin = 0x50000000,
        size = 0x1000,
        cached = True,
    ))
```

Figure 58. Adding Custom IP

The following example adds an `axi_ram` as a slave to the interconnect at the base address of `0x50000000` with a size of `0x1000`. This can be simulated using the console as shown above and can also modify the firmware to test the system.

The RAM simulation is shown in [Figure 59](#).



Figure 59. RAM Simulation Environment

## 2.8.4 Raptor IP Catalog

The Raptor IP catalog hosts a suite of IPs mostly based on AXI bus standard. All these IPs are parameterizable and can be generated using the IP Configurator window. These generated IPs are available to create system level designs and can also be used to integrate in LiteX SoC framework.

Raptor IP catalog contains a variety of IPs belonging to different categories.

- Processor IP (CPU, DSP)
- Memory IP (BRAM, ROM, FIFO)
- Interconnect IP (bus, switch, bridge)
- Peripheral IP (UART, SPI, I2C, Ethernet)

Generated IP hierarchy hosts, IP user guide document, constraint file, simulation source and the IP source files. IP Source files are visible in the IP Instance window under the name of the IP.



Figure 60. Example of axi\_ram IP Structure

### 2.8.5. IP Catalog Simulations

Once an IP is generated a user can simulate the IP from Raptor. Generated IPs are available in the IP Instance window, Simulate IP button is available when you right click on any of the IP from IP Instance window.



Figure 61. Simulating IP Catalog IP

Once the IP is simulated the user can view the generated waveform with the View waveform button as shown in the above figure. This will pop up the waveform of the IP you simulated as shown below in figure 57.



Figure 62. Simulation of IP

## 3 Raptor Place and Route

### 3.1 Introduction

Raptor place and route (P&R) is the process of determining locations of post-synthesized gates and connecting them by following the netlist description. Raptor P&R is timing-driven.

There are two ways to setup and run P&R:

- Use Project Mode, selecting options from the Raptor Integrated Design Environment (IDE).
- Use Tcl Mode, applying Tool Command Language (Tcl) commands or scripts, and controlling your own design files.

### 3.2 P&R Methodology

The Raptor design suite invokes Versatile Place and Route (VPR) to do place and route. VPR is an open-source academic CAD tool designed for the exploration of new FPGA architectures and CAD algorithms, which performs:

- Packing
- Placement
- Routing

For details about VPR, please visit <https://docs.verilogorouting.org/en/latest/vpr/>.

### 3.3 Use P&R

Each stage of P&R can be run within Raptor in 2 ways:

- Use IDE GUI task panel
- Use command lines
  - pack
  - place
  - route

Raptor supports all legal options of VPR. These options can be set with by executing the following command:

```
pnr_options <option_list>
```

All legal options and their description and usage can be found at: [https://docs.verilogorouting.org/en/latest/vpr/command\\_line\\_usage/](https://docs.verilogorouting.org/en/latest/vpr/command_line_usage/)

Below are some common and useful options:

#### 3.3.1 General Options

This section lists the general place and route options.

##### **--target\_utilization <float>**

Sets the target device utilization. This corresponds to the maximum target fraction of device grid-tiles to be used. A value of 1.0 means the smallest device (which fits the circuit) will be used.

Default: 1

**--constant\_net\_method {global | route}**

Specifies how constant nets (i.e., those driven to a constant value) are handled:

- global: Treat constant nets as globals (not routed)

- route: Treat constant nets

as normal nets (routed) Default:

global

**--clock\_modeling {ideal | route | dedicated\_network}**

Specifies how clock nets are handled:

- ideal: Treat clock pins as ideal (i.e., no routing delays on clocks)
- route: Treat clock nets as normal nets (i.e., routed using inter-block routing)
- dedicated\_network: Use the architectures dedicated clock network

(experimental) Default: ideal (Only supported mode currently)

**--terminate\_if\_timing\_fails {on, off}**

Controls whether VPR should terminate if timing is not met after routing.

Default: off

### 3.3.2 Filename Options

This section lists the filename place and route options.

**--outfile\_prefix <string>**

Prefix for output files

### 3.3.3 Netlist Options

This section lists the netlist place and route options.

**--absorb\_buffer\_luts {on | off}**

Controls whether LUTs programmed as wires (i.e., implementing logical identity) should be absorbed into the downstream logic.

Usually, buffer LUTs are introduced in BLIF circuits by upstream tools in order to rename signals (like assign statements in Verilog). Absorbing these buffers reduces the number of LUTs required to implement the circuit.

Ocassionally buffer LUTs are inserted for other purposes, and this option can be used to preserve them. Disabling buffer absorption can also improve the matching between the input and post-synthesis netlist/SDF.

Default: on

**--const\_gen\_inference {none | comb | comb\_seq}**

Controls how constant generators are inferred/detected in the input circuit. Constant generators and the signals they drive are not considered during timing analysis.

- none: No constant generator inference will occur. Any signals which are actually constants will be treated as non-constants.

- comb: VPR will infer constant generators from combinational blocks with no non-constant inputs (always safe).
- comb\_seq: VPR will infer constant generators from combinational and sequential blocks with only constant inputs (usually safe).

**NOTE:** In rare circumstances comb\_seq could incorrectly identify certain blocks as constant generators. This would only occur if a sequential netlist primitive has an internal state which evolves completely independently of any data input (e.g., a hardened LFSR block, embedded thermal sensor).

Default: comb\_seq

#### **--sweep\_dangling\_primary\_ios {on | off}**

Controls whether the circuits dangling primary inputs and outputs (i.e., those who do not drive, or are not driven by anything) are swept and removed from the netlist.ch

Disabling sweeping of primary inputs/outputs can improve the matching between the input and post-synthesis netlists. This is often useful when performing formal verification.

See also:

--sweep\_constant\_primary\_outputs

Default: on

#### **--sweep\_dangling\_nets {on | off}**

Controls whether dangling nets (i.e., those who do not drive, or are not driven by anything) are swept and removed from the netlist.

Default: on

#### **--sweep\_dangling\_blocks {on | off}**

Controls whether dangling blocks (i.e., those who do not drive anything) are swept and removed from the netlist.

Default: on

#### **--sweep\_constant\_primary\_outputs {on | off}**

Controls whether primary outputs driven by constant values are swept and removed from the netlist.

See also:

--sweep\_dangling\_primary\_ios

Default: off

#### **--netlist\_verbosity <int>**

Controls the verbosity of netlist processing (constant generator detection, swept netlist components). High values produce more detailed output.

Default: 1

### 3.3.4 Packing Options

This section lists the packing place and route options.

#### **--connection\_driven\_clustering {on | off}**

Controls whether or not AAPack prioritizes the absorption of nets with fewer connections into a complex logic block over nets with more connections.

Default: on

#### **--allow\_unrelated\_clustering {on | off | auto}**

Controls whether primitives with no attraction to a cluster may be packed into it.

Unrelated clustering can increase packing density (decreasing the number of blocks required to implement the circuit) but can significantly impact routability.

When set to auto VPR automatically decides whether to enable unrelated clustering based on the targetted device and achieved packing density.

Default: auto

#### **--alpha\_clustering <float>**

A parameter that weighs the optimization of timing vs area.

A value of 0 focuses solely on area, a value of 1 focuses entirely on timing.

Default: 0.75

#### **--beta\_clustering <float>**

A tradeoff parameter that controls the optimization of smaller net absorption vs. the optimization of signal sharing.

A value of 0 focuses solely on signal sharing, while a value of 1 focuses solely on absorbing smaller nets into a cluster. This option is meaningful only when connection\_driven\_clustering is on.

Default: 0.9

#### **--timing\_driven\_clustering {on|off}**

Controls whether or not to do timing driven clustering

Default: on

#### **--cluster\_seed\_type {blend | timing | max\_inputs | max\_pins | max\_input\_pins | blend2}**

Controls how the packer chooses the first primitive to place in a new cluster.

- timing means that the unclustered primitive with the most timing-critical connection is used as the seed.
- max\_inputs means the unclustered primitive that has the most connected inputs is used as the seed.
- blend uses a weighted sum of timing criticality, the number of tightly coupled blocks connected to the primitive, and the number of its external inputs.
- max\_pins selects primitives with the most number of pins (which may be used, or unused).
- max\_input\_pins selects primitives with the most number of input pins (which may be used, or unused)

- blend2 An alternative blend formulation taking into account both used and unused pin counts, number of tightly coupled blocks and criticality.

Default: blend2 if timing\_driven\_clustering is on; max\_inputs otherwise.

#### **--clustering\_pin\_feasibility\_filter {on | off}**

Controls whether the pin counting feasibility filter is used during clustering. When enabled the clustering engine counts the number of available pins in groups/classes of mutually connected pins within a cluster. These counts are used to quickly filter out candidate primitives/atoms/molecules for which the cluster has insufficient pins to route (without performing a full routing). This reduces packing run-time.

Default: on

#### **--balance\_block\_type\_utilization {on, off, auto}**

Controls how the packer selects the block type to which a primitive will be mapped if it can potentially map to multiple block types.

- on : Try to balance block type utilization by picking the block type with the (currently) lowest utilization.
- off : Do not try to balance block type utilization
- auto: Dynamically enabled/disabled (based on

density) Default: auto

#### **--target\_ext\_pin\_util { auto | <float> | <float>,<float> | <string>:<float> | <string>:<float>,<float> }**

Sets the external pin utilization target (fraction between 0.0 and 1.0) during clustering. This determines how many pins the clustering engine will aim to use in a given cluster before closing it and opening a new cluster.

Setting this to 1.0 guides the packer to pack as densely as possible (i.e. it will keep adding molecules to the cluster until no more can fit). Setting this to a lower value will guide the packer to pack less densely, and instead create more clusters. In the limit setting this to 0.0 will cause the packer to create a new cluster for each molecule.

Typically packing less densely improves routability, at the cost of using more clusters. This option can take several different types of values:

auto VPR will automatically determine appropriate target utilizations.

- <float> specifies the target input pin utilization for all block types.

For example: 0.7 specifies that all blocks should aim for 70% input pin utilization.

- <float>,<float> specifies the target input and output pin utilizations respectively for all block types.

For example: 0.7, 0.9 specifies that all blocks should aim for 70% input pin utilization, and 90% output pin utilization.

- <string>:<float> and <string>:<float>,<float> specify the target pin utilizations for a specific block type (as above).

For example: clb:0.7 specifies that only clb type blocks should aim for 70% input pin utilization.

clb:0.7,0.9 specifies that only clb type blocks should aim for 70% input pin utilization, and 90% output pin utilization.

**NOTE:** If a pin utilization target is unspecified it defaults to 1.0 (i.e., 100% utilization)

For example:

1.7 leaves the output pin utilization unspecified, which is equivalent to 0.7,1.0.

clb:0.7,0.9 leaves the pin utilizations for all other block types unspecified, so they will assume a default utilization of 1.0,1.0.

This option can also take multiple space-separated values. For example:

--target\_ext\_pin\_util clb:0.5 dsp:0.9,0.7 0.8

would specify that clb blocks use a target input pin utilization of 50%, dsp blocks use a target of 90% and 70% for inputs and outputs respectively, and all other blocks use an input pin utilization target of 80%.

**NOTE:** This option is only a guideline. If a molecule (e.g., a carry-chain with many inputs) would not otherwise fit into a cluster type at the specified target utilization the packer will fall back to using all pins (i.e. a target utilization of 1.0).

**NOTE:** This option requires --clustering\_pin\_feasibility\_filter to be enabled.

Default: auto

#### **--pack\_prioritize\_transitive\_connectivity {on | off}**

Controls whether transitive connectivity is prioritized over high-fanout connectivity during packing. Default: on

#### **--pack\_high\_fanout\_threshold {auto | <int> | <string>:<int>}**

Defines the threshold for high fanout nets within the packer.

This option can take several different types of values:

- auto VPR will automatically determine appropriate thresholds.
- <int> specifies the fanout threshold for all block

types. For example:

64 specifies that a threshold of 64 should be used for all blocks.

- <string>:<float> specifies the threshold for a specific block type.

For example:

clb:16 specifies that clb type blocks should use a threshold of 16.

This option can also take multiple space-separated values. For example:

--pack\_high\_fanout\_threshold 128 clb:16

would specify that clb blocks use a threshold of 16, while all other blocks (e.g., DSPs/RAMs) would use a threshold of 128.

Default: auto

#### **--pack\_transitive\_fanout\_threshold <int>**

Packer transitive fanout threshold.

Default: 4

**--pack\_feasible\_block\_array\_size <int>**

This value is used to determine the max size of the priority queue for candidates that pass the early filter legality test but not the more detailed routing filter.

Default: 30

**--pack\_verbosity <int>**

Controls the verbosity of clustering output. Larger values produce more detailed output, which may be useful for debugging architecture packing problems.

Default: 2

**--write\_block\_usage <file>**

Writes out to the file under path <file> cluster-level block usage summary in machine readable (JSON or XML) or human readable (TXT) format. Format is selected based on the extension of <file>.

### 3.3.5 Placer Options

This section lists the placer place and route options.

**--seed <int>**

Sets the initial random seed used by the placer. Default: 1

**--enable\_timing\_computations {on | off}**

Controls whether or not the placement algorithm prints estimate of the circuit speed of the placement it generates. This setting affects statistical output only, not optimization behavior.

Default: on if timing-driven placement is specified, off otherwise.

**--inner\_num <float>**

The number of moves attempted at each temperature in placement can be calculated from inner\_num scaled with circuit size or device-circuit size as specified in place\_effort\_scaling.

Changing inner\_num is the best way to change the speed/quality tradeoff of the placer, as it leaves the highly-efficient automatic annealing schedule on and simply changes the number of moves per temperature.

Specifying -inner\_num 10 will slow the placer by a factor of 10 while typically improving placement quality only by 10% or less (depends on the architecture). Hence users more concerned with quality than CPU time may find this a more appropriate value of inner\_num.

Default: 0.5

**--place\_effort\_scaling {circuit | device\_circuit}**

Controls how the number of placer moves level scales with circuit and device size:

- circuit: The number of moves attempted at each temperature is  $\text{inner\_num} * \text{num\_blocks}^{(4/3)}$  in the circuit.
- device\_circuit: The number of moves attempted at each temperature is  $\text{inner\_num} * \text{grid\_size}^{(2/3)} * \text{num\_blocks}^{(4/3)}$  in the circuit.

The number of blocks in a circuit is the number of pads plus the number of clbs.

Default: circuit

#### **--init\_t <float>**

The starting temperature of the anneal for the manual annealing schedule.

Default: 100.0

#### **--exit\_t <float>**

The manual anneal will terminate when the temperature drops below the exit temperature. Default: 0.01

#### **--alpha\_t <float>**

The temperature is updated by multiplying the old temperature by alpha\_t when the manual annealing schedule is enabled.

Default: 0.8

#### **--fix\_pins {free | random}**

Controls how the placer handles I/O pads during placement.

- free: The placer can move I/O locations to optimize the placement.
- random: Fixes I/O pads to arbitrary locations and does not allow the placer to move them during the anneal (models the effect of poor board-level I/O constraints).

**NOTE:** The fix\_pins option is also used to accept a third argument - a place file that specifies where I/O pins should be placed. This argument is no longer accepted by fix\_pins. Instead, the fix\_clusters option can now be used to lock down I/O pins.

Default: free.

#### **--fix\_clusters {<file.place>}**

Controls how the placer handles blocks (of any type) during placement.

<file.place>: A path to a file listing the desired location of blocks in the netlist.

This place location file is in the same format as a normal placement file but does not require the first two lines which are normally at the top of a placement file that specify the netlist file, netlist ID, and array size.

#### **--place\_algorithm {bounding\_box | criticality\_timing | slack\_timing}**

Controls the algorithm used by the placer.

- `bounding_box` Focuses purely on minimizing the bounding box wirelength of the circuit. Turns off timing analysis if specified.
- `criticality_timing` Focuses on minimizing both the wirelength and the connection timing costs (criticality \* delay).
- `slack_timing` Focuses on improving the circuit slack values to reduce critical path delay. Default: `criticality_timing`

**--place\_quench\_algorithm {bounding\_box | criticality\_timing | slack\_timing}**

Controls the algorithm used by the placer during placement quench. The algorithm options have identical functionality as the ones used by the option `--place_algorithm`. If specified, it overrides the option `--place_algorithm` during placement quench.

Default: `criticality_timing`

**--place\_chan\_width <int>**

Tells VPR how many tracks a channel of relative width 1 is expected to complete routing of this circuit. VPR will then place the circuit only once, and repeatedly try routing the circuit as usual.

Default: 100

**--place\_rlim\_escape <float>**

The fraction of moves which are allowed to ignore the region limit. For example, a value of 0.1 means 10% of moves are allowed to ignore the region limit.

Default: 0.0

Setting any of the following options selects Dusty's annealing schedule.

**--alpha\_min <float>**

The minimum (starting) update factor (alpha) used. Ranges between 0 and alpha\_max.

Default: 0.2

**--alpha\_max <float>**

The maximum (stopping) update factor (alpha) used after which simulated annealing will complete. Ranges between alpha\_min and 1.

Default: 0.9

**--alpha\_decay <float>**

The rate at which alpha will approach 1:  $\text{alpha}(n) = 1 - (1 - \text{alpha}(n-1)) * \text{alpha\_decay}$  Ranges between 0 and 1.

Default: 0.7

**--anneal\_success\_min <float>**

The minimum success ratio after which the temperature will reset to maintain the target success ratio. Ranges between 0 and anneal\_success\_target.

Default: 0.1

**--anneal\_success\_target <float>**

The temperature after each reset is selected to keep this target success ratio. Ranges between anneal\_success\_target and 1.

Default: 0.25

### 3.3.6 Timing-Driven Placer Options

The following options are only valid when the placement engine is in timing-driven mode (timing-driven placement is used by default).

**--timing\_tradeoff <float>**

Controls the trade-off between bounding box minimization and delay minimization in the placer.

A value of 0 makes the placer focus completely on bounding box (wirelength) minimization, while a value of 1 makes the placer focus completely on timing optimization.

Default: 0.5

**--recompute\_crit\_iter <int>**

Controls how many temperature updates occur before the placer performs a timing analysis to update its estimate of the criticality of each connection.

Default: 1

**--inner\_loop\_recompute\_divider <int>**

Controls how many times the placer performs a timing analysis to update its criticality estimates while at a single temperature.

Default: 0

**--td\_place\_exp\_first <float>**

Controls how critical a connection is considered as a function of its slack, at the start of the anneal.

If this value is 0, all connections are considered equally critical. If this value is large, connections with small slacks are considered much more critical than connections with small slacks. As the anneal progresses, the exponent used in the criticality computation gradually changes from its starting value of td\_place\_exp\_first to its final value of --td\_place\_exp\_last.

Default: 1.0

**--td\_place\_exp\_last <float>**

Controls how critical a connection is considered as a function of its slack, at the end of the anneal.

See also

--td\_place\_exp\_first

Default: 8.0

**--place\_delay\_model {delta, delta\_override}**

Controls how the timing-driven placer estimates delays.

- delta The router is used to profile delay from various locations in the grid for various differences in position
- delta\_override Like delta but also includes special overrides to ensure effects of direct connects between blocks are accounted for. This is potentially more accurate but is more complex and depending on the architecture (e.g. number of direct connects) may increase place run-time.

Default: delta

**--place\_delay\_model\_reducer {min, max, median, arithmean, geomean}**

When calculating delta delays for the placement delay model how are multiple values combined?

Default: min

**--place\_delay\_offset <float>**

A constant offset (in seconds) applied to the placer's delay model.

Default: 0.0

**--place\_delay\_ramp\_delta\_threshold <float>**

The delta distance beyond which --place\_delay\_ramp is applied. Negative values disable the placer delay ramp.

Default: -1

**--place\_delay\_ramp\_slope <float>**

The slope of the ramp (in seconds per grid tile) which is applied to the placer delay model for delta distance beyond --place\_delay\_ramp\_delta\_threshold.

Default: 0.0e-9

**--place\_tsu\_rel\_margin <float>**

Specifies the scaling factor for cell setup times used by the placer. This effectively controls whether the placer should try to achieve extra margin on setup paths. For example, a value of 1.1 corresponds to requesting 10% setup margin.

Default: 1.0

**--place\_tsu\_abs\_margin <float>**

Specifies an absolute offset added to cell setup times used by the placer. This effectively controls whether the placer should try to achieve extra margin on setup paths. For example, a value of 500e-12 corresponds to requesting an extra 500ps of setup margin.

Default: 0.0

**--post\_place\_timing\_report <file>**

Name of the post-placement timing report file to generate (not generated if unspecified).

### 3.3.7 Router Options

VPR uses a negotiated congestion algorithm (based on Pathfinder) to perform routing.

**NOTE:** By default the router performs a binary search to find the minimum routable channel width. To route at a fixed channel width use --route\_chan\_width.

See also [Section 3.3.8 “Timing-Driven Router Options”](#).

**--max\_router\_iterations <int>**

The number of iterations of a Pathfinder-based router that will be executed before a circuit is declared unrouteable (if it hasn't routed successfully yet) at a given channel width.

Speed-quality trade-off: reducing this number can speed up the binary search for minimum channel width, but at the cost of some increase in final track count. This is most effective if -initial\_pres\_fac is simultaneously increased. Increase this number to make the router try harder to route heavily congested designs.

Default: 50

**--first\_iter\_pres\_fac <float>**

Similar to --initial\_pres\_fac. This sets the present overuse penalty factor for the very first routing iteration. --initial\_pres\_fac sets it for the second iteration.

**NOTE:** A value of 0.0 causes congestion to be ignored on the first routing iteration.

Default: 0.0

**--initial\_pres\_fac <float>**

Sets the starting value of the present overuse penalty factor.

Speed-quality trade-off: increasing this number speeds up the router, at the cost of some increase in final track count. Values of 1000 or so are perfectly reasonable.

Default: 0.5

**--pres\_fac\_mult <float>**

Sets the growth factor by which the present overuse penalty factor is multiplied after each router iteration.

Default: 1.3

**--acc\_fac <float>**

Specifies the accumulated overuse factor (historical congestion cost factor).

Default: 1

**--bb\_factor <int>**

Sets the distance (in channels) outside of the bounding box of its pins a route can go. Larger numbers slow the router somewhat but allow for a more exhaustive search of possible routes.

Default: 3

**--base\_cost\_type {demand\_only | delay\_normalized | delay\_normalized\_length | delay\_normalized\_frequency | delay\_normalized\_length\_frequency}**

Sets the basic cost of using a routing node (resource).

- demand\_only sets the basic cost of a node according to how much demand is expected for that type of node.
- delay\_normalized is similar to demand\_only but normalizes all these basic costs to be of the same magnitude as the typical delay through a routing resource.
- delay\_normalized\_length like delay\_normalized but scaled by routing resource length.
- delay\_normalized\_frequency like delay\_normalized, but scaled inversely by routing resource frequency.
- delay\_normalized\_length\_frequency like delay\_normalized, but scaled by routing resource length and scaled inversely by routing resource frequency.

Default: delay\_normalized\_length for the timing-driven router and demand\_only for the breadth-first router.

**--bend\_cost <float>**

The cost of a bend. Larger numbers will lead to routes with fewer bends, at the cost of some increase in track count. If only global routing is being performed, routes with fewer bends will be easier for a detailed router to subsequently route onto a segmented routing architecture.

Default: 1 if global routing is being performed, 0 if combined global/detailed routing is being performed.

**--route\_type {global | detailed}**

Specifies whether global routing or combined global and detailed routing should be performed. Default: detailed (i.e., combined global and detailed routing)

**--route\_chan\_width <int>**

Tells VPR to route the circuit at the specified channel width.

Note

**NOTE:** If the channel width is  $\geq 0$ , no binary search on channel capacity will be performed to find the minimum number of tracks required for routing. VPR simply reports whether or not the circuit will route at this channel width.

Default: -1 (perform binary search for minimum routable channel width)

#### **--min\_route\_chan\_width\_hint <int>**

Hint to the router what the minimum routable channel width is.

The value provided is used to initialize the binary search for minimum channel width. A good hint may speed up the binary search by avoiding time spent at congested channel widths which are not routable.

The algorithm is robust to incorrect hints (i.e., it continues to binary search), so the hint does not need to be precise. This option may occasionally produce a different minimum channel width due to the different initialization.

See also

--verify\_binary\_search

--verify\_binary\_search {on | off}

Force the router to check that the channel width determined by binary search is the minimum.

The binary search occasionally may not find the minimum channel width (e.g., due to router sub-optimality, or routing pattern issues at a particular channel width).

This option attempts to verify the minimum by routing at successively lower channel widths until two consecutive routing failures are observed.

#### **--router\_algorithm {breadth\_first | timing\_driven}**

Selects which router algorithm to use.

**Warning:** The breadth\_first router should NOT be used to compare the run-time/quality of alternate routing algorithms.

It is inferior to the timing\_driven router from a circuit speed (2x - 10x slower) and run-time perspective (takes 10-100x longer on the large benchmarks). The breadth\_first router is deprecated and may be removed in a future release.

The breadth\_first router [BRM99] focuses solely on routing a design successfully, while the timing\_driven router [BRM99, MZB20] focuses both on achieving a successful route and achieving good circuit speed.

The breadth-first router is capable of routing a design using slightly fewer tracks than the timing-driving router (typically 5% if the timing-driven router uses its default parameters. This can be reduced to about 2% if the router parameters are set so the timing-driven router pays more attention to routability and less to area). The designs produced by the timing-driven router are much faster, however, (2x - 10x) and it uses less CPU time to route.

Default: timing\_driven

#### **--min\_incremental\_reroute\_fanout <int>**

Incrementally re-route nets with fanout above the specified threshold.

This attempts to re-use the legal (i.e. non-congested) parts of the routing tree for high fanout nets, with the aim of reducing router execution time.

To disable, set value to a value higher than the largest fanout of any net.

Default: 16

**--max\_logged\_overused\_rr\_nodes <int>**

Prints the information on overused RR nodes to the VPR log file after each failed routing attempt.

If the number of overused nodes is above the given threshold N, then only the first N entries are printed to the log- file.

Default: 20

**--generate\_rr\_node\_overuse\_report {on | off}**

Generates a detailed report on the overused RR nodes' information: report\_overused\_nodes.rpt.

This report is generated only when the final routing attempt fails (i.e. the whole routing process has failed).

In addition to the information that can be seen via --max\_logged\_overused\_rr\_nodes, this report prints out all the net ids that are associated with each overused RR node. Also, this report does not place a threshold upon the number of RR nodes printed.

Default: off

**--write\_timing\_summary <file>**

Writes out to the file under path <file> final timing summary in machine readable (JSON or XML) or human readable (TXT) format. Format is selected based on the extension of <file>. The summary consists of parameters:

- cpd - Final critical path delay (least slack) [ns]
- fmax - Maximal frequency of the implemented circuit [MHz]
- swns - setup Worst Negative Slack (sWNS) [ns]
- stns - Setup Total Negative Slack (sTNS) [ns]

### 3.3.8 Timing-Driven Router Options

The following options are only valid when the router is in timing-driven mode (the default).

**--astar\_fac <float>**

Sets how aggressive the directed search used by the timing-driven router is.

Values between 1 and 2 are reasonable, with higher values trading some quality for reduced CPU time.

Default: 1.2

**--max\_criticality <float>**

Sets the maximum fraction of routing cost that can come from delay (vs. coming from routability) for any net.

A value of 0 means no attention is paid to delay; a value of 1 means nets on the critical path pay no attention to congestion.

Default: 0.99

**--criticality\_exp <float>**

Controls the delay - routability tradeoff for nets as a function of their slack.

If this value is 0, all nets are treated the same, regardless of their slack. If it is very large, only nets on the critical path will be routed with attention paid to delay. Other values produce more moderate tradeoffs.

Default: 1.0

#### **--router\_init\_wirelength\_abort\_threshold <float>**

The first routing iteration wirelength abort threshold. If the first routing iteration uses more than this fraction of available wirelength routing is aborted.

Default: 0.85

#### **--incremental\_reroute\_delay\_ripup {on | off | auto}**

Controls whether incremental net routing will rip-up (and re-route) a critical connection for delay, even if the routing is legal. auto enables delay-based rip-up unless routability becomes a concern.

Default: auto

#### **--routing\_failure\_predictor {safe | aggressive | off}**

Controls how aggressive the router is at predicting when it will not be able to route successfully and giving up early. Using this option can significantly reduce the runtime of a binary search for the minimum channel width.

- safe only declares failure when it is extremely unlikely a routing will succeed, given the amount of congestion existing in the design.
- aggressive can further reduce the CPU time for a binary search for the minimum channel width but can increase the minimum channel width by giving up on some routings that would succeed.
- off disables this feature, which can be useful if you suspect the predictor is declaring routing failure too quickly on your architecture.

See also:

--verify\_binary\_search

Default: safe

#### **--routing\_budgets\_algorithm { disable | minimax | scale\_delay }**

**Warning:** Experimental

Controls how the routing budgets are created. Routing budgets are used to guide VPR's routing algorithm to consider both short path and long path timing constraints [FBC08].

- disable is used to disable the budget feature. This uses the default VPR and ignores hold time constraints.
- minimax sets the minimum and maximum budgets by distributing the long path and short path slacks depending on the current delay values. This uses the routing cost valleys and Minimax-PERT algorithm [FBC08, YLS92].
- scale\_delay has the minimum budgets set to 0 and the maximum budgets is set to the delay of a net scaled by the pin criticality (net delay/pin criticality).

Default: disable

**--save\_routing\_per\_iteration {on | off}**

Controls whether VPR saves the current routing to a file after each routing iteration. May be helpful for debugging. Default: off

**--congested\_routing\_iteration\_threshold CONGESTED\_ROUTING\_ITERATION\_THRESHOLD**

Controls when the router enters a high effort mode to resolve lingering routing congestion. Value is the fraction of max\_router\_iterations beyond which the routing is deemed congested.

Default: 1.0 (never)

**--route\_bb\_update {static, dynamic}**

Controls how the router's net bounding boxes are updated:

- static: bounding boxes are never updated
- dynamic: bounding boxes are updated dynamically as routing progresses (may improve routability of congested designs)

Default: dynamic

**--router\_high\_fanout\_threshold ROUTER\_HIGH\_FANOUT\_THRESHOLD**

Specifies the net fanout beyond which a net is considered high fanout. Values less than zero disable special behavior for high fanout nets.

Default: 64

**--router\_lookahead {classic, map}**

Controls what lookahead the router uses to calculate the cost of completing a connection.

- classic: The classic VPR lookahead
- map: A more advanced lookahead which accounts for diverse wire types and their connectivity

Default: classic

**--router\_max\_convergence\_count <float>**

Controls how many times the router is allowed to converge to a legal routing before halting. If multiple legal solutions are found the best quality implementation is used.

Default: 1

**--router\_reconvergence\_cpd\_threshold <float>**

Specifies the minimum potential CPD improvement for which the router will continue to attempt re-convergent routing.

For example, a value of 0.99 means the router will not give up on reconvergent routing if it thinks a > 1% CPD reduction is possible.

Default: 0.99

**--router\_initial\_timing {all\_critical | lookahead}**

Controls how criticality is determined at the start of the first routing iteration.

- all\_critical: All connections are considered timing critical.
- lookahead: Connection criticalities are determined from timing analysis assuming (best-case) connection delays as estimated by the router's lookahead.

Default: all\_critical for the classic --router\_lookahead, otherwise lookahead

**--router\_update\_lower\_bound\_delays {on | off}**

Controls whether the router updates lower bound connection delays after the 1st routing iteration.

Default: on

**--router\_first\_iter\_timing\_report <file>**

Name of the timing report file to generate after the first routing iteration completes (not generated if unspecified).

**--router\_debug\_net <int>**

**NOTE:** This option is likely only of interest to developers debugging the routing algorithm

Controls which net the router produces detailed debug information for.

- For values  $\geq 0$ , the value is the net ID for which detailed router debug information should be produced.
- For value == -1, detailed router debug information is produced for all nets.
- For values  $< -1$ , no router debug output is produced.

**Warning:** VPR must have been compiled with VTR\_ENABLE\_DEBUG\_LOGGING on to get any debug output from this option.

Default: -2

**--router\_debug\_sink\_rr ROUTER\_DEBUG\_SINK\_RR**

**NOTE:** This option is likely only of interest to developers debugging the routing algorithm

Controls when router debugging is enabled for the specified sink RR.

- For values  $\geq 0$ , the value is taken as the sink RR Node ID for which to enable router debug output.
- For values  $< 0$ , sink-based router debug output is disabled.

**Warning:** VPR must have been compiled with VTR\_ENABLE\_DEBUG\_LOGGING on to get any debug output from this option.

Default: -2

### 3.3.9 Analysis Options

#### --full\_stats

Print out some extra statistics about the circuit and its routing useful for wireability analysis.

Default: off

#### --gen\_post\_synthesis\_netlist { on | off }

Generates the Verilog and SDF files for the post-synthesized circuit. The Verilog file can be used to perform functional simulation and the SDF file enables timing simulation of the post-synthesized circuit.

The Verilog file contains instantiated modules of the primitives in the circuit. Currently VPR can generate Verilog files for circuits that only contain LUTs, Flip Flops, IOs, Multipliers, and BRAMs. The Verilog description of these primitives are in the primitives.v file. To simulate the post-synthesized circuit, one must include the generated Verilog file and also the primitives.v Verilog file, in the simulation directory.

See also Post-Implementation Timing Simulation

If one wants to generate the post-synthesized Verilog file of a circuit that contains a primitive other than those mentioned above, he/she should contact the VTR team to have the source code updated. Furthermore, to perform simulation on that circuit the Verilog description of that new primitive must be appended to the primitives.v file as a separate module.

Default: off

#### --gen\_post\_implementation\_merged\_netlist { on | off }

This option is based on --gen\_post\_synthesis\_netlist. The difference is that --gen\_post\_implementation\_merged\_netlist generates a single verilog file with merged top module multi-bit ports of the implemented circuit. The name of the file is <basename>\_merged\_post\_implementation.v

Default: off

#### --post\_synth\_netlist\_unconn\_inputs { unconnected | nets | gnd | vcc }

Controls how unconnected input cell ports are handled in the post-synthesis netlist

- unconnected: leave unconnected
- nets: connect each unconnected input pin to its own separate undriven net named: \_\_vpr\_\_unconn<ID>, where <ID> is index assigned to this occurrence of unconnected port in design
- gnd: tie all to ground (1'b0)
- vcc: tie all to VCC

(1'b1) Default: unconnected

#### --post\_synth\_netlist\_unconn\_outputs { unconnected | nets }

Controls how unconnected output cell ports are handled in the post-synthesis netlist

- unconnected: leave unconnected
- nets: connect each unconnected output pin to its own separate undriven net named: \_vpr\_\_unconn<ID>, where <ID> is index assigned to this occurrence of unconnected port in design

Default: unconnected

#### -timing\_report\_npaths <int>

Controls how many timing paths are reported.

- (default)

Users need to source this script into the project tcl script and then invoke any of the desired procedures with the appropriate arguments to start the desired compilation flow.

**NOTE: The number of paths reported may be less than the specified value, if the circuit has fewer paths.**  
**Default: 100**

### 3.3.10 Congestion Mitigation

While implementing large designs, congestion can often result in routing failures. In order to mitigate congestion issues, the flow.tcl script can be used. This script defines four different procedures which implement different packing, P&R and synthesis strategies. The following flows are available in this script:

- **area\_flow**: Area driven compilation flow which aims to reduce area.
- **congestion\_flow**: Congestion driven compilation flow. This flow has an argument `congestion_type` which accepts the following options:
  - "uniform" for uniformly congested high utilization designs
  - "hotspot" for hotspots of congestion in moderately utilized designs
- **routability\_flow**: <`number_of_molecules_in_partition` "200"> <`congestion` "medium | high">
- <`vpr_constraints_file` ""> : Routability driven compilation flow. This proc accepts three optional arguments:
  - `number_of_molecules_in_partition`: Average number of molecules in each cluster (default is 200).
  - `congestion`: medium, high
  - initial VPR placement constraints file
- **timing\_flow**: Aims to achieve timing driven placement and routing. This flow accepts only one optional argument `initial_placer_type` with the following two options:
  - "analytic" for using timing-driven analytic placement as initial placement. The result is then passed through the simulated annealing (SA) placer.
  - 'default': Use VPR's default initial placer (default)

Users need to source this script into the project tcl script and then invoke any of the desired procedures with the appropriate arguments to start the desired compilation flow.

**--timing\_report\_detail { netlist | aggregated | detailed | debug}**

Controls the level of detail included in generated timing reports.

We obtained the following results using the k6\_frac\_N10\_frac\_chain\_mem32K\_40nm.xml architecture and multi-clock.blif circuit.

- netlist: Timing reports show only netlist primitive pins.
- aggregated: Timing reports show netlist pins, and an aggregated summary of intra-block and inter-block routing delays.
- detailed: Like aggregated, the timing reports show netlist pins, and an aggregated summary of intra-block. In addition, it includes a detailed breakdown of the inter-block routing delays.
- debug: Like detailed, but includes additional VPR internal debug information such as timing graph node IDs (tnode) and routing SOURCE/SINK nodes.

Default: netlist

**--echo\_dot\_timing\_graph\_node { string | int }**

Controls what subset of the timing graph is echoed to a GraphViz DOT file when vpr --echo\_file is enabled.

Value can be a string (corresponding to a VPR atom netlist pin name), or an integer representing a timing graph node ID. Negative values mean the entire timing graph is dumped to the DOT file.

Default: -1

**--timing\_report\_skew { on | off }**

Controls whether clock skew timing reports are generated.

Default: off

### 3.4 Use Pin Location Constraints

Raptor allows users to bind their design I/O ports to specific device pins, by using pin location constraint commands in the SDC file.

The list of commands is as follows:

**set\_pin\_loc <design\_io\_name> <device\_io\_name>**

Constrains design pin to device pin.

Arguments:

<design\_io\_name>

The IO port name in user design.

<device\_io\_name>

The device package pin name.

**set\_property mode <io\_mode\_name> <device\_io\_name>**

Constrains IO operation mode.

Arguments:

<io\_mode\_name>

Available IO operation mode.

<device\_io\_name>

---

Device IO package pin name.

Here is an example:

```
set_property mode Mode_BP_SDR_A_TX  
Bank_VL_1_19  
set_pin_loc a Bank_VL_1_19  
  
set_property mode Mode_BP_SDR_A_TX  
Bank_VL_1_21  
set_pin_loc b Bank_VL_1_21  
  
set_property mode Mode_BP_SDR_A_TX  
Bank_VL_1_23  
set_pin_loc c Bank_VL_1_23
```

Where:

a, b and c are design ports

Bank\_\* are device package pins

Mode\_\* are IO operation modes

**NOTE:** To set the proper and available modes for pin constraint, please refer to the device pin table. In case there is no pin location constraint given, Raptor is able to assign pin location in the method specified by user through below command:

#### **pin\_loc\_assign\_method <method>**

Method can be one of below:

- in\_define\_order: Pins are assigned to available device pin by the order the ports in design are defined
- random: Pins are assigned to available device pin by the order the ports randomly
- free: Pins are assigned by Raptor placer (VPR)

## 4. Raptor Timing Analysis

Raptor invokes the VPR/tatum timing engine to do static timing analysis (STA). Tatum is a block-based Static Timing Analysis (STA) engine suitable for integration with Computer-Aided Design (CAD) tools, which analyze, implement and optimize digital circuits. Tatum supports both setup (max-delay) and hold (min-delay) analysis, clock skew, multiple clocks and a variety of timing exceptions.

There are two ways to setup and run timing analysis:

- Use Project Mode, selecting options from the Raptor Integrated Design Environment (IDE).
- Use Tcl Mode, applying Tool Command Language (Tcl) commands or scripts, and controlling your own design files.

### 4.1 STA Methodology

Tatum timing engine is an open project which has been used in different tools and projects. VPR uses it as timing engine starting in version v8.0.0-rc1(2019-06-13), where tatum performs:

- Apply timing constraints (through SDC commands)
- Time design (Delay calculation)
- Timing violation check

For details about VPR/tatum, <https://github.com/verilog-to-routing/tatum>

### 4.2 Using STA

Each stage of STA can be run within Raptor in 2 ways:

- Use IDE GUI task panel
- Use command lines
  - add\_constraint\_file <SDC\_FILE>
  - sta

**NOTE:** Static timing analysis should be performed after P&R.

#### 4.2.1 SDC Commands

To do timing analysis, the user must provide SDC file for VPR/tatum to start with. Raptor passes these commands in SDC file to VPR/tatum to allow it to do the job.

Tatum supports a subset of SDC commands. For details and usage examples, please refer to: [https://docs.verilog-torouting.org/en/latest/vpr/sdc\\_commands/](https://docs.verilog-torouting.org/en/latest/vpr/sdc_commands/).

The following subset of SDC syntax is supported by VPR.

#### create\_clock

Creates a netlist or virtual clock.

Assigns a desired period (in nanoseconds) and waveform to one or more clocks in the netlist (if the –name option is omitted) or to a single virtual clock (used to constrain input and outputs to a clock external to the design). Netlist clocks can be referred to using regular expressions, while the virtual clock name is taken as-is.

**Example Usage:**

```
#Create a netlist clock  
create_clock -period <float> <netlist clock list or regexes>  
  
#Create a virtual clock  
create_clock -period <float> -name <virtual clock name>  
  
#Create a netlist clock with custom waveform/duty-cycle  
create_clock -period <float> -waveform {rising_edge falling_edge} <netlist clock list or regexes>
```

Omitting the waveform creates a clock with a rising edge at 0 and a falling edge at the half period and is equivalent to using **-waveform {0 <period/2>}**. Non-50% duty cycles are supported but behave no differently than 50% duty cycles, since falling edges are not used in analysis. If a virtual clock is assigned using a `create_clock` command, it must be referenced elsewhere in a `set_input_delay` or `set_output_delay` constraint.

**create\_clock****-period <float>**

Specifies the clock period.

**Required:** Yes

**-waveform {<float> <float>}**

Overrides the default clock waveform.

The first value indicates the time the clock rises, the second the time the clock falls.

**Required:** No

Default: 50% duty cycle (i.e. **-waveform {0 <period/2>}**).

**-name <string>**

Creates a virtual clock with the specified name.

**Required:** No

**<netlist clock list or regexes>**

Creates a netlist clock

---

**Required:** No

#### Note

One of -name or <netlist clock list or regexes> must be specified.

#### Warning:

If a netlist clock is not specified with a create\_clock command, paths to and from that clock domain will not be analysed.

### **set\_clock\_groups**

Specifies the relationship between groups of clocks. May be used with netlist or virtual clocks in any combination.

Since VPR supports only the **-exclusive** option, a **set\_clock\_groups** constraint is equivalent to a **set\_false\_path** constraint (see below) between each clock in one group and each clock in another.

For example, the following sets of commands are equivalent:

```
#Do not analyze any timing paths between clk1 and clk2
set_clock_groups -exclusive -group {clk1} -group {clk2}
and
set_false_path -from [get_clocks {clk1}] -to [get_clocks {clk2}]
set_false_path -from [get_clocks {clk2}] -to [get_clocks {clk1}]
```

### **set\_clock\_groups**

#### **-exclusive**

Indicates that paths between clock groups should not be analyzed.

**Required:** Yes

#### Note:

VPR currently only supports exclusive clock groups

**-group {<clock list or regexes>}**

Specifies a group of clocks.

#### Note:

At least 2 groups must be specified.

**Required:** Yes

## **set\_false\_path**

Cuts timing paths unidirectionally from each clock in **-from** to each clock in **-to**. Otherwise, equivalent to **set\_clock\_groups**.

### **Example Usage:**

```
#Do not analyze paths launched from clk1 and captured by clk2
set_false_path -from [get_clocks {clk1}] -to [get_clocks {clk2}]

#Do not analyze paths launched from clk2 and captured by clk1
set_false_path -from [get_clocks {clk2}] -to [get_clocks {clk1}]
```

### **Note:**

False paths are supported between entire clock domains, but not between individual registers.

## **set\_false\_path**

**-from [get\_clocks <clock list or regexes>]**

Specifies the source clock domain(s).

**Required:** No

**Default:** All clocks

**-to [get\_clocks <clock list or regexes>]**

Specifies the sink clock domain(s).

**Required:** No

**Default:** All clocks

## **set\_max\_delay/set\_min\_delay**

Overrides the default setup (max) or hold (min) timing constraint calculated using the information from **create\_clock** with a user-specified delay.

**Example Usage:**

```
#Specify a maximum delay of 17 from input_clk to output_clk  
set_max_delay 17 -from [get_clocks {input_clk}] -to [get_clocks {output_clk}]  
  
#Specify a minimum delay of 2 from input_clk to output_clk  
set_min_delay 2 -from [get_clocks {input_clk}] -to [get_clocks {output_clk}]
```

**Note**

Max/Min delays are supported between entire clock domains, but not between individual netlist elements.

**set\_max\_delay/set\_min\_delay****<delay>**

The delay value to apply.

**Required:** Yes

**-from [get\_clocks <clock list or regexes>]**

Specifies the source clock domain(s).

**Required:** No

**Default:** All clocks

**-to [get\_clocks <clock list or regexes>]**

Specifies the sink clock domain(s).

**Required:** No

**Default:** All clocks

---

**set\_multicycle\_path**

Sets how many clock cycles elapse between the launch and capture edges for setup and hold checks.

The default the setup multicycle value is 1 (i.e., the capture setup check is performed against the edge one cycle after the launch edge).

The default hold multicycle is one less than the setup multicycle path (e.g. the capture hold check occurs in the same cycle as the launch edge for the default setup multicycle).

#### **Example Usage:**

```
#Create a 4 cycle setup check, and 0 cycle hold check from clkA to clkB
set_multicycle_path -from [get_clocks {clkA}] -to [get_clocks {clkB}] 4

#Create a 3 cycle setup check from clk to clk2
# Note that this moves the default hold check to be 2 cycles
set_multicycle_path -setup -from [get_clocks {clk}] -to [get_clocks {clk2}] 3

#Create a 0 cycle hold check from clk to clk2
# Note that this moves the default hold check back to it's original
# position before the previous setup setup_multicycle_path was applied
set_multicycle_path -hold -from [get_clocks {clk}] -to [get_clocks {clk2}] 2

#Create a multicycle to a specific pin
set_multicycle_path -to [get_pins {my_inst.in\[0\]}] 2
```

#### **Note:**

Multicycles are supported between entire clock domains and ending at specific registers.

#### **set\_multicycle\_path**

##### **-setup**

Indicates that the multicycle-path applies to setup analysis.

**Required:** No

##### **-hold**

Indicates that the multicycle-path applies to hold analysis.

**Required:** No

##### **-from [get\_clocks <clock list or regexes>]**

Specifies the source clock domain(s).

**Required:** No

**Default:** All clocks

#### **-to [get\_clocks <clock list or regexes>]**

Specifies the sink clock domain(s).

**Required:** No

**Default:** All clocks

#### **-to [get\_pins <pin list or regexes>]**

Specifies the sink/capture netlist pins to which the multicycle is applied.

#### **See also**

VPR's pin naming convention.

**Required:** No

#### **<path\_multiplier>**

The number of cycles that apply to the specified path(s).

**Required:** Yes

#### **Note:**

If neither -setup nor -hold the setup multicycle is set to path\_multiplier and the hold multicycle offset to 0.

#### **Note:**

Only a single -to option can be specified (either clocks or pins, but not both).

#### **set\_input\_delay/set\_output\_delay**

Use **set\_input\_delay** if you want timing paths from input I/Os analyzed, and **set\_output\_delay** if you want timing paths to output I/Os analyzed.

**Note:**

If these commands are not specified in your SDC, paths from and to I/Os will not be timing analyzed.

These commands constrain each I/O pad specified after **get\_ports** to be timing-equivalent to a register clocked on the clock specified after **-clock**. This can be either a clock signal in your design or a virtual clock that does not exist in the design but which is used only to specify the timing of I/Os.

The specified delays are added to I/O timing paths and can be used to model board level delays.

For single-clock circuits, **-clock** can be wildcarded using \* to refer to the single netlist clock, although this is not supported in standard SDC. This allows a single SDC command to constrain I/Os in all single-clock circuits.

**Example Usage:**

```
#Set a maximum input delay of 0.5 (relative to input_clk) on
#ports in1, in2 and in3
set_input_delay -clock input_clk -max 0.5 [get_ports {in1 in2 in3}]

#Set a minimum output delay of 1.0 (relative to output_clk) on
#all ports matching starting with 'out*'
set_output_delay -clock output_clk -min 1 [get_ports {out*}]

#Set both the maximum and minimum output delay to 0.3 for all I/Os
#in the design
set_output_delay -clock clk2 0.3 [get_ports {*}]
```

**set\_input\_delay/set\_output\_delay****-clock <virtual or netlist clock>**

Specifies the virtual or netlist clock the delay is relative to.

**Required:** Yes

**-max**

Specifies that the delay value should be treated as the maximum delay.

**Required:** No

**-min**

Specifies that the delay value should be treated as the minimum delay.

**Required:** No

#### **<delay>**

Specifies the delay value to be applied

**Required:** Yes

#### **[get\_ports {<I/O list or regexes>}]**

Specifies the port names or port name regex.

**Required:** Yes

**Note:**

If neither **-min** nor **-max** are specified the delay value is applied to both.

---

## **set\_clock\_uncertainty**

Sets the clock uncertainty between clock domains. This is typically used to model uncertainty in the clock arrival times due to clock jitter.

**Example Usage:**

```
#Sets the clock uncertainty between all clock domain pairs to 0.025
set_clock_uncertainty 0.025

#Sets the clock uncertainty from 'clk' to all other clock domains to 0.05
set_clock_uncertainty -from [get_clocks {clk}] 0.05

#Sets the clock uncertainty from 'clk' to 'clk2' to 0.75
set_clock_uncertainty -from [get_clocks {clk}] -to [get_clocks {clk2}] 0.75
```

#### **set\_clock\_uncertainty**

##### **-from [get\_clocks <clock list or regexes>]**

Specifies the source clock domain(s).

**Required:** No

**Default:** All clocks

**-to [get\_clocks <clock list or regexes>]**

Specifies the sink clock domain(s).

**Required:** No

Default: All clocks

**-setup**

Specifies the clock uncertainty for setup analysis.

**Required:** No

**-hold**

Specifies the clock uncertainty for hold analysis.

**Required:** No

**<uncertainty>**

The clock uncertainty value between the from and to clocks.

**Required:** Yes

**Note**

If neither **-setup** nor **-hold** are specified the uncertainty value is applied to both.

---

## **set\_clock\_latency**

Sets the latency of a clock. VPR automatically calculates on-chip clock network delay, and so only source latency is supported.

Source clock latency corresponds to the delay from the true clock source (e.g. off-chip clock generator) to the on-chip clock definition point.

```
#Sets the source clock latency of 'clk' to 1.0  
set_clock_latency -source 1.0 [get_clocks {clk}]
```

## **set\_clock\_latency**

### **-source**

Specifies that the latency is the source latency.

**Required:** Yes

### **-early**

Specifies that the latency applies to early paths.

Required: No

### **-late**

Specifies that the latency applies to late paths.

**Required:** No

### **<latency>**

The clock's latency.

**Required:** Yes

### **[get\_clocks <clock list or regexes>]**

Specifies the clock domain(s).

**Required:** Yes

### **Note**

If neither **-early** nor **-late** are specified the latency value is applied to both.

## **set\_disable\_timing**

Disables timing between a pair of connected pins in the netlist. This is typically used to manually break combinational loops.

```
#Disables the timing edge between the pins 'FFA.Q[0]' and 'to_FFD.in[0]' on  
set_disable_timing -from [get_pins {FFA.Q\[0\]}] -to [get_pins {to_FFD.in\[0\]}]
```

### **set\_disable\_timing**

```
-from [get_pins <pin list or regexes>]
```

Specifies the source netlist pins.

#### **See also**

VPR's pin naming convention.

**Required:** Yes

```
-to [get_pins <pin list or regexes>]
```

Specifies the sink netlist pins.

#### **See also**

VPR's pin naming convention.

**Required:** Yes

#### **Note**

Make sure to escape the characters in the regexes.

#### **Special Characters**

```
# (comment), \\ (line continued), * (wildcard), {} (string escape)
```

# starts a comment – everything remaining on this line will be ignored.

\ at the end of a line indicates that a command wraps to the next line.

\* is used in a **get\_clocks/get\_ports** command or at the end of **create\_clock** to match all netlist clocks. Partial wildcarding (e.g. **clk\*** to match **clk** and **clk2**) is also supported. As mentioned above, \* can be used in **set\_input\_delay** and **set\_output\_delay** to refer to the netlist clock for single-clock circuits only, although this is not supported in standard SDC.

{} escapes strings, e.g. **{top^clk}** matches a clock called **top^clk**, while **top^clk** without braces gives an error because of the special ^ character.

## SDC Examples

The following are sample SDC files for common non-default cases (assuming netlist clock domains **clk** and **clk2**).

### A

Cut I/Os and analyse only register-to-register paths, including paths between clock domains; optimize to run as fast as possible.

```
create_clock -period 0 *
```

### B

Same as A, but with paths between clock domains cut. Separate target frequencies are specified.

```
create_clock -period 2 clk
create_clock -period 3 clk2
set_clock_groups -exclusive -group {clk} -group {clk2}
```

### C

Same as B, but with paths to and from I/Os now analyzed. This is the same as the multi-clock default, but with custom period constraints.

```
create_clock -period 2 clk
create_clock -period 3 clk2
create_clock -period 3.5 -name virtual_io_clock
set_clock_groups -exclusive -group {clk} -group {clk2}
set_input_delay -clock virtual_io_clock -max 0 [get_ports {*}]
set_output_delay -clock virtual_io_clock -max 0 [get_ports {*}]
```

### D

Changing the phase between clocks, and accounting for delay through I/Os with **set\_input/output\_delay** constraints.

```
#Custom waveform rising edge at 1.25, falling at 2.75
create_clock -period 3 -waveform {1.25 2.75} clk
create_clock -period 2 clk2
create_clock -period 2.5 -name virtual_io_clock
set_input_delay -clock virtual_io_clock -max 1 [get_ports {*}]
set_output_delay -clock virtual_io_clock -max 0.5 [get_ports {*}]
```

### E

Sample using many supported SDC commands. Inputs and outputs are constrained on separate virtual clocks.

```
create_clock -period 3 -waveform {1.25 2.75} clk
create_clock -period 2 clk2
create_clock -period 1 -name input_clk
create_clock -period 0 -name output_clk
set_clock_groups -exclusive -group input_clk -group clk2
set_false_path -from [get_clocks {clk}] -to [get_clocks {output_clk}]
set_max_delay 17 -from [get_clocks {input_clk}] -to [get_clocks {output_clk}]
set_multicycle_path -setup -from [get_clocks {clk}] -to [get_clocks {clk2}] 3
set_input_delay -clock input_clk -max 0.5 [get_ports {in1 in2 in3}]
set_output_delay -clock output_clk -max 1 [get_ports {out*}]
```

**F**

Sample using all remaining SDC commands.

```
create_clock -period 3 -waveform {1.25 2.75} clk
create_clock -period 2 clk2
create_clock -period 1 -name input_clk
create_clock -period 0 -name output_clk
set_clock_latency -source 1.0 [get_clocks{clk}]

#if neither early nor late is specified then the latency applies to early paths
set_clock_groups -exclusive -group input_clk -group clk2 set_false_path -from [get_clocks{clk}] -to
[get_clocks{output_clk}]
set_input_delay -clock input_clk -max 0.5 [get_ports{in1 in2 in3}]
set_output_delay -clock output_clk -min 1 [get_ports{out*}]
set_max_delay 17 -from [get_clocks{input_clk}] -to [get_clocks{output_clk}]
set_min_delay 2 -from [get_clocks{input_clk}] -to [get_clocks{output_clk}]
set_multicycle_path -setup -from [get_clocks{clk}] -to [get_clocks{clk2}] 3
#For multicycle_path, if setup is specified then hold is also implicitly specified
set_clock_uncertainty -from [get_clocks{clk}] -to [get_clocks{clk2}] 0.75
#For set_clock_uncertainty, if neither setup nor hold is unspecified then uncertainty is applied to both
set_disable_timing -from [get_pins {FFA.Q\[0\]}] -to [get_pins {to_FFD.in\[0\]}]
```

## 5. Device Configuration

The Raptor Device Programmer allows you to program and configure Rapid Silicon FPGA devices. After compiling your design, the next step is generating the device image and download into the target FPGA device or flash. Use the Raptor device programming Tcl commands or Raptor device programming GUI to program your target device. The supported programmer's modes are JTAG and Master SPI interface programming via third-party QSPI serial configuration devices.

### 5.1 Raptor Device Programmer GUI



Figure 63. Raptor Programmer and Debugger GUI

1. RPD Button to launch Raptor Programmer and Debugger GUI.
2. Raptor Programmer and Debugger GUI Tool.
3. Hardware selection. Currently only one FTDI cable is available.
4. Interface selection for programming. Currently only JTAG interface is supported.
5. Detect button. Click to perform hardware and device(s) detection that is connected to the machine.
6. Click to begin device programming operation on selected device(s) in the Device Tree table.
7. Overall progress bar indicator.
8. Device Tree table. Connected devices will be automatically populated in this table during the tool start up. Alternatively, users can click the detect button to reload the devices detection.

### 5.2 FPGA Device Configuration

#### FPGA configuration steps using GUI and/or programmer Tcl commands

1. Generate the bitstream using Raptor compilation tool.
2. Connect the board with JTAG USB cable.
3. Connect the power cable attached to the board to a power source.
4. Turn on the power to the board.
5. Launch Raptor software followed by clicking the RPD button to launch Raptor Programmer and Debugger GUI tool.

6. There are two ways to perform device programming.
  - I. Using Raptor Programmer and Debugger GUI
  - II. Using Programmer TCL commands
7. Using the GUI, when the tool is loaded, the FPGA and Flash device will be automatically detected as shown in figure 58
  - a. Right click on the gemini device row in the Device Tree. A context menu will pop up showing in Figure 58.
  - b. Select the Add Bitstream File and a file browser window will pop up and allow you to select the bitstream file.
  - c. Check the checkbox on the left side of the row if it is not checked.
  - d. Click start to begin FPGA configuration. Figure 59 shows the FPGA configuration is in progress



Figure 64. Add bitstream file



Figure 65. FPGA configuration in progress

8. Using Programmer TCL commands, simply enter the following command in Raptor TCL console or Raptor Programmer and Debugger GUI TCL console
  - a. *Programmer fpga config <bitstream file path> -c <cable name/index> -d <device index>*  
*programmer fpga\_config /home/helloworld.cfgbit -c 1 -d 1*

### 5.3 Flash Programming

The Raptor Device Programmer also supports flash programming. You can use the Programmer to load an FPGA configuration bitstream file into a Quad SPI flash memory device. The Quad SPI flash memory device subsequently loads the configuration data into the target.



**Figure 66. Programming Flash using JTAG**

## Flash Programming Steps using GUI and/or programmer Tcl commands

1. Generate the flash bitstream using Raptor compilation tool.
2. Connect the board with a JTAG USB cable.
3. Connect the power cable attached to the board to a power source.
4. Turn on the power to the board.
5. Launch Raptor software followed by clicking the RPD button to launch Raptor Programmer and Debugger GUI tool.
6. There are two ways to perform device programming.
  - I. Using Raptor Programmer and Debugger GUI
  - II. Using Programmer TCL commands
7. Using the GUI, when the tool is loaded, the FPGA and Flash device will be automatically detected as shown in figure 61
  - a. Right click on the Flash device row in the Device Tree. A context menu will pop up showing in Figure 61.
  - b. Select the Add Bitstream File and a file browser window will pop up and allow you to select the bitstream file.
  - c. Check the checkbox on the left side of the row if it is not checked.
  - d. Click start to begin Flash programming.



**Figure 67. Add flash file**



**Figure 68. Flash programming in progress**

8. Using Programmer TCL commands, simply enter the following command in Raptor TCL console or Raptor Programmer and Debugger GUI TCL console
  - a. *programmer flash <bitstream file path> -o <operation> -c <cable name/index> -d <device index>*  
*programmer flash /home/helloworld.cfgbit -o program -c 1 -d 1*

## 5.4 OTP Programming

OTP programming refers to “One-Time Programmable” programming. Once configured or programmed, the data remains stored even when power is removed. The OTP memory in FPGA is used to store critical configuration data, such as the initial bitstream or settings, encryption keys, identification information, or other sensitive data providing a level of security and intellectual property protection that are essential for the FPGA to perform its intended function.

### OTP Programming Steps using GUI and/or programmer Tcl commands

1. Generate the OTP bitstream using Raptor compilation tool.
2. Connect the board with a JTAG USB cable.
3. Connect the power cable attached to the board to a power source.
4. Turn on the power to the board.
5. Launch Raptor software followed by clicking the RPD button to launch Raptor Programmer and Debugger GUI tool.
6. There are two ways to perform device programming.
  - I. Using Raptor Programmer and Debugger GUI
  - II. Using Programmer TCL commands
7. Using the GUI, when the tool is loaded, the FPGA and Flash device will be automatically detected
  - a. Right click on the FPGA device row in the Device Tree. A context menu will pop up showing in Figure 63. Here, there are three things to take note
    - i. Select the Add OTP Bitstream File and a file browser window will pop up and allow you to select the bitstream file.
    - ii. Right click the row again, select OTP programming operation, shown in figure 69.
    - iii. Before OTP programming begin, a warning message will pop to tell user that it is one time programming and it is an irreversible process. Click Ok to continue otherwise cancel. This is shown in figure 70.
  - b. Check the checkbox on the left side of the row if it is not checked.

- c. Click start to begin OTP programming.



**Figure 69. OTP programming**



**Figure 70. OTP Warning Message**

8. Using Programmer TCL commands, simply enter the following command in Raptor TCL console or Raptor Programmer and Debugger GUI TCL console
- a. *programmer otp <bitstream file path> -c <cable name/index> -d <device index> -y*  
*programmer otp /home/otp\_bitstream.bin -c 1 -d 1 -y*

## 5.5 Other Programmer Commands

### 5.5.1 list\_cable

list\_cable command is used to list all connected USB programmer cables connected in the machine. The command is as follows:

```
programmer list_cable ?-v?
```

Figure 65 shows the example of `list\_cable -v` output in TCL console.



Figure 71. List cable command output

### 5.5.2 list\_device

list\_device command is used to list all available devices or specified cable devices. The command is as follows:

```
programmer list_device ?-c <cable name/index>? ?-v?
```

Figure 66 shows the example of `list\_device -v` output in TCL console.



Figure 72. List Device command output

### 5.5.3 fpga\_status

list\_device command is used to query FPGA Configuration Done and Configuration IsError status for a specified device. The command is as follows:

```
programmer fpga_status -c <cable name/index> -d <device index> ?-v?
```

Figure 66 shows the example of `programmer fpga\_status -c 1 -d1` -v output in TCL console.



Figure 73. Fpga status command output

## 6. OCLA Debugger

The OCLA Debugger is an integrated debugging feature in Raptor, specifically designed for facilitating efficient debugging with the On-Chip Logic Analyzer (OCLA) Intellectual Property (IP) instantiated within FPGA designs. This tool enables users to gain access to and analyze internal signals of a design within Rapid Silicon's field-programmable gate arrays (FPGAs). With its seamless integration with GTKWave, it allows users to visualize and analyze the digital waveforms they acquire during the debugging process.

Additionally, the OCLA Debugger software incorporates the Emulated-IO (EIO) feature, enabling designers to simulate IO signals to and from the FPGA fabric.

### 6.1. OCLA Debugger Tcl Command

The OCLA Debugger encompasses a set of comprehensive Tcl commands that allow users to access and manage OCLA IP instances in a design via the JTAG interface from a host computer.

#### 6.1.1. Detect JTAG cable

1. Connect the USB JTAG cable to the OCLA JTAG pins on the board and the host computer.
2. Connect the power cable to the board and power source.
3. Turn on the power.
4. Launch Raptor software on the host computer.
5. In the console, enter the command “`debugger list_cable -v`” and press Enter to detect and list all cables attached to the host computer.

```
Console
# debugger list_cable -v
Q INFO: Cable
INFO: -----
INFO: (1) RsFtdi_1_1
INFO: (2) RsFtdi_1_2
# RsFtdi_1_1 RsFtdi_1_2
#
```

**Figure 74. List cable command output**

**NOTE:** OCLA Debugger is currently compatible only with FTDI-based cable and hardware adapters.

#### 6.1.2. Detect OCLA Device

1. In the console, enter the command “`debugger list_device -v`” and press Enter to detect all OCLA devices on all attached cables on the host computer.

```
Console
# debugger list_device -v
Q INFO: Cable | Device
INFO: -----
INFO: (2) RsFtdi_1_2 OCLA<1>
# RsFtdi_1_2 OCLA<1>
#
```

**Figure 75. List device command output**

#### 6.1.3. Load OCLA debug information from a user design

The OCLA debug information comprises a list of clock domains and the associated signals with descriptive names and corresponding probe information (e.g. position, width etc.) within a user design. This information is mandatory for the software to function properly and allows users to easily identify available debug signals and simplify the process of configuring triggers by referencing signal names.

Below are steps to load the OCLA debug information: -

1. In the console, enter the command “debugger load --file <filepath to .bitasm>” and press Enter to load the debug information from a user design in a bit assembler file with .bitasm extension.
2. Enter the command “debugger info --cable <index> --device <dev>” and press Enter to verify the OCLA debug information is loaded properly.



**Figure 76. Info command output with OCLA debug Info.**

#### 6.1.4. Configure OCLA

The OCLA IP supports various features e.g., capture mode, global Boolean condition for multiple triggers setup and configure the number of samples to capture rather than the default sample size.

Below are steps to configure the OCLA on a clock domain: -

1. In the console, enter the command “debugger config --cable <index> --device <dev> --domain <n> --mode <mode> --trigger\_condition <bool> --sample\_size <size>” and press Enter to configure an OCLA clock domain.
2. Following are the details of the command options: -

| Option      | Description                                                                                                    | Possible value                            | Default     | Mandatory |
|-------------|----------------------------------------------------------------------------------------------------------------|-------------------------------------------|-------------|-----------|
| cable       | Specify the index or name of the JTAG cable                                                                    | Integer starts from 1 or cable name       | 1           | No        |
| device      | Specify the index of the device on the cable                                                                   | Integer starts from 1                     | 1           | No        |
| domain      | Specify the index of the OCLA clock domain to configure.                                                       | Integer starts from 1 to max clock domain | -           | Yes       |
| mode        | Configure the trigger mode of the OCLA instance.                                                               | pre-trigger, center-trigger, post-trigger | pre-trigger | No        |
| sample_size | Configure the number of samples data to acquire. Value 0 will set the design time memory depth as sample size. | 0 to memory depth of the IP               | 0           | No        |

|                   |                                             |              |    |    |
|-------------------|---------------------------------------------|--------------|----|----|
| trigger_condition | Configure global trigger Boolean condition. | or, and, xor | or | No |
|-------------------|---------------------------------------------|--------------|----|----|

3. Enter the command “debugger info --cable <index> --device <dev>” and press Enter to verify the settings of the OCLA on clock domain.



Figure 77. Info command output with OCLA settings

### 6.1.5. Configure OCLA Trigger

The OCLA IP supports various trigger types that can be used to monitor the connected signals of a user design. The users can set up multiple triggers on signals with different combinations of trigger types for a specific scenario that they want to capture.

Below are steps to configure a trigger: -

1. In the console, enter the command “debugger add\_trigger --cable <index> --device <dev> --domain <n> --probe <m> --signal <name> --type <type> --event <event> --value <val> --compare\_width <width>” and press Enter to add a trigger into a OCLA clock domain.
2. Following are the details of the command options: -

| Option | Description                                              | Possible value                            | Default | Mandatory |
|--------|----------------------------------------------------------|-------------------------------------------|---------|-----------|
| cable  | Specify the index or name of the JTAG cable              | Integer starts from 1 or name             | 1       | No        |
| device | Specify the index of the device on the cable             | Integer starts from 1                     | 1       | No        |
| domain | Specify the index of the OCLA clock domain to configure. | Integer starts from 1 to max clock domain | -       | Yes       |
| probe  | Specify the index of probe of the signal.                | Integer starts from 1                     | -       | Yes       |
| signal | Specify signal name or index to configure a trigger on.  | Integer starts from 1 or signal name      | -       | Yes       |

|               |                                                                                                                                                                                                                                                                                                                         |                                                            |        |    |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|--------|----|
|               | <b>NOTE:</b> When configuring a value compare trigger, the bit array notation “{signal[end:start]}” can be utilized to designate a subrange of bits within a bus-type signal.                                                                                                                                           |                                                            |        |    |
| type          | Configure the trigger type for the trigger.                                                                                                                                                                                                                                                                             | edge, level, value_compare                                 | edge   | No |
| event         | Configure the trigger event according to the specified trigger type as below: -<br><br>For ‘edge’ trigger: rising, falling, either<br><br>For ‘level’ trigger: high, low<br><br>For ‘value_compare’ trigger: equal, greater, lesser                                                                                     | rising, failing, either, low, high, equal, greater, lesser | rising | No |
| value         | Configure the compare value. This is only required for value_compare trigger type.                                                                                                                                                                                                                                      | 32-bit integer values                                      | 0x0    | No |
| compare_width | Configure the compare width. This is only applicable for value_compare trigger type.<br><br><b>NOTE:</b> When using the bit array notation of signal, the compare width is automatically derived from the selected signal bit range. If this option is provided, the compare width of this option will take precedence. | 1 to 32                                                    | 1      | No |

3. Enter the command “debugger info --cable <index> --device <dev>” and press Enter to verify the trigger configuration on the OCLA of a clock domain.



**Figure 78. Info command output with trigger configuration**

### 6.1.6. Modify and delete existing trigger configuration

Below are steps to modify and delete existing trigger: -

In the console, enter the command “`debugger edit_trigger --cable <index> --device <dev> --index <i> --domain <n> --probe <m> --signal <name> --type <type> --event <event> --value <val> --compare_width <width>`” and press Enter to change an existing trigger configuration specified by the ‘index’ option.

Following are the details of the “`edit_trigger`” command options: -

| Option | Description                                                                                                | Possible value                | Default | Mandatory |
|--------|------------------------------------------------------------------------------------------------------------|-------------------------------|---------|-----------|
| cable  | Specify the index or name of the JTAG cable                                                                | Integer starts from 1 or name | 1       | No        |
| device | Specify the index of the device on the cable                                                               | Integer starts from 1         | 1       | No        |
| index  | Specify the index of the trigger to modify                                                                 | Integer starts from 1         | -       | Yes       |
| -      | <b>NOTE:</b> Please refer to the previous section for details of the common trigger configuration options. | -                             | -       | -         |

Enter the command “`debugger remove_trigger --cable <index> --device <dev> --index <i>`” and press Enter to delete an existing trigger configuration specified by the ‘index’ option.

Following are the details of the “`remove_trigger`” command options: -

| Option | Description                                  | Possible value                | Default | Mandatory |
|--------|----------------------------------------------|-------------------------------|---------|-----------|
| cable  | Specify the index or name of the JTAG cable  | Integer starts from 1 or name | 1       | No        |
| device | Specify the index of the device on the cable | Integer starts from 1         | 1       | No        |

|       |                                            |                       |   |     |
|-------|--------------------------------------------|-----------------------|---|-----|
| index | Specify the index of the trigger to modify | Integer starts from 1 | - | Yes |
|-------|--------------------------------------------|-----------------------|---|-----|

Enter the command “debugger info --cable <index> --device <dev>” and press Enter to verify the changes to the trigger configuration.

### 6.1.7. Start OCLA and visualize sample waveform in GTKWave

After configuring the OCLA and setting up the trigger configuration, OCLA IP needs to be armed so that the IP will start monitoring the trigger conditions the user configured.

Below are steps to start the OCLA IP: -

1. In the console, enter the command “debugger start --cable <index> --device <dev> --domain <n> --timeout <seconds> --output <filepath>” and press Enter to start the OCLA IP.
2. Following are the details of the command options: -

| Option  | Description                                                                                                                                                              | Possible value                            | Default         | Mandatory |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|-----------------|-----------|
| cable   | Specify the index or name of the JTAG cable                                                                                                                              | Integer starts from 1 or name             | 1               | No        |
| device  | Specify the index of the device on the cable                                                                                                                             | Integer starts from 1                     | 1               | No        |
| domain  | Specify the index of the OCLA clock domain to configure.                                                                                                                 | Integer starts from 1 to max clock domain | -               | Yes       |
| timeout | Command timeout in seconds<br><br><b>NOTE:</b><br>This is a blocking command that will complete and return when trigger condition is met, or the timeout period exceeds. | 1 to max of 32-bit unsigned integer       | 60              | No        |
| output  | Output waveform filepath                                                                                                                                                 | Filesystem path                           | /tmp/output.fst | No        |

3. When the trigger condition hits, the acquired samples are downloaded from the IP internal buffer and GTKWave is opened to visualize the samples in digital waveform as illustrated in the figures below: -



Figure 79. Start command output when capture succeed



**Figure 80. GTKWave showing digital waveform of the captured samples**

4. If the command timeout, the error message will be shown in the illustration below. Timeout could mean the trigger condition configured doesn't happen in that period. Users can reconfigure the OCLA and/or trigger configuration and run the command again.



**Figure 81. Start command timeout message**

## 6.2. Emulate-IO (EIO) Support

The Emulate-IO (EIO) IP provides input and output probes to sample and drive signals on FPGA fabric. Designers can incorporate EIO IP into their designs to emulate IO signals within the FPGA for testing or debugging purposes, eliminating the need for physical IO pins.

### 6.2.1. Inspect EIO input & output signal information

The EIO information is included in the OCLA debug data. Therefore, to work with EIO, one must load the OCLA debug information from a user design .bitasm file.

Below are steps to load and query EIO information: -

In the console, enter the command “`debugger load --file <filepath to .bitasm>`” and press Enter to load the OCLA debug information from a user design in a bit assembler file with .bitasm extension.

Enter the command “`debugger info --cable <index> --device <dev>`” and press Enter to inspect the EIO information.

**NOTE:** EIO section will be at the bottom of the console's text output. Below illustration has trimmed the middle portion to reveal the EIO section at the bottom.



The screenshot shows the Rapid Silicon Raptor Design Suite interface. The top menu bar includes File, Project, Run, View, Tools, and Help. Below the menu is a toolbar with icons for File, Project, Run, View, Tools, Help, and a search bar. The main workspace is divided into several panes: a Source pane on the left showing a project structure with 'Design Sources(0)', 'Constraints(0)', 'Simulation Sources(0)', and 'IP Instances(0)'; a central workspace; a 'RapidGPT' pane on the right containing an 'Incognito mode' section and a text input field 'Ask me anything'; and a 'Console' pane at the bottom displaying the following text:

```
# debugger load --file /home/chernyee/development/my_counter_design.bitasm
# debugger info
# INFO: User design loaded: /home/chernyee/development/my_counter_design.bitasm
# INFO: Clock Domain 1:
# INFO: Probe 1

# INFO: EIO:
# INFO: In-Probe 1
# INFO: +-----+
# INFO: | Index | Signal Name           | Bitwidth |
# INFO: +-----+
# INFO: |   1   | counter1                 | 48        |
# INFO: |   2   | counter2                 | 8         |
# INFO: |   3   | counter3                 | 8         |
# INFO: +-----+
# INFO: Out-Probe 1
# INFO: +-----+
# INFO: | Index | Signal Name           | Bitwidth |
# INFO: +-----+
# INFO: |   1   | start                   | 1         |
# INFO: |   2   | stop                    | 1         |
# INFO: +-----+
# INFO:
# INFO: NOTES
# INFO: Use the 'loop' & 'interval' (in milisecond) options to repeatedly read
# INFO: the state of the input signals for specific number of times.
# INFO:

#
```

Figure 82. EIO Input/Output Signal Information

### 6.2.2. Read EIO Input IO state

The EIO inputs are the signal output routed from a user design into the EIO IP. This allows the designer to read signal states in real time to analyze the behavior of the design.

Below are steps to read the EIO input IO state: -

In the console, enter the command “`debugger get_io --cable <index> --device <dev> --loop <num> --interval <milliseconds> <signal1> <signal2> ...`” and press Enter to read the state of the specified signals in the arguments.

Following are the details of the command options: -

| Option      | Description                                                                                         | Possible value                      | Default | Mandatory            |
|-------------|-----------------------------------------------------------------------------------------------------|-------------------------------------|---------|----------------------|
| cable       | Specify the index or name of the JTAG cable                                                         | Integer starts from 1 or name       | 1       | No                   |
| device      | Specify the index of the device on the cable                                                        | Integer starts from 1               | 1       | No                   |
| loop        | Read for a specified number of times                                                                | Integer                             | 1       | No                   |
| interval    | Time interval between reads in millisecond                                                          | 1 to max of 32-bit unsigned integer | 100     | No                   |
| arg1...argN | List of signal names or indexes to read.<br><br>Example: -<br><code>debugger get_io s1 s2 #3</code> | Signal name or index with # prefix  | -       | Minimum one argument |



Figure 83. EIO Read Input IO State

### 6.2.3. Configure EIO Output IO state

The EIO outputs are signals routed from the EIO IP to the input signals of the user design. This enables users to drive input signals from outside of the design, allowing them to, for example, toggle features on and off or simulate external inputs to the design.

Below are steps to configure/set the EIO output IO state: -

In the console, enter the command “`debugger set_io --cable <index> --device <dev> <signal1=value> <signal2=value>`” and press Enter to configure the output signals according to the specified arguments.

Following are the details of the command options: -

| Option                | Description                                                                                                   | Possible value                     | Default | Mandatory            |
|-----------------------|---------------------------------------------------------------------------------------------------------------|------------------------------------|---------|----------------------|
| cable                 | Specify the index or name of the JTAG cable                                                                   | Integer starts from 1 or name      | 1       | No                   |
| device                | Specify the index of the device on the cable                                                                  | Integer starts from 1              | 1       | No                   |
| arg1=val1...argN=valN | List of signal names or indexes and values to set.<br><br>Example: -<br>debugger set_io s1=1<br>s2=0x123 #3=0 | Signal name or index with # prefix | -       | Minimum one argument |



Figure 84. EIO Configure/Set Output IO State

## 7. Using Tcl Scripting

The Tool Command Language, or Tcl, is one of the languages used to interface to the Rapid Silicon Raptor design suite. Rapid Silicon has adopted Tcl as a standard Application Programming Interface (API). The Tcl interpreter built-in to the Raptor Design Suite provides Tcl the ability to control the application, access design objects, and create reports.

Tcl provides built-in commands to read and write files within the local Raptor file system. These commands allow users to perform tasks such as creating directories, adding files, starting design projects, and running synthesis. The results of the project run are output to a file that can be reviewed by the designer to check for any issues.

### 7.1 Tcl Overview

A Tcl script is a series of Tcl commands. Each command is separated by either a new-line or a semicolon. The built-in Tcl interpreter described above breaks individual commands into segments and performs substitutions as needed.

The Tcl interpreter reads a line from left to right. Similarly, command and variable substitutions are also performed from left to right.

A Tcl word is a string that can be represented as follows:

- A single word
- Multiple words within braces, { }
- Multiple words within quotation marks, " "

Semicolons, brackets, tabs, spaces, and new lines within quotation marks or braces are treated as ordinary characters.

The first word identifies the command, and all subsequent words are passed to the command as arguments.

**NOTE:** In Tcl, a backslash \ is treated as a special character even within braces and quotation marks.

## 7.2 Loading and Running Tcl Scripts

The Raptor Design Suite offers three ways to load and run a Tcl script during a design session

- Load script files automatically when the Raptor design suite is launched
- Run a script from the Tcl command line
- Add the Tcl script to the menu selections in the Raptor design suite.

### 7.2.1 Automatically Load Tcl Scripts

The Raptor Design Suite can automatically load Tcl scripts that are defined in the raptor\_init.tcl file. The benefit of this method is that Tcl procedures which define new commands are made available to all Raptor design sessions.

### 7.2.2 Invoking a Tcl Script at Power-up

A Tcl script to be executed at power-up from the command line using the -script option:

```
raptor --script <path-to-script>
```

### 7.2.3 Tcl Script Source Command

The source command allows the Tcl script files to be manually loaded into the Raptor design suite.

### 7.2.4 Adding Constraints to Tcl Scripts

Tcl scripts can be added to project constraint sets like any regular Raptor file. However, since the Raptor files are managed by the tool and not Tcl scripts, any constraints defined by a Tcl script and edited by the tool cannot be saved back to the Tcl script automatically. Rather, the edited file must be saved to memory, then it can be used to manually update the Tcl script.

## 7.3 Writing a Tcl Script

When writing a Tcl script, the script should provide the same type of functionality as the embedded Raptor commands. An example would be the Help command. When the user types Help on the command line, the output should provide the same relative amount of information as would be displayed when clicking on the Help button in the GUI.

### 7.3.1. Adding Arguments to a Tcl Script

When writing a Tcl script, it is advantageous for the programmer to add arguments to a procedure. These arguments help to reduce the amount of redundant code, while at the same time allowing the procedure to handle multiple contexts.

### 7.3.2. Types of Variables

A Tcl script typically contains both local and global variables. A local variable is created inside a Tcl procedure and is only accessible within that procedure. As such, it is not subject to name collision with the same variable name outside the procedure.

## 7.4. Loop Control and Iteration

The Tcl language uses the following commands to implement loops and perform iterations through a loop:

- for
- foreach
- while

## 7.5. Error Handling

The Raptor design suite stops at the first Tcl error it encounters. If the error is coming from a script, it points to the file and line number. It also shows a Tcl stack trace.

### 7.5.1. Corner Cases and Incorrect Script Usage

When writing a Tcl scripts, Rapid Silicon recommends that the user check for corner cases or other conditions that could cause the code to fail. These checks can sometimes indicate the script was being used incorrectly. Checking for these conditions is important to avoid having the script stop abruptly. Without these checks, the user will not know what went wrong or what corrective action should be taken.

### 7.5.2. Tcl Script Errors

As mentioned in the previous section, an error in the Tcl script can abruptly halt the execution of the script. If this occurs, the Raptor design suite will generate a Tcl error message.

## 7.6. Interfacing to External Programs

The Tcl interpreter inside the Raptor design suite allows for calling external programs from within Tcl and capturing the result of that program. The user should be explicit when calling external programs or commands to ensure data integrity.

## 7.7. Tcl Commands

Raptor executable options:

- help : This help
- version : Version
- batch : Tcl only, no GUI
- script <script>: Execute a Tcl script
- project <project file>: Open a project
- mute : mutes stdout in batch mode

The following is a list of Tcl commands supported by the Raptor design suite.

Tcl commands are available in GUI mode, Batch console, or Batch script. For bellow table, arguments inside two question marks is optional: ?-optional argument?

### General Tcl Commands:

| Tcl Command & Arguments | Description                                                                                                           |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------|
| help                    | Help                                                                                                                  |
| send                    | Command to send message                                                                                               |
| reset                   | Command to reset history                                                                                              |
| -c <path>               | Specify ini file path with API key. The key needs to be set only once for a session<br>[OpenAI]<br>API_KEY: <api key> |

## Project Tcl Commands:

| Tcl Command & Arguments                                                                                                          | Description                                                                                                                                                                                                                                                                                                                |
|----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| create_design <name> ?clean? ?-type <project type>?<br><br><project type><br>clean                                               | Creates a design with <name> name<br><br>rtl (Default), gate-level<br>If project folder already exists, remove recursively folder content                                                                                                                                                                                  |
| open_project <file>                                                                                                              | Opens a project                                                                                                                                                                                                                                                                                                            |
| run_project <file>                                                                                                               | Opens and immediately runs the project                                                                                                                                                                                                                                                                                     |
| device_file <file>                                                                                                               | Set file <file> with supported devices which replaces default file (device.xml)                                                                                                                                                                                                                                            |
| target_device <name>                                                                                                             | Targets a device with <name> (default is 1GE75)                                                                                                                                                                                                                                                                            |
| add_design_file <file list> ?type? ?-work <libName>? ?-L <libName>?<br><br><type><br><br>-work <libName><br><br>-L <libName>     | -VHDL_1987, -VHDL_1993, -VHDL_2000, -VHDL_2008, -VHDL_2019, -<br><br>V_1995, -V_2001, -SV_2005, -SV_2009, -SV_2012, -SV_2017, default auto-detect<br><br>Compiles the compilation unit into library <libName>, default is "work"<br>Import the library <libName> needed to compile the compilation unit, default is "work" |
| set_top_module <top> ?-work <libName>?                                                                                           | Sets the top-level design module/entity for synthesis                                                                                                                                                                                                                                                                      |
| add_include_path <paths>                                                                                                         | Specify paths for Verilog includes (Not applicable to VHDL)                                                                                                                                                                                                                                                                |
| add_library_path <paths>                                                                                                         | Specify paths for libraries (Not applicable to VHDL)                                                                                                                                                                                                                                                                       |
| add_library_ext <ext>                                                                                                            | Specify library extensions (Not applicable to VHDL)                                                                                                                                                                                                                                                                        |
| set_macro <name>=<value>                                                                                                         | As in -D<macro>=<value>                                                                                                                                                                                                                                                                                                    |
| read_netlist <file>                                                                                                              | Read a netlist (.blif.eblif) instead of an RTL design (Skip Synthesis)                                                                                                                                                                                                                                                     |
| add_constraint_file <file>                                                                                                       | Sets constraints file (SDC) filename and location                                                                                                                                                                                                                                                                          |
| add_simulation_file <file list> ?type? ?-work <libName>? ?-L <libName>?<br><br><type><br><br>-work <libName><br><br>-L <libName> | -VHDL_1987, -VHDL_1993, -VHDL_2000, -VHDL_2008, -VHDL_2019, -<br><br>V_1995, -V_2001, -SV_2005, -SV_2009, -SV_2012, -SV_2017, -C, -CPP<br><br>Compiles the compilation unit into library <libName>, default is "work"<br>Import the library <libName> needed to compile the compilation unit, default is "work"            |
| set_top_testbench <module>                                                                                                       | Sets the top-level testbench module/entity for simulation                                                                                                                                                                                                                                                                  |
| clear_simulation_files                                                                                                           | Remove all simulation files                                                                                                                                                                                                                                                                                                |
| script_path                                                                                                                      | Returns the path of the Tcl script passed with --script                                                                                                                                                                                                                                                                    |
| max_threads <-1/[2:64]>                                                                                                          | Maximum number of threads to be used (-1 is for automatic selection)                                                                                                                                                                                                                                                       |

|                                                                            |                                                                                       |
|----------------------------------------------------------------------------|---------------------------------------------------------------------------------------|
| <code>set_device_size XxY</code>                                           | Device fabric size selection                                                          |
| <code>custom_openfpga_script &lt;file&gt;</code>                           | Uses a custom OpenFPGA templated script                                               |
| <code>architecture &lt;vpr_file.xml&gt; ?&lt;openfpga_file.xml&gt;?</code> | Uses the architecture file and optional openfpga arch file (For bitstream generation) |

**Constraints Tcl Commands:**

| Tcl Command & Arguments                                                                                    | Description                                                                                                                                                                                                    |
|------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>keep &lt;signal list&gt; OR all_signals</code>                                                       | Keeps the list of signals or all signals through Synthesis unchanged (unoptimized in certain cases)                                                                                                            |
| <code>message_severity &lt;message_id&gt; &lt;ERROR/WARNING/INFO/IGNORE&gt;</code>                         | Upgrade/downgrade message severity                                                                                                                                                                             |
| <code>set_pin_loc &lt;design_io_name&gt; &lt;device_io_name&gt; ?&lt;internal_pinname&gt;?</code>          | Constraints pin location (Use in constraint.pin file)                                                                                                                                                          |
| <code>set_property mode &lt;io_mode_name&gt; &lt;device_io_name&gt;</code>                                 | Constraints pin mode (Use in constraint.pin file)                                                                                                                                                              |
| <code>set_clock_pin -device_clock &lt;device_clock_name&gt; -design_clock &lt;design_clock_name&gt;</code> | like gemini has 16 clocks clk[0],clk[1]....,clk[15] and e.g. user clocks are clk_a, clk_b and want to map clk_a with clk[15]<br>constraints: set clocks for repacking constraints (Use in constraint.pin file) |

**IP Tcl Commands:**

| Tcl Command & Arguments                                                                                                                                 | Description                                                                              |
|---------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|
| <code>add_litex_ip_catalog &lt;directory&gt;</code>                                                                                                     | Browses directory for LiteX IP generators, adds the IP(s) to the IP Catalog              |
| <code>ip_catalog ?&lt;ip_name&gt;?</code>                                                                                                               | Lists all available IPs, and their parameters if <ip_name> is given                      |
| <code>configure_ip &lt;IP_NAME&gt; -mod_name &lt;name&gt; -out_file &lt;filename&gt; -version &lt;ver_name&gt; -P&lt;param&gt;=&lt;value&gt;"...</code> | Configures an IP <IP_NAME> and generates the corresponding file with module name         |
| <code>ipgenerate ?clean? clean</code>                                                                                                                   | Generates all IP instances set by ip_configure<br>Deletes files generated from this task |
| <code>simulate_ip &lt;module name&gt;</code>                                                                                                            | Simulate IP with module name <module name>                                               |

**Simulation Tcl Commands:**

| Tcl Command & Arguments                                                                                        | Description                                                                                                                                                              |
|----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>simulation_options &lt;simulator&gt; &lt;phase&gt; ?&lt;level&gt;? &lt;options&gt; &lt;phase&gt;</code>  | Sets the simulator specific options for the specified phase<br><br>compilation, elaboration, simulation, extra_options                                                   |
| <code>simulate&lt;level&gt; ?&lt;simulator&gt;? ?&lt;waveform_file&gt;? &lt;level&gt; &lt;simulator&gt;</code> | Simulates the design and testbench<br><br>rtl, gate, pnr, rtl : RTL simulation, gate: post-synthesis simulation, pnr: post-pnr simulation<br><br>verilator, ghdl, icarus |
| <code>wave_*</code>                                                                                            | All wave commands will launch a GTKWave process if one hasn't been launched already. Subsequent commands will be sent to the launched process                            |

|                      |                                                                                                        |
|----------------------|--------------------------------------------------------------------------------------------------------|
| wave_cmd ...         | Sends given tcl commands to GTKWave process.<br>See GTKWave docs for gtkwave :: commands               |
| wave_open <filename> | Load given file in current GTKWave process                                                             |
| wave_refresh         | Reloads the current active wave file                                                                   |
| wave_show <signal>   | Add the given signal to the GTKWave window and highlight it                                            |
| wave_time <time>     | Set the primary marker to <time>. Time units can be specified, without a space. Ex:<br>wave_time 100ps |

## Synthesis Tcl Commands:

| Tcl Command & Arguments                                                                                                                                                                                                                                                                                                                                                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| synth_options <option list><br>-efort <level><br>high<br>medium<br>low<br>-fsm_encoding <encoding><br>binary<br>onehot<br>-carry <mode><br>all<br>auto<br>none<br>-clke_strategy <strategy><br>early<br>late<br>-fast<br>-no_flatten<br>-no_simplify<br>-no_tribuf<br>-no_adder<br>-inferred_io<br>-no_inferred_io<br>-clke_strategy <strategy><br>early<br>late<br>-cec | Optimization effort level (high, medium, low)<br>Most compute, generally impacting runtime (default)<br>Balanced compute<br>least compute, least runtime<br>FSM encoding (binary, onehot)<br>Compact encoding - using minimum of registers to cover the N states<br>One hot encoding - using N registers for N states (default)<br>Carry logic inference mode (all, auto, none)<br>Infer as much as possible<br>Infer carries based on internal heuristics (default)<br>Do not infer carries<br>Clock enable extraction strategy for FFs (early, late)<br>Perform early extraction (default)<br>Perform late extraction<br>Perform the fastest synthesis. QoR can be impacted<br>Do not flatten design<br>Do not run special simplification algorithms in synthesis<br>Do not preserve I/O tristate buffers<br>Do not infer adders<br>Automatic I/O inference (Default false for eFPGA)<br>No automatic I/O inference (Default true for FPGA)<br>Clock enable extraction strategy for FFs<br>Perform early extraction<br>Perform late extraction<br>Dump verilog after key phases and use internal equivalence checking (ABC based) |
| set_limits <type> <int><br>dsp<br>bram<br>carry_length                                                                                                                                                                                                                                                                                                                   | Sets a user limit on object of type (dsp, bram), specify 0 to disable block inference<br>Maximum number of usable DSPs<br>Maximum number of usable BRAMs<br>Maximum carry length                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| analyze ?clean?<br>clean                                                                                                                                                                                                                                                                                                                                                 | Analyzes the RTL design, generates top-level, pin and hierarchy information<br>Deletes files generated from this task                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

|                                                      |                                                                                                                                                                                                                                   |
|------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>synthesize &lt;optimization&gt; ?clean?</code> | RTL Synthesis, optional opt. (area, delay, mixed)<br>area, delay, mixed<br>Optimize for reduce resource area<br>Optimize for performance<br>Optimize for area and performance (default)<br>Deletes files generated from this task |
| <code>synthesis_type Yosys/QL/RS</code>              | Selects Synthesis type                                                                                                                                                                                                            |
| <code>custom_synth_script &lt;file&gt;</code>        | Uses a custom Yosys templated script                                                                                                                                                                                              |

### Packing Tcl Commands

| Tcl Command & Arguments                          | Description                                                                                             |
|--------------------------------------------------|---------------------------------------------------------------------------------------------------------|
| <code>pnr_netlist_lang &lt;format&gt;</code>     | Chooses post-synthesis netlist format, (blif, edif, eblif, verilog, vhdl)                               |
| <code>packing_options &lt;option list&gt;</code> | Packing options                                                                                         |
| <code>-clb_packing &lt;directive&gt;</code>      | Performance optimization flags (auto, dense, timing_driven)                                             |
| <code>auto</code>                                | CLB packing automatically determined (default)                                                          |
| <code>dense</code>                               | Pack logic more densely into CLBs resulting in fewer utilized CLBs however may negatively impact timing |
| <code>timing_driven</code>                       | Pack logic to optimize timing                                                                           |
| <code>packing ?clean?</code>                     | Packing                                                                                                 |
| <code>clean</code>                               | Deletes files generated from this task                                                                  |

### Place Tcl Commands:

| Tcl Command & Arguments                           | Description                                                            |
|---------------------------------------------------|------------------------------------------------------------------------|
| <code>pin_loc_assign_method &lt;method&gt;</code> | Algorithm for automatic pin assignment (in_define_order, random, free) |
| <code>in_define_order</code>                      | Port order pin assignment (default)                                    |
| <code>random</code>                               | Random pin assignment                                                  |
| <code>free</code>                                 | No automatic pin assignment                                            |
| <code>place ?clean?</code>                        | Placer                                                                 |
| <code>clean</code>                                | Deletes files generated from this task                                 |
| <code>pnr_options &lt;option list&gt;</code>      | PnR Options                                                            |

### Route Tcl Commands:

| Tcl Command & Arguments                    | Description                            |
|--------------------------------------------|----------------------------------------|
| <code>route ?clean?</code>                 | Router                                 |
| <code>clean</code>                         | Deletes files generated from this task |
| <code>set_channel_width &lt;int&gt;</code> | VPR Routing channel setting            |

**Static Timing Analysis Tcl Commands:**

| Tcl Command & Arguments | Description                                                           |
|-------------------------|-----------------------------------------------------------------------|
| sta ?clean?<br>clean    | Statistical Timing Analysis<br>Deletes files generated from this task |

**Power Analysis Tcl Commands:**

| Tcl Command & Arguments | Description                                                          |
|-------------------------|----------------------------------------------------------------------|
| power ?clean?<br>clean  | Statistical Power Analysis<br>Deletes files generated from this task |

**Bitstream Tcl Commands:**

| Tcl Command & Arguments                                                                                                             | Description                                                    |
|-------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|
| bitstream ?force? ?clean? ?enable_simulation? ?write_xml? ?write_fabric_independent? ?pb_pin_fixup?<br>clean                        | Bitstream generation<br>Deletes files generated from this task |
| bitstream_config_files -bitstream <bitstream_setting.xml> -sim <sim_setting.xml> -repack <repack_setting.xml> -key <fabric_key.xml> | Uses alternate bitstream generation configuration files        |

**Program & Debug Tcl Commands:**

| Tcl Command & Arguments                                                            | Description                                                                                                  |
|------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|
| programmer <command><br>command                                                    | fpga_config, flash, otp, fpga_status, list_device, list_cable                                                |
| fpga_config -c <cable name/index> ?-d <device_index>? <bitstream_file>             | Program the device via JTAG                                                                                  |
| flash -c <cable name/index> ?-d <device_index>? ?-o <operations>? <bitstream_file> | Program the flash via JTAG                                                                                   |
| otp -c <cable name/index> -d <device_index> ?-y? <bitstream_file>                  | Program the device OTP via JTAG.<br>WARNING: OTP programming is not reversible once programmed successfully. |
| fpga_status -c <cable name/index> -d <device_index>                                | Query FPGA Configuration Done and Configuration IsError status for a specified device                        |
| list_device ?-c <cable name/index>? ?-v?                                           | List all available devices or specified cable devices                                                        |
| list_cable ?-v?                                                                    | List all connected USB programmer cables                                                                     |

**OCLA Debugger Tcl Commands:**

| Tcl Command & Arguments       | Description                                                                |
|-------------------------------|----------------------------------------------------------------------------|
| debugger <command><br>command | load, unload, info, status, start, show_waveform, list_cable, list_device, |

|                                                                                                                                                                                                    |                                                                                                                                                  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                    | config, add_trigger, edit_trigger,<br>remove_trigger, set_io, get_io                                                                             |
| load -f <filepath>                                                                                                                                                                                 | Start a debugging session with user design specified in a .bitasm file.                                                                          |
| unload                                                                                                                                                                                             | Stop the debugging session and clear the loaded OCLA information.                                                                                |
| info ?-b <cable name/index>? ?-d <device index>?                                                                                                                                                   | Command to display all probe information in the user design parsed from the .bitasm file. And the current OCLA global and trigger configuration. |
| status -n <clock domain id> ?-b <cable name/index>? ?-d <device index>?                                                                                                                            | To query the clock domain sampling status.                                                                                                       |
| start -n <clock domain id> ?-b <cable name/index>? ?-d <device index>? ?-t <seconds>? ?-o <filepath>?                                                                                              | To start the OCLA debug subsystem of a clock domain to capture signal samples.                                                                   |
| show_waveform -n <clock domain id> ?-b <cable name/index>? ?-d <device index>? ?-o <filepath>?                                                                                                     | To generate waveform file and display the signal waveform of a clock domain in GtkWave UI app.                                                   |
| list_cable ?-v?                                                                                                                                                                                    | To display all the connected/detected cables.                                                                                                    |
| list_device ?-v?                                                                                                                                                                                   | To display list of connected devices to each connected/detected cable.                                                                           |
| config -n <clock domain id> ?-m <trigger mode>? ?-s <sample size>? ?-t <boolean condition>? ?-b <cable name/index>? ?-d <device index>?                                                            | To configure the global operation modes of a clock domain.                                                                                       |
| add_trigger -n <clock domain id> -p <probe id> -s <signal name> ?-t <trigger type>? ?-e <trigger event>? ?-v <value>? ?-w <compare width>? ?-b <cable name/index>? ?-d <device index>?             | To add a trigger configuration into a clock domain.                                                                                              |
| edit_trigger -n <clock domain id> -i <index> -p <probe id> -s <signal name> ?-t <trigger type>? ?-e <trigger event>? ?-v <value>? ?-w <compare width>? ?-b <cable name/index>? ?-d <device index>? | To edit an existing trigger configuration of a clock domain.                                                                                     |
| remove_trigger -n <clock domain id> -i <index> ?-b <cable name/index>? ?-d <device index>?                                                                                                         | To remove an existing trigger configuration from a clock domain.                                                                                 |
| set_io ?-b <cable name/index>? ?-d <device index>? <signal1=value1> <signal2=value2>                                                                                                               | To configure the state/value of an IO signal.                                                                                                    |
| get_io ?-l <times>? ?-t <milliseconds>? ?-b <cable name/index>? ?-d <device index>? <signal1> <signal2>                                                                                            | To read the state/value of an IO signal.                                                                                                         |

## 7.8 Using RapidGPT in Raptor

1. Raptor has an integrated AI Chatbot called RapidGPT from PrimisAI tailored for hardware engineers. Read more about it at <https://primis.ai/>.
2. RapidGPT chatbot will open by default as long as it's enabled under the View menu.
3. Each chat instance is currently tied to each file that's open and we also maintain the history if the file is closed and re-opened.
4. To set it up, one needs to get the API key from PrimisAI at <https://primis.ai/#pricing>
5. Save the key in the RapidGPT settings under File -> Preferences -> RapidGPT settings as shown in below Figure X.



Figure 84. RapidGPT settings

```

1 `timescale 1ns / 1ps
2 ///////////////////////////////////////////////////////////////////
3 // Rapid Silicon Raptor Example Design
4 // and2.v - Top-level file of simple 2-input AND gate //
5 ///////////////////////////////////////////////////////////////////
6
7 module and2 (
8     input a,
9     input b,
10    input clk,
11    input reset,
12    output reg c = 1'b0
13 );
14
15    reg a_reg, b_reg = 1'b0;
16
17    always@(posedge clk)
18        if (reset) begin
19            a_reg <= 1'b0;
20            b_reg <= 1'b0;
21            c <= 1'b0;
22        end else begin
23            a_reg <= a;
24            b_reg <= b;
25            c <= a_reg & b_reg;
26        end
27
28 endmodule
29
30

```

2.17 Sec 02/06/2024, 21:56:00

>User Tell me about the module and2 02/06/2024, 21:56:09

RapidGPT

The 'and2' module is a simple 2-input AND gate implemented in Verilog. It has four input ports: 'a', 'b', 'clk', and 'reset', and one output port 'c'. Here's a breakdown of the module:

- Inputs:
  - 'a' and 'b': These are the two input signals to the AND gate.
  - 'clk': This is the clock signal used for synchronous operation.
  - 'reset': This is the reset signal used to initialize the internal registers and output.
- Outputs:
  - 'c': This is the output signal of the AND gate.

The module also includes two internal registers, 'a\_reg' and 'b\_reg', which are used to store the previous values of inputs 'a' and 'b', respectively. The output 'c' is computed as the logical AND of 'a\_reg' and 'b\_reg'.

The behavior of the 'and2' module is as follows:
 

- On the positive edge of the clock ('clk'), if the 'reset' signal is asserted, all internal registers and the output 'c' are reset to 0.
- If the 'reset' signal is not asserted, the values of 'a' and 'b' are stored in 'a\_reg' and 'b\_reg' respectively, and the output 'c' is updated with the logical AND of 'a\_reg' and 'b\_reg'.

Please let me know if you need any further information or if you would like to see the Verilog code for this module.

5.33 Sec 02/06/2024, 21:56:14

Ask me anything

Figure 85. RapidGPT chat example

## 8. Examples

### 8.1. Tcl Examples

The installation directory contains several Tcl script example designs under;

<install\_path>/share/raptor/tcl\_examples

For instance, refer to:

raptor --script <install\_path>/share/raptor/tcl\_examples/aes\_decrypt\_fpga/aes\_decrypt.tcl  
(GUI mode)

Or

```
raptor --script <install_path>/share/raptor/tcl_examples/aes_decrypt_fpga/aes_decrypt.tcl --batch  
(Batch mode)
```

## 8.2 Project Examples

The installation directory contains several GUI project examples. From the GUI you can select them using the menu:

File → Select example design

## 8.3 Example Designs

Raptor installation contains example designs, there are two type of example design.

- LiteX SoC based example design
  - Based on VEXRISCV Soft CPU, LiteX, Migen generated IPs and Native Verilog IP
  - Design Name:
    - vexrisc\_axi\_gpio
    - vexrisc\_axi\_ram
    - vexrisc\_axi\_hello\_world
- Native RTL example SoC Design:
  - This has VEXRISCV Soft CPU, AXI interconnect and AXI BRAM, It also has Bare Metal C Code to perform test on the design. User can simulate this design using Verilator simulator and compile on Raptor
  - Design name: vexriscv\_axi\_ram
- How to Run LiteX SoC simulation:
  - Command: <Raptor Installation area> /share/envs/litex/bin/python3 litex\_sim\_rs.py
  - Each of example design has README file, which describes the steps to simulate with Verilator and compile the design on Raptor
- Path of example designs: <Raptor Installation area> /share/litex\_reference\_design

**Notes:**

- LiteX is installed on user machine as a part of Raptor Installation setup. For more information refer to *Raptor Installation Guide*.
  - LiteX installation path: <Raptor Installation area> /share/envs/litex/bin
- LiteX dependency and how to install these:
  - Python dependency for LiteX:
    - Command to install: pip3 install meson ninja
  - Verilator simulator & other OS dependency:
    - Command to install: sudo apt install libevent-dev libjson-c-dev verilator
  - RISC-V Tool Chain:
    - CentOS: [https://static.dev.sifive.com/dev-tools/freedom-tools/v2020.08/riscv64-unknown-elf-gcc-10.1.0-2020.08.2-x86\\_64-linux-centos6.tar.gz](https://static.dev.sifive.com/dev-tools/freedom-tools/v2020.08/riscv64-unknown-elf-gcc-10.1.0-2020.08.2-x86_64-linux-centos6.tar.gz)
    - Ubuntu: [https://static.dev.sifive.com/dev-tools/freedom-tools/v2020.08/riscv64-unknown-elf-gcc-10.1.0-2020.08.2-x86\\_64-linux-ubuntu14.tar.gz](https://static.dev.sifive.com/dev-tools/freedom-tools/v2020.08/riscv64-unknown-elf-gcc-10.1.0-2020.08.2-x86_64-linux-ubuntu14.tar.gz)

## 9 Formal Verification

The Raptor post-synthesis netlist can be formally verified through Formal Verification tools like OneSpin or Formality. This formal verification consists to compare the original RTL design description versus the post-synthesis netlist. Note that this verification requires to add to the netlist description the associated Rapid Silicon primitives that are defined in file “cells\_sim.v” or “cells\_sim.vhd” depending if the netlist output format is Verilog or VHDL.

### 9.1 Formal Verification Using VHDL

The following figure is a typical tcl script to provide to OneSpin in order to compare for instance the RTL description of design “rtea” versus the post-synthesis netlist in VHDL:

```

load_settings ec_fpga_rtl

read_vhdl -golden -pragma_ignore {} -version 2008 {
    rtea.vhdl
}
set_elaborate_option -golden -top {vhdl!work.rtea(behave)}

read_vhdl -revised -pragma_ignore {} -version 2008 {
    cells_sim.vhd \
    post_synthesis_netlist.vhd
}
set_elaborate_option -revised -top {vhdl!work.rtea(arch)}

elaborate -both

compile -both
set_mode ec
map
compare

exit -force

```

Figure 86. OneSpin Tcl Script – VHDL

## 9.2 Formal Verification Using Verilog

The following figure\_is a typical tcl script to provide to OneSpin in order to compare for instance the RTL description of design “rtea” versus the post-synthesis netlist in Verilog:

```

load_settings ec_fpga_rtl

read_verilog -golden -pragma_ignore {} -version sv2012 {
    rtea.v
}
set_elaborate_option -golden -top {verilog!work.rtea}

read_verilog -revised -pragma_ignore {} -version sv2012 {
    cells_sim.v \
    post_synthesis_netlist.v
}

set_elaborate_option -revised -top {verilog!work.rtea}

elaborate -both

compile -both
set_mode ec
map
compare

exit -force
~
```

Figure 87. OneSpin Tcl Script - Verilog

### 9.3 Formal Verification Using Formality

Formality can also be used. A classic Formality script with VHDL RTL language can look like that shown in the following figure:

```

set synopsys_auto_setup true
set hdlin_vhdl_auto_file_order False

# = = = = = = = = = = = = = = = = = = = = = =
# Ignore Design Elaboration Warnings
# = = = = = = = = = = = = = = = = = = = = = =
set mismatch_message_filter -warn FMR_ELAB-116
set mismatch_message_filter -warn FMR_ELAB-147
set mismatch_message_filter -warn FMR_ELAB-149

set ReadRef [read_vhdl -container r -libname WORK {
    key_schedule.vhd, round_f.vhd, rtea.vhd
}]

set ref_top [set_top r:/WORK/rtea]

set ReadRev [read_vhdl -container i -libname WORK {
    cells_sim.vhd, post_synthesis_netlist.vhd
}]

set rev_top [set_top i:/WORK/rtea]

# = = = = = = = = = = = = = = = = = = = = = =
# Setup the Tool's Setting For Compare Point Matching
# = = = = = = = = = = = = = = = = = = = = = =

set message_x_source_reporting True
set name_match_based_on_nets False
set name_match port

# = = = = = = = = = = = = = = = = = = = = = =
# Setup the Tool's Setting For Verification Stage
# = = = = = = = = = = = = = = = = = = = = = =

set verification_timeout limit 04:00:00
set verification_run_analyze_points False
set verification_merge_duplicated_registers False
set verification_failing_point_limit 1000
set verification_assume_reg_init Auto
set debug_mode False

if {$ReadRef && $ref_top && $ReadRev && $rev_top} {
    verify
} else {
    puts " ERROR Reading Design Files"
}
report_status > output_rtea.log

```

Figure 88. Using Formality Script in VHDL

## 9.4. View Raptor Post-Synthesis Verilog Netlist in StarVision

The following numbered procedure describes how to view the Raptor post-synthesis Verilog Netlist in the StarVision Pro software.

1. Compile the design using Rapid Silicon's Raptor Software
2. Generate post synthesis Verilog netlist



3. Invoke the StarVision Pro software as shown:

4. Load Raptor post Synthesis Verilog netlist (\*.v /\*.edf /\*.edif file) in StarVision Pro UI





## 5. Analyse schematic view of Raptor Verilog netlist.



## 9.5 MVP Support

The Gemini device supports MVP equivalence checking using OneSpin. Customers should contact OneSpin for support.

# Appendix A Raptor Design Suite Installation Guide

The access to Rapid silicon tools is given through the industry-standard FTP communication protocol. A username and password provided by Rapid Silicon to access our tool (a tar file) is needed. The download

## A.1 Installing Raptor

GUI mode:

Once downloaded, unzip the downloaded tar file either by double clicking on it and then extracting or using the below command:

```
tar -xvzf <Downloaded tar file>
```

Make sure to replace Downloaded tar file with correct name.

Once unzipping is done. Invoke the GUI mode of installer using the below command:

```
./<Raptor .run file>
```

Provide the Raptor .run file name.

This will pop up the GUI installer. Follow the on-screen instructions to do installation.

Note: When choosing installation folder, make sure you have correct write access.

### ***Batch mode or non-gui mode:***

You can also install the Raptor without the GUI. In batch mode you must provide the following command line options:

- -b or --batch-mode -> running in interactive mode. Mandatory if you want to use -r or -i option
- -r or --raptor-home -> you are giving the absolute path of directory where Raptor will be installed
- --accept -> [Mandatory] Grant acceptance of license on command line.

Go to the directory where you have extracted the Raptor executable after downloading and execute it with any or with all above mentioned options like below

```
...  
./Raptor_x.x.run --batch --accept -r <absolute path where Raptor will be  
installed>  
...
```

Replace `x.x` in the name above with the version of Raptor executable file you have received.

## A.2 Verify the Installation

The user can verify the installation using the following commands.

```
source <install_path>/raptorenv_lin64.sh  
raptor --version  
raptor (To verify the GUI compone
```