blob: 791a75086fcee3032e486879342601709cddae65 [file] [log] [blame]
#!/bin/bash
QEMU_ARGS="-M powernv -nodefaults -device ipmi-bmc-sim,id=bmc0 -serial none"
QEMU_ARGS+=" -device isa-serial,chardev=s1 -chardev stdio,id=s1,signal=off"
if [ -z "$QEMU_BIN" ]; then
QEMU_BIN="qemu-system-ppc64"
fi
if [ ! $(command -v $QEMU_BIN) ]; then
echo "Could not find executable QEMU_BIN ($QEMU_BIN). Skipping hello_world test";
exit 0;
fi
if [ -n "$KERNEL" ]; then
echo 'Please rebuild skiboot without KERNEL set. Skipping hello_world test';
exit 0;
fi
if [ ! $(command -v expect) ]; then
echo 'Could not find expect binary. Skipping hello_world test';
exit 0;
fi
if [ -z "$SKIBOOT_ZIMAGE" ]; then
export SKIBOOT_ZIMAGE=$(pwd)/zImage.epapr
fi
if [ ! -f "$SKIBOOT_ZIMAGE" ]; then
echo "No $SKIBOOT_ZIMAGE, skipping boot test";
exit 0;
fi
T=$(mktemp --tmpdir skiboot_qemu_boot_test.XXXXXXXXXX)
( cat <<EOF | expect
set timeout 600
spawn $QEMU_BIN $QEMU_ARGS -bios skiboot.lid -kernel $SKIBOOT_ZIMAGE
expect {
timeout { send_user "\nTimeout waiting for petitboot\n"; exit 1 }
eof { send_user "\nUnexpected EOF\n;" exit 1 }
"Could not load OPAL firmware" { send_user "\nSkiboot is too large for this Qemu, skipping\n"; exit 4; }
"Machine Check Stop" { exit 1; }
"Trying to write privileged spr 338" { send_user "\nUpgrade Qemu: needs PCR register\n"; exit 3 }
"Welcome to Petitboot"
}
close
wait
exit 0
EOF
) 2>&1 > $T
E=$?
if [ $E -eq 4 ]; then
echo "Qemu is too old and can't load a skiboot.lid this big"
rm $T
exit 0
fi
if [ $E -eq 3 ]; then
echo "WARNING: Qemu test not run; upgrade QEMU to one that supports PCR register";
rm $T
exit 0;
fi
if [ -n "$V" ] ; then cat "$t" ; fi
if [ $E -eq 0 ]; then
rm $T
else
echo "Boot Test FAILED. Results in $T";
fi
echo
exit $E;