

# Intel Accelerator Functional Unit Simulation Environment Quick Start User Guide

Updated for  $Intel^{(R)}$  Acceleration Stack for  $Intel^{(R)}$  Xeon<sup>(R)</sup> CPU with FPGAs: **1.2.1 and 2.0.1** 





### **Contents**

| 1. About this Document                                      | 3  |
|-------------------------------------------------------------|----|
| 2. System Requirements                                      | 4  |
| 3. Setting Up the Environment                               | 5  |
| 4. Simulating hello_afu in Client-Server Mode               | 7  |
| 4.1. Simulation in Client-Server Mode                       |    |
| 4.1.1. Simulation Log Files                                 | 9  |
| 4.1.2. Design Declarations                                  | 10 |
| 4.1.3. Troubleshooting Client-Server Simulation             | 10 |
| 5. AFU Examples                                             | 11 |
| 6. Troubleshooting                                          | 13 |
| 7. ASE Quick Start User Guide Archives                      | 14 |
| 8. Document Revision History for ASE Quick Start User Guide | 15 |





### **1. About this Document**

This document describes how to simulate a sample Accelerator Functional Unit (AFU) using the Intel<sup>®</sup> Accelerator Functional Unit (AFU) Simulation Environment (ASE) environment. Refer to the *Intel Accelerator Functional Unit (AFU) Simulation Environment (ASE) User Guide* for comprehensive details on ASE capabilities and internal architecture.

The Intel Accelerator Functional Unit (AFU) Simulation Environment (ASE) is a hardware and software co-simulation environment for any Intel FPGA Programmable Acceleration Card (Intel FPGA PAC). This software co-simulation environment currently supports the following Intel FPGA PACs:

- Intel Programmable Acceleration Card with Intel Arria<sup>®</sup> 10 GX FPGA
- Intel FPGA Programmable Acceleration Card D5005

The ASE provides a transactional model for the Core Cache Interface (CCI-P) protocol and a memory model for the FPGA-attached local memory.

The ASE also validates Accelerator Functional Unit (AFU) compliance to the following protocols and APIs:

- The CCI-P protocol specification
- The Avalon<sup>®</sup> Memory Mapped (Avalon-MM) Interface Specification
- The Open Programmable Acceleration Engine (OPAE)

#### Table 1. Acceleration Stack for Intel Xeon<sup>®</sup> CPU with FPGAs Glossary

| Term                                                                   | Abbreviation             | Description                                                                                                                                                             |
|------------------------------------------------------------------------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Intel Acceleration Stack for Intel Xeon <sup>®</sup><br>CPU with FPGAs | Acceleration Stack       | A collection of software, firmware and<br>tools that provides performance-<br>optimized connectivity between an<br>Intel FPGA and an Intel Xeon<br>processor.           |
| Intel FPGA Programmable Acceleration<br>Card (Intel FPGA PAC)          | Intel FPGA PAC           | PCIe* FPGA accelerator card.<br>Contains an FPGA Interface Manager<br>(FIM) that pairs with an Intel Xeon<br>processor over a PCIe bus.                                 |
| Intel Xeon Scalable Platform with Integrated FPGA                      | Integrated FPGA Platform | Intel Xeon plus FPGA platform with the<br>Intel Xeon and an FPGA in a single<br>package and sharing a coherent cache<br>of memory via Ultra Path Interconnect<br>(UPI). |

#### **Related Information**

Intel Accelerator Functional Unit (AFU) Simulation Environment (ASE) User Guide

Intel Corporation. All rights reserved. Agilex, Altera, Arria, Cyclone, Enpirion, Intel, the Intel logo, MAX, Nios, Quartus and Stratix words and logos are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services. \*Other names and brands may be claimed as the property of others.





# **2. System Requirements**

Here are the system requirements for Intel Accelerator Functional Unit (AFU) Simulation Environment (ASE)::

