README.md 2.09 KB
Newer Older
Antoine Kaufmann's avatar
Antoine Kaufmann committed
1
2
# Endhost

Antoine Kaufmann's avatar
Antoine Kaufmann committed
3
4
5
Code structure:
 - `proto/`: protocol definitions for PCIe and Ethernet channels
 - `nicsim_common/`: helper library for NIC simulations
Antoine Kaufmann's avatar
Antoine Kaufmann committed
6
 - `dummy_nic/`: dummy device illustrating PIO with cosim-pci interface
Antoine Kaufmann's avatar
Antoine Kaufmann committed
7
8
9
10
11
 - `corundum/`: verilator-based cycle accurate Corundum model
 - `corundum_bm/`: C++ behavioral model for Corundum
 - `netsim_common/`: helper library for network simulations
 - `net_tap/`: Linux tap interface connector for Ethernet channel
 - `net_wire/`: Ethernet wire, connects to Ethernet channels together:w
Antoine Kaufmann's avatar
Antoine Kaufmann committed
12

Antoine Kaufmann's avatar
Antoine Kaufmann committed
13
14
15
16
# Building
 - External dependencies for qemu: `libglib2.0-dev libpixman-1-dev`
 - External dependencies for gem5: `scons`

Antoine Kaufmann's avatar
Antoine Kaufmann committed
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
## Running Qemu
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
```
5. 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
1. Clone from here: `git@github.com:nicklijl/gem5.git`
2. Build with: `scons build/X86/gem5.opt -jX` (with `X` set to # cores)
Antoine Kaufmann's avatar
Antoine Kaufmann committed
37
38
39
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:
Antoine Kaufmann's avatar
Antoine Kaufmann committed
40
41
42
43
44
45
46
47
48
```
./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
```
5. Attach to gem5 terminal: `./util/term/m5term localhost 3456`