This artifact contains a vagrant repository that downloads and compiles the source code for Jaaru, its companion compiler pass, and benchmarks. The artifact enables users to reproduce the bugs that are found by Jaaru in PMDK and RECIPE as well as performance results to compare Jaaru with Yat, a naive persistent memory model checker.
Our workflow has four primary parts: (1) creating a virtual machine and installing dependencies needed to reproduce our results, (2) downloading the source code of \tool and the benchmarks and building them, (3) providing the parameters corresponding to each bug to reproduce the bugs, and (4) running the benchmarks to compare Jaaru with the naive exhaustive approach (i.e., Yat). After the experiment, the corresponding output files are generated for each bug and each performance measurement.
-
In order for Vagrant to run, we should first make sure that the VT-d option for virtualization is enabled in BIOS.
-
Then, you need to download and install Vagrant, if we do not have Vagrant ready on our machine. Also, it is required to install vagrant-disksize plugin for vagrant to specify the size of the disk needed for the evaluation.
$ sudo apt-get install virtualbox
$ sudo apt-get install vagrant
$ vagrant plugin install vagrant-disksize
- Clone this repository into the local machine and go to the jaaru-vagrant folder:
$ git clone https://github.com/uci-plrg/jaaru-vagrant.git
$ cd jaaru-vagrant
- Use the following command to set up the virtual machine. Then, our scripts automatically downloads the source code for Jaaru, its LLVM pass, and PMDK and RECIPE. Then, it builds them and sets them up to be used. Finally, it copies the running script in the home directory of the virtual machine.
jaaru-vagrant $ vagrant up
- After everything is set up, the virtual machine is up and the user can ssh to it by using the following command:
jaaru-vagrant $ vagrant ssh
- After logging in into the VM, there are three script files in the 'home' directory. These scripts automatically run the corresponding benchmark and save the results in the ~/results direcotory:
vagrant@ubuntu-bionic:~$ ls
llvm-project nvm-benchmarks pmcheck pmcheck-vmem pmdk pmdk-bugs.sh recipe-bugs.sh recipe-perf.sh
- To generate performance results for recipe benchmark, run recipe-perf.sh script. When it finishes successfully, it generates the corresponding performance results in ~/results/recipe-performance directory.
vagrant@ubuntu-bionic:~$ ./recipe-perf.sh
- Run recipe-bugs.sh script to regenerate bugs in RECIPE that found by Jaaru. Then, it generates the corresponding log file for each bug in ~/results/recipe-bugs directory.
vagrant@ubuntu-bionic:~$ ./recipe-bugs.sh
- Run pmdk-bugs.sh script to regenerate bugs in PMDK that found by Jaaru. Then, it generates the corresponding log file for each bug in ~/results/pmdk-bugs directory.
vagrant@ubuntu-bionic:~$ ./pmdk-bugs.sh
We make no warranties that Jaaru is free of errors. Please read the paper and the README file so that you understand what the tool is supposed to do.
Please feel free to contact us for more information. Bug reports are welcome, and we are happy to hear from our users. Contact Hamed Gorjiara at [email protected], Harry Xu at [email protected], or Brian Demsky at [email protected] for any questions about Jaaru.