#!/bin/bash # # A quick standard test of Haiku booting under qemu in various configurations # # Example usages: # x86_64 bios # ../src/tests/qemu-boot-test x86_64 bios haiku-nightly-anyboot.iso # x86_64 efi # ../src/tests/qemu-boot-test x86_64 efi haiku-nightly-anyboot.iso # riscv64 opensbi w/u-boot payload # ../src/tests/qemu-boot-test riscv64 kernel:~/Code/firmware/u-boot/riscv64/qemu/u-boot.bin haiku-mmc.image if [ $# -lt 3 ]; then echo "Usage: $0 " exit 1; fi ARCH=$1 PLATFORM=$2 IMAGE=$3 EMULATOR=qemu-system-$ARCH EXTRAS="-parallel none" function check_logs { FILE=$1 echo -n " Haiku kernel loaded: " # First output from kernel on boot if grep -q "Welcome to kernel debugger output" $FILE; then echo "YES" else echo "NO" fi # Checking for a KDL echo -n " Potential KDL Detected: " if grep -q "kdebug>" $FILE; then echo "YES" else echo "NO" fi echo " Potential issues in logs:" egrep -i "FATAL|ERROR|FAIL|GDB" $FILE | grep -vi " No error" } case "$PLATFORM" in bios) EXTRAS="$EXTRAS" ;; efi) eval BIOS="${EFI_BIOS}:-/usr/share/edk2/ovmf/OVMF_CODE.fd" EXTRAS="$EXTRAS -bios $QEMU_BIOS" ;; bios:*) eval BIOS=$(echo "$PLATFORM" | cut -d":" -f2) EXTRAS="$EXTRAS -bios $BIOS" ;; kernel:*) eval BIOS=$(echo "$PLATFORM" | cut -d":" -f2) EXTRAS="$EXTRAS -kernel $BIOS" ;; *) EXTRAS="$EXTRAS" ;; esac echo "We're going to step through the potential boot options for $ARCH under qemu" echo "" echo -n "Press enter to begin..." read TEST_SERIALLOG="/tmp/test-$ARCH-serial.mon" EXTRAS="$EXTRAS -chardev vc,id=serial,logfile=$TEST_SERIALLOG,signal=off -serial chardev:serial" > $TEST_SERIALLOG case "$ARCH" in "x86" | "x86_64") MEMORY=2048 TEST_FILE="/tmp/test-$ARCH.iso" EMULATOR="$EMULATOR --enable-kvm -m $MEMORY $EXTRAS" rm -f $TEST_FILE echo "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++" echo "+++ Testing $PLATFORM CDROM boot..." cp $IMAGE $TEST_FILE $EMULATOR -cdrom $TEST_FILE check_logs $TEST_SERIALLOG rm -f $TEST_FILE $TEST_SERIALLOG echo "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++" echo "+++ Testing $PLATFORM IDE boot..." cp $IMAGE $TEST_FILE $EMULATOR -drive file=$TEST_FILE,format=raw,if=ide check_logs $TEST_SERIALLOG rm -f $TEST_FILE $TEST_SERIALLOG echo "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++" echo "+++ Testing $PLATFORM USB boot..." cp $IMAGE $TEST_FILE $EMULATOR -drive if=none,id=stick,file=$TEST_FILE,format=raw -device qemu-xhci,id=xhci -device usb-storage,bus=xhci.0,drive=stick check_logs $TEST_SERIALLOG rm -f $TEST_FILE $TEST_SERIALLOG ;; "riscv64") MEMORY=2048 TEST_FILE="/tmp/test-$ARCH.mmu" EMULATOR="$EMULATOR -m $MEMORY -M virt $EXTRAS" rm -f $TEST_FILE $TEST_SERIALLOG echo "+++++++++++++++++++++++++++++++++++++++++++++++++++++++++" echo "+++ Testing $PLATFORM boot..." cp $IMAGE $TEST_FILE $EMULATOR -device ati-vga -drive file=$TEST_FILE,format=raw,if=virtio check_logs $TEST_SERIALLOG rm -f $TEST_FILE $TEST_SERIALLOG ;; *) echo "Error: Unknown architecture!" ;; esac