Repository with Jailhouse build configuration for Jetson TX2
Building
---------
+========
+
wget https://debian.pengutronix.de/debian/pool/main/o/oselas.toolchain/oselas.toolchain-2014.12.2-aarch64-v8a-linux-gnu-gcc-4.9.2-glibc-2.20-binutils-2.24-kernel-3.16-sanitized_2014.12.2_amd64.deb
sudo dpkg -i oselas.toolchain-2014.12.2-aarch64-v8a-linux-gnu-gcc-4.9.2-glibc-2.20-binutils-2.24-kernel-3.16-sanitized_2014.12.2_amd64.deb
The above croscompiles the following: Linux kernel, Jailhouse and
simple root filesystem.
-Building on TX2
----------------
+Building on TX2 (only Jailhouse and Linux)
+------------------------------------------
make jailhouse CROSS_COMPILE=
Booting
--------
+=======
+
+Network book
+------------
We use novaboot tool (https://github.com/wentasah/novaboot) to boot
-the resulting images over network. Use build/boot to boot Jailhouse or
-build/boot-linux to boot plain Linux without starting Jailhouse.
+the resulting images over network. Use the `build/boot` script to boot
+Jailhouse or `build/boot-linux` to boot plain Linux without starting
+Jailhouse.
+
+Flash/SD card boot
+------------------
+
+To boot Linux and Jailhouse without novaboot, create a Debian package
+by running:
+
+ cd build
+ make deb
+
+Copy the resulting .deb package to the board and install it with
+
+ dpkg -i jailhouse_*.deb
+
+Then, after rebooting choose "prem kernel and jailhouse" entry from
+the extlinux boot menu. Jailhouse will start automatically during the
+boot. You can use `systemctl` command to see its status, stop it etc.:
-To boot without novaboot, copy linux-4.4/arch/arm64/boot/Image and
-files from rootfs-overlay to your board. If needed, we will provide
-deailed instructions later.
+ systemctl {status|start|stop} jailhouse
mkimage -f auto -d kernel-4.4/arch/arm64/boot/Image -i buildroot/images/rootfs.cpio.uboot -b kernel-4.4/arch/arm64/boot/dts/tegra186-quill-p3310-1000-c03-00-base.dtb image.fit
buildroot/images/rootfs.cpio.uboot: ./buildroot/.config
-buildroot/images/rootfs.cpio.uboot: rootfs-overlay/lib/firmware/jailhouse.bin rootfs-overlay/lib/modules/4.4.38+/modules.dep
+buildroot/images/rootfs.cpio.uboot: rootfs-overlay/lib/firmware/jailhouse.bin
+buildroot/images/rootfs.cpio.uboot: modules_install
buildroot/images/rootfs.cpio.uboot: $(shell find rootfs-overlay)
buildroot/images/rootfs.cpio.uboot: rootfs-overlay/bin/prem-test
$(MAKE) -j1 -C buildroot ROOTFS_CPIO_COMPRESS_CMD="gzip --fast -c"
jailhouse: ../jailhouse/hypervisor/jailhouse.bin
-JAILHOUSE_DESTDIR=$(CURDIR)/rootfs-overlay
+DESTDIR=$(CURDIR)/rootfs-overlay
jailhouse-install: FORCE
- $(MAKE) -C ../jailhouse -j$(NPROC) install KDIR=$(CURDIR)/kernel-4.4 ARCH=arm64 DESTDIR=$(abspath $(JAILHOUSE_DESTDIR)) prefix=/usr
- mkdir -p $(JAILHOUSE_DESTDIR)/jailhouse/configs/ $(JAILHOUSE_DESTDIR)/jailhouse/demos/
+ $(MAKE) -C ../jailhouse -j$(NPROC) install KDIR=$(CURDIR)/kernel-4.4 ARCH=arm64 DESTDIR=$(abspath $(DESTDIR)) prefix=/usr
+ mkdir -p $(DESTDIR)/jailhouse/configs/ $(DESTDIR)/jailhouse/demos/
# cp ../jailhouse/inmates/demos/arm64/my-demo.bin rootfs-overlay/jailhouse/demos/
- cp ../jailhouse/configs/arm64/jetson-tx2.cell $(JAILHOUSE_DESTDIR)/jailhouse/configs/
- cp ../jailhouse/configs/arm64/jetson-tx2-demo.cell $(JAILHOUSE_DESTDIR)/jailhouse/configs/
+ cp ../jailhouse/configs/arm64/jetson-tx2.cell $(DESTDIR)/jailhouse/configs/
+ cp ../jailhouse/configs/arm64/jetson-tx2-demo.cell $(DESTDIR)/jailhouse/demos/
# Add something like this to ~/.ssh/config for
# jailhouse-install-remote to work out of the box:
echo '#define CONFIG_MACH_JETSON_TX2 1' >> $@.tmp
mv --update $@.tmp $@
-rootfs-overlay/lib/modules/4.4.38+/modules.dep: kernel-4.4/vmlinux
- $(MAKE) -C kernel-4.4 -j$(NPROC) modules_install INSTALL_MOD_PATH=$(CURDIR)/rootfs-overlay
-
kernel-4.4/vmlinux:
$(MAKE) -C $(@D) -j$(NPROC)
+linux_install: kernel-4.4/vmlinux
+ install -m644 -D kernel-4.4/arch/arm64/boot/Image $(DESTDIR)/boot/Image-prem
+
+modules_install: kernel-4.4/vmlinux
+ $(MAKE) -C kernel-4.4 -j$(NPROC) modules_install INSTALL_MOD_PATH=$(DESTDIR)
+
.PHONY: FORCE
../test/prem-test: FORCE
scp ../test/prem-test tx2:/bin
# scp ../jailhouse/hypervisor/jailhouse.bin tx2:/lib/firmware
ssh tx2 'sh /etc/init.d/S20jailhouse.sh stop && sh /etc/init.d/S20jailhouse.sh start'
+
+deb: DESTDIR=$(CURDIR)/_install.deb
+deb: jailhouse-install linux_install modules_install DEBIAN_DIR
+ $(file >$(DESTDIR)/DEBIAN/control,$(deb_control))
+ $(file >$(DESTDIR)/DEBIAN/postinst,$(deb_postinst))
+ $(file >$(DESTDIR)/DEBIAN/prerm,$(deb_prerm))
+ chmod +x $(DESTDIR)/DEBIAN/postinst $(DESTDIR)/DEBIAN/prerm
+ rm -f _install.deb/lib/modules/*/source _install.deb/lib/modules/*/build
+ install -D ./rootfs-overlay/etc/init.d/S20jailhouse.sh $(DESTDIR)/etc/init.d/jailhouse
+ install -m644 -D ./rootfs-overlay/etc/systemd/system/jailhouse.service $(DESTDIR)/lib/systemd/system/jailhouse.service
+ install -d $(DESTDIR)/lib/systemd/system/multi-user.target.wants/
+ ln -sf ../jailhouse.service $(DESTDIR)/lib/systemd/system/multi-user.target.wants/jailhouse.service
+# Note: --root-owner-group requires dpkg version 1.19.0+
+ dpkg-deb --root-owner-group --build $(DESTDIR) .
+
+DEBIAN_DIR:
+ install -d $(DESTDIR)/DEBIAN
+
+
+define deb_control
+Package: jailhouse
+Essential: no
+Priority: optional
+Section: admin
+Maintainer: Michal Sojka <michal.sojka@cvut.cz>
+Architecture: arm64
+Version: $(shell git describe --always --dirty)
+Description: Jailhouse hypervisor and the Linux kernel for the HERCULES project.
+endef
+
+define deb_postinst
+#!/bin/sh
+set -e
+if ! grep -q Image-prem /boot/extlinux/extlinux.conf; then
+cat >>/boot/extlinux/extlinux.conf <<'EOF'
+LABEL prem
+ MENU LABEL prem kernel and jailhouse
+ LINUX /boot/Image-prem
+ APPEND $${cbootargs} root=/dev/mmcblk0p1 rw rootwait rootfstype=ext4 mem=7808M vmalloc=512M jailhouse
+EOF
+fi
+endef
+
+define deb_prerm
+#!/bin/sh
+set -e
+if grep -q Image-prem /boot/extlinux/extlinux.conf; then
+ . # TODO
+fi
+endef