Skip to content

Latest commit

 

History

History
268 lines (197 loc) · 8.83 KB

README.md

File metadata and controls

268 lines (197 loc) · 8.83 KB

FireMarshal Keystone on FireSim

FireSim Version: v1.16.0

This repository contains changes from the original firemarhsal-keystone repository. This uses the dev banch of the Keystone repository.

This build was tested using Berkeley eXtensible Environment (BXE). This can be run both on the virtual machines as well as the BXE Docker image.

Running BXE Docker Keystone Image

  1. Pull the Keystone BXE Docker image
docker pull socks.lbl.gov:4567/cag/bxe:keystone
  1. Run the Docker image
docker run --privileged -it socks.lbl.gov:4567/cag/bxe:keystone
  1. Source FireSim
source source-env.sh
  1. Launch Keystone with FireMarshal
cd ~/firesim/sw/firesim-software
./marshal -v launch bxe-workloads/firemarshal-keystone/keystone.json

Prerequisites for Building Keystone

  • Install the prerequisites for Keystone to build
sudo apt install cmake makeself ninja-build pkg-config pkg-config-riscv64-linux-gnu libglib2.0-dev

Building Keystone for FireMarshal on BXE VMs

NOTE: Make sure you've installed prerequisites in your BXE VM.

  1. Source FireSim
cd firesim
source sourceme-f1-manager.sh --skip-ssh-setup
  1. Clone this repository into the FireMarshal directory.
cd ~/firesim/sw/firesim-software
mkdir bxe-workloads
cd bxe-workloads
git clone https://github.com/lbnl-cybersecurity/firemarshal-keystone.git
cd ..
  1. Source the source-keystone.sh script. This will modify PATH to make sure the system cmake has priority over Xilinx's older version of cmake.
source bxe-workloads/firemarshal-keystone/source-bxevm-keystone.sh
  1. Run a FireMarshal build. This will FAIL the first time, as KEYSTONE_SDK_DIR isn't set your enivironment. However, this will pull the keystone project from GitHub and do some preliminary set up.
./marshal -v build bxe-workloads/firemarshal-keystone/keystone.json
  1. Source the newly generated Keystone sourcing script to add KEYSTONE_SDK_DIR to you environment.
source bxe-workloads/firemarshal-keystone/keystone/source.sh
  1. Rerun the FireMarshal build. This will FAIL again as the tests.ke file is missing for Keystone.
./marshal -v build bxe-workloads/firemarshal-keystone/keystone.json
  1. Navigate to the Keystone build directory and run make examples to build the required tests.ke file. This make will ultimately fail, as we haven't set up attestation, but the tests.ke file is generated.
cd bxe-workloads/firemarshal-keystone/keystone/build
make examples
cd ../../../..
  1. Rerun the FireMarshal build. This should run without any errors and generate the disk image.
./marshal -v build bxe-workloads/firemarshal-keystone/keystone.json
  1. Run the FireMarshal simulation to verify the build.
./marshal -v launch bxe-workloads/firemarshal-keystone/keystone.json
  1. Once confirmed, install the workload to FireSim to prepare for an FPGA simulation. Follow the instructions on running a Hardware FPGA Simulation on BXE.
./marshal -v install bxe-workloads/firemarshal-keystone/keystone.json

Running Keystone on BXE FireSim

  1. If you've completed the above steps, you'll see the corresponding Keystone JSON and directory in firesim/deploy/workloads
...
keystone/
keystone.json
...
  1. Modify the workload section of firesim/deploy/config_runtime.yaml to run this newly installed Keystone workload
workload:
    workload_name: keystone.json
    terminate_on_completion: no
    suffix_tag: null
  1. Run the FireSim Simulation
firesim launchrunfarm
firesim infrasetup    # This step will take some time to run
firesim runworkload

After the firesim runworkload, you'll see the following output on your console:

This workload's output is located in:
/home/bxeuser/firesim/deploy/results-workload/2023-11-09--04-13-01-keystone/
This run's log is located in:
/home/bxeuser/firesim/deploy/logs/2023-11-09--04-13-01-runworkload-VECZEPC17GHQHCB9.log
This status will update every 10s.
--------------------------------------------------------------------------------
Instances
--------------------------------------------------------------------------------
Hostname/IP: localhost | Terminated: False
--------------------------------------------------------------------------------
Simulated Switches
--------------------------------------------------------------------------------
--------------------------------------------------------------------------------
Simulated Nodes/Jobs
--------------------------------------------------------------------------------
Hostname/IP: localhost | Job: keystone0 | Sim running: True
--------------------------------------------------------------------------------
Summary
--------------------------------------------------------------------------------
1/1 instances are still running.
1/1 simulations are still running.
--------------------------------------------------------------------------------
  1. In a different window, run:
screen -r fsim0

You will see the console slowly boot:

[   18.678898] keystone_enclave: keystone enclave v1.0.0
Mounting /dev/iceblk as root device
[   18.877760] EXT4-fs (iceblk): mounted filesystem cef912a2-15bf-4aa3-bd13-fbcbd1407107 without journal. Quota mode: disabled.
Loaded platform drivers, booting from disk:
[   19.300984] EXT4-fs (iceblk): re-mounted cef912a2-15bf-4aa3-bd13-fbcbd1407107. Quota mode: disabled.
running /etc/init.d/S01syslogd
Starting syslogd: OK
running /etc/init.d/S02klogd
Starting klogd: OK
running /etc/init.d/S02sysctl
Running sysctl: OK
running /etc/init.d/S10mdev
Starting mdev: OK
running /etc/init.d/S40network
Starting network: OK
running /etc/init.d/S99run
launching firemarshal workload run/command
firemarshal workload run/command done

Welcome to Buildroot
buildroot login:
  1. Unfortunately, the current limitation where the simulation doesn't respond to keyboard input. To end the simulation, return to the window where you ran firesim runworkload and press CTRL + C to terminate the simulation.

The workaround to this issue is to build a workload that runs the program and ends the simulation. To do so, the the BXE Documentation on defining a custom workload will guide you through that process.

Building Keystone for FireMarshal on BXE Docker

NOTE: Make sure you've installed prerequisites in the Docker container.

  1. Source FireSim
source source-env.sh
  1. Clone this repository into the FireMarshal directory.
cd ~/firesim/sw/firesim-software
mkdir bxe-workloads
cd bxe-workloads
git clone https://github.com/lbnl-cybersecurity/firemarshal-keystone.git
cd ..
  1. Run a FireMarshal build. This will fail the first time, as KEYSTONE_SDK_DIR isn't set your enivironment. However, this will pull the keystone project from GitHub and do some preliminary set up.
./marshal -v build bxe-workloads/firemarshal-keystone/keystone.json
  1. Source the newly generated Keystone sourcing script to add KEYSTONE_SDK_DIR to you environment.
source bxe-workloads/firemarshal-keystone/keystone/source.sh
  1. Rerun the FireMarshal build. This will FAIL again as the tests.ke file is missing for Keystone.
./marshal -v build bxe-workloads/firemarshal-keystone/keystone.json
  1. Navigate to the Keystone build directory and run make examples to build the required tests.ke file. This make will ultimately fail, as we haven't set up attestation, but the tests.ke file is generated.
cd bxe-workloads/firemarshal-keystone/keystone/build
make examples
cd ../../../..
  1. Rerun the FireMarshal build. This should run without any errors and generate the disk image.
./marshal -v build bxe-workloads/firemarshal-keystone/keystone.json
  1. Run the FireMarshal simulation to verify the build.
./marshal -v launch bxe-workloads/firemarshal-keystone/keystone.json