Skip to content

Latest commit

 

History

History
178 lines (114 loc) · 7.94 KB

aws.md

File metadata and controls

178 lines (114 loc) · 7.94 KB

Running Spatial on AWS F1 Instances

This tutorial explains how to compile any Spatial application and run it on the Amazon F1. It is not specific to applications created through the Spatial Multiverse.

Contents

Prerequisites

Running on EC2 FPGAs requires the following prerequisites:

Setting up aws-fpga

Clone Amazon's EC2 FPGA Hardware and Software Development Kit to any location:

$ git clone https://github.com/aws/aws-fpga.git

Spatial was most recently tested with version 1.4.7 of this repository (git commit a9c3a00d78cf539cdc597d2d42ea5dd268a9bc1a).

Set the AWS_HOME environment variable to point to the cloned directory. Also source the AWS setup scripts. The HDK script is needed for simulation and synthesis, and the SDK is needed to create the host binary:

$ export AWS_HOME=/path/to/aws-fpga
$ cd /path/to/aws-fpga/
$ source /path/to/aws-fpga/hdk_setup.sh
$ source /path/to/aws-fpga/sdk_setup.sh

For example, you can add the 4 commands above to your .bashrc and source that.

You will then need to make the following edits to aws-fpga source files in order to compile the Spatial C++ host:

To file sdk/userspace/fpga_mgmt_tools/src/fpga_local_cmd.c:

-                       printf(long_help);
+                       printf("%s", long_help);

To file sdk/userspace/include/fpga_dma.h:

-    char device_file[static FPGA_DEVICE_FILE_NAME_MAX_LEN]);
+    char device_file[FPGA_DEVICE_FILE_NAME_MAX_LEN]);

Running on F1

Running on the F1 requires a few simple manual steps. These depend on your personal AWS account (EC2 and S3). Specifically, following synthesis Amazon requires the bitstream to be uploaded to your S3 account, and an EC2 account is needed to launch an F1 instance to run the spatial application in hardware.

This tutorial describes the following steps:

  • Authenticating your AWS account
  • Generating and synthesizing a Spatial design. In our experience, synthesis/place/route takes 4-12 hours depending on design size
  • Uploading the bitstream (AKA design checkpoint, or DCP) to Amazon S3 and waiting approximately 1 hour for the Amazon FPGA Image (AFI) associated with this bitstream to become valid
  • Opening an F1 instance through your EC2 account
  • Running the spatial application

Step 1: Authenticating your AWS account

Follow these steps to create a file rootkey.csv. This file can be placed anywhere, and will be needed for later steps to run commands associated with your AWS account.

Then add the path to that file to your .bashrc as follows:

export AWS_CONFIG_FILE=/path/to/rootkey.csv

Step 2: Compile and Synthesize your application

Compile your application using the following command:

  $ bin/spatial example --synth --fpga=AWS_F1 && cd gen/example && make aws-F1

If compiling from a front-end framework like TensorFlow, the script dnn_to_spatial.py will print the above command for you to run.

This step requires Vivado. We tested using Amazon's FPGA Developer AMI version 1.5.0, as mentioned above, however this can also be run locally using these instructions.

Notice that once this command completes, Vivado synthesis will be running in the background. A script called create_spatial_AFI_instructions.sh has also been created. Follow the instructions in this text file (also described below) once Vivado completes to upload the Design Checkpoint (DCP) and finish creating the AFI.

Step 3: Creating the AFI

Once Vivado has finished, run:

bash create_spatial_AFI_instructions.sh

This is an executable bash script that uploads the DCP to S3 and then runs the create-fpga-image command. Running this will require the AWS Command Line Interface. We tested with version 1.11.78.

Once create-fpga-image has been run by the script above, it will print the agfi ID. Modify the file load.sh in software/runtime to paste in the agfi ID returned above. Now wait approximately 1-2 hours for the logs directory in S3 to be filled, and ensure that the AFI state in the file called State is "available".

Step 4: Opening an F1 instance

Start an F1 instance in the AWS console. We tested with Amazon's FPGA Developer AMI, version 1.5.0, in order to ensure the right SDK tools are compiled (e.g. fpga-load-local-image).

If you already have an existing F1 instance (e.g. for a previous Spatial application), skip to Step 5. If this is your first time starting the F1 instance, follow the one-time setup steps below.

Clone Amazon's EC2 FPGA Hardware and Software Development Kit to any location, e.g. /home/centos/src/project_data:

git clone https://github.com/aws/aws-fpga.git

Put the following (replacing with your chosen path above) in your .bashrc:

cd /home/centos/src/project_data/aws-fpga/
source /home/centos/src/project_data/aws-fpga/sdk_setup.sh

Source the .bashrc:

source ~/.bashrc

Then follow these instructions to build and install the required XDMA driver. Verify it is running using:

lsmod | grep xdma

Step 5: Running the Spatial application

The command make aws-F1 above should have created the Top software binary.

You can do this on your local machine and copy over the binary to the F1 (this might require changing permissions to run it), or compile the binary on the F1 instance. To do it on the F1 instance, you only need the software/runtime and software/include directories of the generated Spatial AWS application, and can compile using make all in software/runtime.

Load the afi to the FPGA using the command below. load.sh can be found in the runtime directory.

bash load.sh

Now you an run the application as many times as needed using the command below. Top can also be found in the runtime directory.

sudo ./Top arg1 arg2 ...

Important Tips

  • If running an application on the F1 manually, do not include capital letters or underscores in your Spatial application name. This name is used to make the S3 bucket, and S3 does not allow these characters. The Spatial Multiverse automatically removes underscores and makes all letters lowercase from the application name, but if running a Spatial application on the F1 manually be aware of this.

Frequently Asked Questions

Q. How do these steps differ from the F1 tutorial on the Spatial webpage?

A. Those steps are out of date, these steps are current.