- A 64-bit Linux operating system. This release validated the following operating systems:
  - For Intel FPGA PAC D5005:
    - RHEL 7.6 with Kernel 3.10.0-957
  - For Intel PAC with Intel Arria 10 GX FPGA:
    - RHEL 7.6 with Kernel 3.10.0-957
    - Ubuntu 18.04 with Kernel 4.15
- One of the following simulators:
  - 64-bit Synopsys\* VCS-MX-2016.06-SP2-1 RTL Simulator
  - 64-bit Mentor Graphics\* Modelsim SE Simulator (Version 10.5c)
  - 64-bit Mentor Graphics QuestaSim Simulator (Version 10.5c)
- C compiler: GCC 4.7.0 or above
- CMake: version 2.8.12 or above
- GNU C Library: version 2.17 or above
- Python: version 2.7
- Intel Quartus<sup>®</sup> Prime Pro Edition software version 19.2<sup>(1)</sup>

Intel Corporation. All rights reserved. Agilex, Altera, Arria, Cyclone, Enpirion, Intel, the Intel logo, MAX, Nios, Quartus and Stratix words and logos are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services. \*Other names and brands may be claimed as the property of others.



<sup>&</sup>lt;sup>(1)</sup> The required version is installed with the **Acceleration Stack for Development** version.



## **3. Setting Up the Environment**

You must set up your simulation environment and install the OPAE software before running the ASE.

- 1. Set the following environment variables for your simulation software:
  - For VCS:

\$ export VCS\_HOME<<pre>path to VCS installation directory>
\$ export PATH=\$VCS\_HOME/bin:\$PATH

The VCS installation directory structure is as follows: admin bin etc gnu include linux mmc suse32 vcfca vgcommon amd64 doc flexlm gui install.log linux64 packages suse64 verific vms

Make sure your system has a valid VCS license.

• For Modelsim SE/QuestaSim:

\$ export MTI\_HOME=<path to Modelsim installation directory> \$ export PATH=\$MTI\_HOME/linux\_x86\_64/:\$MTI\_HOME/bin/:\$PATH

The Modelsim/Questa installation directory structure is as follows:

| avm         | gcc32                  | ieee | LICENSE      | mpich2  | perl src                     | sv std   | uvm-1.1d    | vhdlopt lib |
|-------------|------------------------|------|--------------|---------|------------------------------|----------|-------------|-------------|
| bin         | gcc-4.3.3-linux        |      | linux        | msidata |                              |          |             | vhdl_src    |
|             | gcc-4.3.3-linux_x86_64 |      |              | osver   | RELEASE_NOTES.html           |          |             |             |
|             | gcc-4.5.0-linux        |      |              | OSVVM   | RELEASE_NOTES.txt            |          |             |             |
| drill_src   | gcc-4.5.0-linux_x86_64 |      |              |         |                              |          | VCO         |             |
|             | gcc-4.7.4-linux        |      |              |         | std                          |          | verilog     |             |
| floatfixlib | gcc-4.7.4-linux x86 64 | lib  | modelsim lib | pa_lib  | <pre>std_developerskit</pre> | uvm-1.1c | verilog_src | vovl_src    |

Make sure your system has a valid Modelsim SE/QuestaSim license.

#### • For Intel Quartus Prime Pro Edition:

\$ export QUARTUS\_HOME=<path to Intel Quartus Prime Pro Edition
installation directory>

The Intel Quartus Prime installation directory structure is as follows: adm common drivers dsp\_builder extlibs32 linux64 qdesigns sopc\_builder bin cusp dspba eda libraries lmf readme.txt version.txt

Add the environment variable to check the Modelsim license:

\$ export MGLS\_LICENSE\_FILE=<Modelsim License>

2. Export:

\$ export LM\_LICENSE\_FILE=<Quartus Prime License>

3. Extract the runtime archive file, and install OPAE libraries, binaries, include files, and ASE libraries as described in the section: *Installing the OPAE Software Package* in the appropriate Intel Acceleration Stack Quick Start User Guide for your Intel FPGA PAC.

