Skip to content

Latest commit

 

History

History
194 lines (146 loc) · 9.32 KB

README.md

File metadata and controls

194 lines (146 loc) · 9.32 KB

Risotto: A Dynamic Binary Translator for Weak Memory Architectures --- Artifact

This repository contains all the code and instructions to reproduce the results from the following paper:

Risotto: A Dynamic Binary Translator for Weak Memory Architectures
Redha Gouicem (TU Munich), Dennis Sprokholt (TU Delft), Jasper Ruehl (TU Munich), Rodrigo C. O. Rocha (University of Edinburgh), Tom Spink (University of St Andrews), Soham Chakraborty (TU Delft), Pramod Bhatotia (TU Munich)
International Conference on Architectural Support for Programming Languages and Operating Systems (ASPLOS), 2023

Content

This repository contains multiple submodules:

  • qemu: contains our modified QEMU (modified mappings for memory operations, support for native shared libraries, native CAS translation)
  • benchmarks: contains the benchmarks used in the paper
  • proofs: contains the formal proof regarding our memory mappings and optimisations

Requirements

Hardware

To run these experiments, you will need an arm64 machine with at least ARMv8.2. If you want to easily build the x86_64 versions of the benchmarks, you will also need an x86 machine. You can also cross-compile them on the ARM machine, but we do not provide instructions for this. You can adapt the building scripts to use a cross-compiler.

Software

We rely on NixOS to have a unified execution environment. You can either install NixOS as a full operating system, or just as a package manager (Nix) on top of your Linux installation. You can find out more information on the Nix download page. The easy installation consists of using Nix as a package manager, installing it this way:

sh <(curl -L https://nixos.org/nix/install) --daemon

Required packages to reproduce the plots are available in the Nix environment, but you can also reproduce them on you local OS if you prefer. You will need the following packages:

apt install python3-pip                    # install pip
pip install notebook pandas matplotlib seaborn

Quick result reproduction

This section details how to quickly reproduce the results of the paper in a fully automated way. If you have encounter any issue or only want to run a specific part of the evaluation, you can check the Detailed instructions below.

From the root directory of the repository, run these commands:

source sourceme
./scripts/build.sh
./scripts/run_benchmarks.sh
./scripts/plot.sh

This will produce the figures from the paper (12 to 15) in the plots/ directory, as pdf files.

Detailed instructions

Building the software

Before running the experiments, we need to build the software and the benchmarks. You can try to build everything at once or separately.

Building everything

You can build everything by executing:

source sourceme
./scripts/build.sh

If everything works fine, you can skip to Running the benchmarks.

Note that this script downloads the pre-built binaries for the benchmarks and does not build them. If you want to build them, check the following sections.

Building QEMU

You need to build our modified QEMU as well as the baselines for the evaluation to work. It is located in the qemu submodule and can be built by running:

source sourceme
nix-shell --run scripts/build_qemu.sh qemu.nix

Since QEMU will be executed on the ARM machine, it has to be built for ARM. To simplify this, we recommend to build this directly on the ARM machine you will use to reproduce the results of the paper.

After running this script, you should have four versions of QEMU built, located in build/qemu/:

  • master-6.1.0: this is the official QEMU 6.1.0, unmodified (used as a baseline)
  • no-fences: QEMU 6.1.0 but no fence is generated for any memory access. This version may create incorrect executions (used as a comparison)
  • tcg-tso: QEMU 6.1.0 + our memory mappings (used to evaluate the performance of our mappings)
  • risotto: QEMU 6.1.0 + our memory mappings + native CAS + native shared libraries

Building the benchmarks

The benchmarks need to be built twice: once for arm64 and once for x86_64. You can do this in different ways:

  • Download pre-built binaries (recommended)
  • Build the x86_64 binaries on an x86_64 machine, and the arm64 binaries on an arm64 machine
  • Build everything on the same machine with cross-compilation for the non-native version.
Downloading pre-built binaries

We provide an archive with all benchmarks packaged for both x86_64 and arm64 at this address. You can just download and extract the archives wherever you want with:

tar xf <archive.tar.xz>

These archives contain the binaries and input data for each benchmark.

Build binaries on x86_64 and arm64 machines

On each machine, you can run the same commands to build all the benchmarks:

source sourceme
nix-shell --run scripts/build_benchmarks.sh default.nix

Note that you will need to check the paths specified in the configuration files available in config/*.config and set them up properly.

Running the benchmarks

This section shows how to run the benchmarks and plot each figure available in the paper. Note that the provided scripts pin the benchmarks to a subset of cores, tailored for our test machine (cores 0 to 111). If you want to use your own machine, change the taskset command in the scripts/run_benchmarks.sh script to match your configuration. If you have a machine with multiple NUMA nodes, we suggest to pin the benchmarks to a single node. You can get the list of cores of each node with the lscpu command.

Figure 12: PARSEC and Phoenix

You can run these benchmarks by executing these two commands from the root of this repository (after running source sourceme):

nix-shell --run ${RISOTTO_ROOT}/scripts/run_parsec.sh ${RISOTTO_ROOT}/default.nix
nix-shell --run ${RISOTTO_ROOT}/scripts/run_phoenix.sh ${RISOTTO_ROOT}/default.nix

The results will be available in results/parsec-phoenix.csv. Note that if you run the scripts multiple times, the results are appended to the csv file. If you want to start again from scratch, delete or rename the csv before running the benchmarks.

To plot the figure, start the jupyter notebook server from the root of the repository (if it's not already started):

jupyter notebook

In the browser window, open the plots/fig12.ipynb and run all the cells in order. The plot should be available in the 9th cell.

Figure 13: openssl and sqlite

You can run these benchmarks by executing these two commands from the root of this repository (after running source sourceme):

nix-shell --run ${RISOTTO_ROOT}/scripts/run_openssl.sh ${RISOTTO_ROOT}/default.nix
nix-shell --run ${RISOTTO_ROOT}/scripts/run_sqlite.sh ${RISOTTO_ROOT}/default.nix

The results will be available in results/openssl.csv and results/sqlite.csv. Note that if you run the scripts multiple times, the results are appended to the csv files. If you want to start again from scratch, delete or rename the csv before running the benchmarks.

To plot the figure, start the jupyter notebook server from the root of the repository (if it's not already started):

jupyter notebook

In the browser window, open the plots/fig13.ipynb and run all the cells in order. The plot should be available in the 11th cell.

Figure 14: math

You can run these benchmarks by executing this command from the root of this repository (after running source sourceme):

nix-shell --run ${RISOTTO_ROOT}/scripts/run_math.sh ${RISOTTO_ROOT}/default.nix

The results will be available in results/math.csv. Note that if you run the scripts multiple times, the results are appended to the csv file. If you want to start again from scratch, delete or rename the csv before running the benchmarks.

To plot the figure, start the jupyter notebook server from the root of the repository (if it's not already started):

jupyter notebook

In the browser window, open the plots/fig14.ipynb and run all the cells in order. The plot should be available in the 9th cell.

Figure 15: cas

You can run these benchmarks by executing this command from the root of this repository (after running source sourceme):

nix-shell --run ${RISOTTO_ROOT}/scripts/run_cas.sh ${RISOTTO_ROOT}/default.nix

The results will be available in results/cas.csv. Note that if you run the scripts multiple times, the results are appended to the csv file. If you want to start again from scratch, delete or rename the csv before running the benchmarks.

To plot the figure, start the jupyter notebook server from the root of the repository (if it's not already started):

jupyter notebook

In the browser window, open the plots/fig15.ipynb and run all the cells in order. The plot should be available in the 4th cell.

Proofs

The proofs have their own README.md (inside proofs/), with explanations. For evaluation, it's easiest to use the pre-build Docker image. Check the proofs with:

docker run -it --rm sourcedennis/risotto-proofs:latest agda src/Main.agda --safe

Generate HTML-rendered Agda with (into local directory html/):

docker run -it --rm -v "$PWD/html:/proofs/html" sourcedennis/risotto-proofs:latest agda --html --html-dir=html src/Main.agda

Or, build the Docker images yourself with the contained proofs/Dockerfile.