Skip to content

Latest commit

 

History

History
119 lines (94 loc) · 5.93 KB

README.md

File metadata and controls

119 lines (94 loc) · 5.93 KB

APAI-LAB01: PULP Virtual Platform Setup and C programming

The target device for the lab sessions is the multi-core PULP platform. The PULP Virtual Platform simulator GVSOC, which is included within the PULP SDK, will be used during the class. To install the GVSOC Simulator and setup your environment, you can follow one of the two options described below.

GVSOC Simulator Install Guide

Option 1 (suggested): Download the PULP Virtual Machine

The Virtual Machine including a pre-installed PULP SDK and Virtual Platform simulator can be found here Link (5GB). The machine can be used in VirtualBox, VMware (instructions below) or other hosts (not tested - you are on your own...). Note: if you want to run this on a Mac with an ARM-based processor (M1, M1-Pro, M2, ...), go to Option 4 (MacOS Virtual Machine) or 3 (Docker).

If you want to use VirtualBox:

  1. Download pulp_box_2021_dory.ova from this OneDrive link (8.1 GB)
    • The link works with unibo accounts.
  2. Install and open VirtualBox
  3. Go to File > Import Appliance...
  4. Select pulp_box_2021_dory.ova as the Appliance to import
  5. If needed, change the destination folder, then click on Import
  6. In the main VirtualBox window, click on the new virtual machine, then on Start

If you want to use VMware Workstation Player 16:

  1. Download pulp_box_2021_dory.ova from this OneDrive link (5.5 GB)
  2. Install and open VMware Workstation Player 16. Notice that "Player" is the free version of WMware, while "Pro" must be paid.
  3. Go to Player> File > open ...
  4. Select pulp_box_2021_dory.ova as the Appliance to import
  5. If needed, change the destination folder, then click on Import
  6. If WMware gets you a warning, force the import of the VM image provided
  7. In the main WMware window, click on the new virtual machine, then on "Play virtual machine"

The username in the virtual machine is pulp-user, while the password is pulp. Check the README file on the Desktop. To make the SDK and GVSOC available in a newly opened shell, use the following command:

source /pulp/sourceme.sh

Option 2 (alternative): Install the PULP-SDK on your Linux machine

If you prefer to use your own Linux machine, you can follow the instructions here, which have been tested on a fresh Ubuntu 18.04 Bionic Beaver 64-Bit machine. Beware that if you prefer to use your own machine, you may encounter issues for which we cannot easily support you -- especially if your distro is different from Ubuntu 18.04 64-bit. The main steps concern:

  1. Install the compiler. A precompiled version can be taken from here.

  2. Export the RISC-V compiler path.

export PULP_RISCV_GCC_TOOLCHAIN=<INSTALL_DIR>
  1. Clone and build the PULP SDK
git clone https://github.com/pulp-platform/pulp-sdk.git
cd pulp-sdk
source configs/pulp-open.sh
make build

Option 3 (alternative): Install the PULP-SDK in a Docker container

To install the PULP-SDK inside a Docker container running Ubuntu 18.04, follow these steps:

  1. Install docker and docker-compose on your host machine. If you use on a Debian-based Linux distro, you can do it as follows:
sudo apt install docker docker-compose
  1. Add your user to the docker group to avoid having to use sudo.
sudo usermod -aG docker $USER

Then restart your system.

  1. Run the container (NB the first run may take several minutes, as it needs to build the Docker image).
docker-compose run --rm pulp

A new shell will open inside the container, in the /home/pulp/workspace folder (you're the pulp user); such folder is a volume, meaning that you will see it on your host too (you can share files between the host and the container using such folder).

  1. After terminating the container (with Ctrl+D), close the resources.
docker-compose down

Option 4 (alternative for Mac M1/M1-Pro/M2): Download a PULP Virtual Machine for ARM64

  1. Download PULPBox-UTM.utm from this OneDrive link (4 GB)
    • The link works with unibo accounts.
  2. Install and open UTM
  3. Open the downloaded PULPBox.

Test your GVSOC Installation

After completing the GVSOC setup, you can download some example code in your preferred working directory and run the Helloworld on the PULP platform.

cd <your_work_directory>
git clone https://github.com/GreenWaves-Technologies/pmsis_tests.git
cd pmsis_tests/quick/hello/
make clean all run

If you see an Hello from PULP, your setup is fine! ;)

Additional Information

Source the PULP SDK every time you open a new shell

To run example code on the PULP Virtual Plaform, you must export the RISC-V Compiler path and source the platorm configurafion file every time a shell is opened.

If you are using the PULP Virtual Machine (Option 1), we prepared a bash script that does this for you. For each new shell, all you need to do is running:

source /pulp/sourceme.sh

If you installed the VM on your own, you will not find the sourceme.sh file. You must run the following commands manually each time you open a new shell:

export PULP_RISCV_GCC_TOOLCHAIN=<INSTALL_DIR>
source configs/pulp-open.sh

You can consider to prepare a bash script (equivalent to the sourceme.sh) that you will use to automatically run these commands.