Your environment must be set up correctly to configure and build an AFU. In particular, you must install the OPAE Software Development Kit (SDK) properly. OPAE SDK scripts must be on PATH and include files and libraries that must be available to





the C compiler. In addition, you must ensure that the OPAE\_PLATFORM\_ROOT environment variable is set. Refer to Installing the OPAE Software Package for more information.

To ensure that the OPAE SDK and ASE are properly installed, in a shell, confirm that your PATH includes afu\_sim\_setup. The afu\_sim\_setup should be in the /usr/bin directory or in *<opae install path>* if you built the OPAE from source files.

#### **Related Information**

- Intel Accelerator Functional Unit (AFU) Simulation Environment (ASE) User Guide ٠
- Installing the OPAE Software Package ٠ For Intel PAC with Intel Arria 10 GX FPGA.
- Installing the OPAE Software Package For Intel FPGA PAC D5005.





### 4. Simulating hello\_afu in Client-Server Mode

The hello\_afu example is a simple AFU template that demonstrates the primary CCI-P interface. The RTL satisfies the minimum requirements of an AFU, responding to memory-mapped I/O reads to return the device feature header and the AFU's UUID.

#### Figure 1. hello\_afu Directory Tree



*Note:* This document uses <*AFU example*> to refer to an example design directory, such as hello\_afu in the figure above.

The software demonstrates the minimum requirements to attach to an FPGA using the OPAE. The RTL demonstrates the minimum requirements to satisfy the OPAE driver and the hello\_afu example software.

filelist.txt specifies the files for RTL simulation and synthesis.

To successfully configure and build the AFU samples, your environment must be set up correctly, as described in *Setting Up the Environment*.

#### **Related Information**

- Intel Accelerator Functional Unit (AFU) Simulation Environment (ASE) User Guide
- Setting Up the Environment on page 5

Intel Corporation. All rights reserved. Agilex, Altera, Arria, Cyclone, Enpirion, Intel, the Intel logo, MAX, Nios, Quartus and Stratix words and logos are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services. \*Other names and brands may be claimed as the property of others.







٠

Developing AFUs with the OPAE SDK In the Accelerator Functional Unit (AFU) Developer's Guide



4. Simulating hello\_afu in Client-Server Mode UG-20165 | 2020.03.06



### 4.1. Simulation in Client-Server Mode

The following example flow introduces the basic ASE scripts. You can simulate all examples with the ASE, except eth\_e2e\_e10 and eth\_e2e\_e40.

Simulation requires two software processes: one process for RTL simulation and a second process to run the connected software. To construct an RTL simulation environment, run the following in \$OPAE\_PLATFORM\_ROOT/hw/samples/
hello\_afu:

\$ afu\_sim\_setup --source hw/rtl/filelist.txt build\_sim

This command constructs an ASE environment in the build\_sim subdirectory.

To build and run the simulator:

\$ cd build\_sim
\$ make
\$ make sim

The simulator prints a message that it is ready for simulation. It also prints a message prompting you to set the ASE\_WORKDIR environment variable.

Open another shell for software simulation. You must ensure to set the OPAE\_PLATFORM\_ROOT environment variable.

To build and run the software in the new shell:

```
$ cd $OPAE_PLATFORM_ROOT
$ export ASE_WORKDIR=$OPAE_PLATFORM_ROOT/hw/samples/hello_afu/build_sim/work
$ cd $OPAE_PLATFORM_ROOT/hw/samples/hello_afu/sw
$ make clean
$ make USE_ASE=1
$ ./hello_afu
```

*Note:* The specific pathname for ASE\_WORKDIR may vary. Use the pathname provided by the simulator prompt.

The software and simulator run, log transactions, and exit.

#### 4.1.1. Simulation Log Files

The simulation work directory stores the waveform, CCI-P transactions, and simulation log files.

Complete the following steps to view the waveform database:

- 1. Change to the directory in which you executed the make sim command.
- 2. Type:

\$ make wave

The make wave command, invokes the waveform viewer.





### 4.1.2. Design Declarations

The following file and directories define the AFU simulation:

- \$OPAE\_PLATFORM\_ROOT/hw/samples/<AFU example>/hw/rtl/ filelist.txt specifies RTL sources.
- <AFU example> is the example directory as shown in the *hello\_afu Directory* Tree figure.
- filelist.txt lists SystemVerilog, VHDL, and the AFU JavaScript Object Notation (.json) file.
- The AFU . json describes the interfaces the AFU requires. It also includes a UUID to identify the AFU once downloaded to an FPGA.
- hw/rtl/hello\_afu.json defines ccip\_std\_afu as the top-level interface by setting afu-top-interface to ccip\_std\_afu. ccip\_std\_afu is the base CCI-P interface including clocks, reset, and CCI-P TX and RX structures. More advanced examples define other interface options.
- The . json file declares the AFU UUID. An OPAE script generates the UUID. The RTL loads the UUID from afu\_json\_info.vh.
- sw/Makefile generates afu json info.h. Software loads the UUID from afu\_json\_info.h.

### 4.1.3. Troubleshooting Client-Server Simulation

If the afu sim setup command fails, confirm that:

- afu\_sim\_setup is on your PATH. afu\_sim\_setup should be in /usr/bin or in <opae install path> if you built OPAE from source files.
- You have Python version 2.7 or higher installed.

If you are unable to build and execute the simulator, it is likely that you did not install your RTL simulation tool properly.

When you try to build and run the software, if you see an "Error enumerating AFCs" message, you omitted setting USE\_ASE=1 on the make command line. The software is searching for a physical FPGA device. To recover, repeat the steps from the make clean command.



Send Feedback



### **5. AFU Examples**

#### Table 2.AFU Examples

Each AFU example includes a detailed README file, providing an operational description and notes on how to simulate the design. For a full understanding of the simulation process, review the README file in each AFU example.

| AFU                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| hello_mem_afu          | hello_mem_afu demonstrates an AFU that builds a simple state machine to access memory. The state machine is capable of several access patterns to local memory directly attached to FPGA pins, such as DDR4 DIMMs. This memory is distinct from the host memory accessed over CCI-P. The host manages the hello_mem_afu controller state machine using memory-mapped I/O (MMIO) requests to control and status registers (CSRs). |  |  |
| hello_intr_afu         | hello_intr_afu demonstrates the application interrupt feature in the ASE.                                                                                                                                                                                                                                                                                                                                                        |  |  |
| dma_afu <sup>(2)</sup> | dma_afu demonstrates a DMA Basic Building Block for host to FPGA, FPGA to host, and FPGA to FPGA memory transfers. When simulating this AFU, the buffer size used for DMA transfer is small to keep the simulation time reasonable. For more information, refer to the DMA Accelerator Functional Unit (AFU) User Guide.                                                                                                         |  |  |
| nlb_mode_0             | <pre>nlb_mode_0 is a CCI-P system demonstrating the memory copy test.<br/>\$OPAE_PLATFORM_ROOT/sw/opae-<release_number>/sample/hello_fpga.c includes<br/>nlb_mode_0.</release_number></pre>                                                                                                                                                                                                                                      |  |  |
|                        | <pre>\$ sh regress.sh -a <afu dir=""> -r rtl_sim     -s &lt; vcs modelsim questa &gt; [-i <opae install="" path="">]     -b <path dir="" opae="" source="" to=""></path></opae></afu></pre>                                                                                                                                                                                                                                      |  |  |
| streaming_dma          | streaming_dma demonstrates how to transfer data between host memory and an FPGA streaming_dma port. For more information, refer to the <i>Streaming DMA Accelerator Functional Un</i> ( <i>AFU</i> ) User Guide.                                                                                                                                                                                                                 |  |  |
| hello_afu              | hello_afu is a simple AFU that demonstrates the primary CCI-P interface. The RTL satisfie the bare minimum requirements of an AFU, responding to MMIO reads to return the device feature header and the AFU's UUID.                                                                                                                                                                                                              |  |  |

