Skip to content

Main Repository for the SimBricks Modular Full-System Simulation Framework.

License

Notifications You must be signed in to change notification settings

FreakyPenguin/simbricks

 
 

Repository files navigation

Endhost

Code structure:

  • proto/: protocol definitions for PCIe and Ethernet channels
  • NIC Simulators:
    • dummy_nic/: dummy device illustrating PIO with cosim-pci interface
    • corundum/: verilator-based cycle accurate Corundum model
    • corundum_bm/: C++ behavioral model for Corundum
    • i40e_bm/: Intel XL710 behavioral model
  • Network Simulators:
    • net_tap/: Linux tap interface connector for Ethernet channel
    • net_wire/: Ethernet wire, connects to Ethernet channels together:w
  • Helper Libraries:
    • nicsim_common/: helper library for NIC simulations
    • netsim_common/: helper library for network simulations
    • libnicbm/: helper library for behavioral nic models

Dependencies

  • Tested to work on Ubuntu 18.04
  • Verilator (branch v4.010)
  • unzip
  • libpcap-dev
  • libglib2.0-dev
  • python (>= 3.7)
  • libgoogle-perftools-dev
  • libboost-iostreams-dev
  • libboost-coroutine-dev
  • scons
  • ninja-build
  • libpixman-1-dev
  • qemu

Building

First, initialize all submodules:

git submodule init
git submodule update

Then, build the project, all submodules, and experiment images:

make -j`nproc` all external build-images

Note: building system images requires KVM support (and KVM permissions).

Running

A list of available simulations is listed in experiments/pyexps.

To run one of the simulations:

cd experiments
python3 run.py pyexps/EXP

where EXP is the name of the simulation file.

Running Qemu

These instructions apply only if you want to build and run qemu separately and are not necessary if built with make external and run with our experiments scripts.

  1. Clone from here: github.com:FreakyPenguin/qemu-cosim.git
  2. Build with ./configure --target-list=x86_64-softmmu --disable-werror --extra-cflags="-I$PATH_TO_THIS_REPO/proto" --enable-cosim-pci
  3. run dummy nic: rm -rf /tmp/cosim-pci; ./dummy_nic
  4. To run for example (only the last two lines are specific to this project):
x86_64-softmmu/qemu-system-x86_64 \
    -machine q35 -cpu host \
    -drive file=/local/endhostsim/vm-image.qcow2,if=virtio \
    -serial mon:stdio -m 2048 -smp 2 -display none -enable-kvm \
    -chardev socket,path=/tmp/cosim-pci,id=cosimcd \
    -device cosim-pci,chardev=cosimcd
  1. in vm test with:
    • for read: dd if=/sys/bus/pci/devices/0000\:00\:03.0/resource2 bs=1 skip=64 count=1
    • for write: echo a | dd of=/sys/bus/pci/devices/0000\:00\:03.0/resource2 bs=1 seek=64 count=1

Running Gem5

These instructions apply only if you want to build and run gem5 separately and are not necessary if built with make external and run with our experiments scripts.

  1. Clone from here: git@github.com:nicklijl/gem5.git
  2. Build with: scons build/X86/gem5.opt -jX (with X set to # cores)
  3. echo -1 | sudo tee /proc/sys/kernel/perf_event_paranoid
  4. run dummy nic: rm -rf /tmp/cosim-pci; ./dummy_nic
  5. To run for example:
./build/X86/gem5.opt \
    configs/cosim/cosim.py \
    --termport=3456 --kernel=$EHSIM/images/vmlinux \
    --disk-image=$EHSIM/images/output-ubuntu1804/ubuntu1804.raw \
    --cpu-type=X86KvmCPU --mem-size=4GB \
    --cosim-pci=/tmp/cosim-pci --cosim-shm=/dev/shm/dummy_nic_shm
  1. Attach to gem5 terminal: ./util/term/m5term localhost 3456

About

Main Repository for the SimBricks Modular Full-System Simulation Framework.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Verilog 57.3%
  • C++ 23.9%
  • C 12.1%
  • Python 4.9%
  • Makefile 0.7%
  • Shell 0.6%
  • Other 0.5%