#### **Related Information**

- DMA Accelerator Functional Unit (AFU) User Guide For information on how to compile and execute the dma\_afu on your Intel PAC with Intel Arria 10 GX FPGA.
- Streaming DMA Accelerator Functional Unit (AFU) User Guide For information on how to compile and execute the streaming\_dma\_afu on your Intel PAC with Intel Arria 10 GX FPGA.
- DMA Accelerator Functional Unit User Guide: Intel FPGA Programmable Acceleration Card D5005

For information on how to compile and execute the  $dma_afu$  on your Intel FPGA PAC D5005.

#### <sup>(2)</sup> Available only in Client-Server mode

Intel Corporation. All rights reserved. Agilex, Altera, Arria, Cyclone, Enpirion, Intel, the Intel logo, MAX, Nios, Quartus and Stratix words and logos are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services. \*Other names and brands may be claimed as the property of others.





٠

Streaming DMA Accelerator Functional Unit User Guide: Intel FPGA Programmable Acceleration Card D5005 For information on how to compile and execute the  ${\tt dma\_afu}$  on your Intel

FPGA PAC D5005.





# 6. Troubleshooting

If the following error appears during simulation, correct it by following the steps below.

#### **Error Message**

# [SIM] An ASE instance is probably still running in current directory !
# [SIM] Check for PID 28816
# [SIM] Simulation will exit... you may use a SIGKILL to kill the simulation
process.
# [SIM] Also check if .ase\_ready.pid file is removed before proceeding.

#### Solution

- 1. Type pkill ase\_simv to kill zombie simulation processes and remove any temporary files left behind by failed simulation processes or lock ups.
- 2. Delete the .ase\_ready.pid file, found in the \$ASE\_WORKDIR directory.





# 7. ASE Quick Start User Guide Archives

| Intel Acceleration<br>Stack Version | User Guide                                                                                  |
|-------------------------------------|---------------------------------------------------------------------------------------------|
| 2.0                                 | Intel Accelerator Functional Unit (AFU) Simulation Environment (ASE) Quick Start User Guide |
| 1.2                                 | Intel Accelerator Functional Unit (AFU) Simulation Environment (ASE) Quick Start User Guide |
| 1.1                                 | Intel Accelerator Functional Unit (AFU) Simulation Environment (ASE) Quick Start User Guide |
| 1.0                                 | Intel Accelerator Functional Unit (AFU) Simulation Environment (ASE) Quick Start User Guide |

Intel Corporation. All rights reserved. Agilex, Altera, Arria, Cyclone, Enpirion, Intel, the Intel logo, MAX, Nios, Quartus and Stratix words and logos are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services. \*Other names and brands may be claimed as the property of others.

ISO 9001:2015 Registered



### 8. Document Revision History for ASE Quick Start User Guide

| Document<br>Version | Intel Acceleration Stack<br>Version | Changes                                                                                                                                                                                                                                                                            |
|---------------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2020.03.06          | 1.2.1 and 2.0.1                     | Updated the following:<br>• System Requirements                                                                                                                                                                                                                                    |
| 2019.08.05          | 2.0                                 | <ul> <li>Updated the Intel Quartus Prime Pro Edition version in System Requirements.</li> <li>Added the hello_afu in AFU Examples.</li> <li>Removed information about simulating in regression mode.</li> <li>Added a new section: ASE Quick Start User Guide Archives.</li> </ul> |
| 2018.12.04          | 1.2                                 | Added Ubuntu support.                                                                                                                                                                                                                                                              |
| 2018.08.06          | 1.1                                 | Updated the system requirements, directory structure and corresponding filenames.                                                                                                                                                                                                  |
| 2018.04.10          | 1.0                                 | Initial release.                                                                                                                                                                                                                                                                   |

