#!/usr/bin/env bash set -Eeuo pipefail # Docker environment variables : "${BIOS:=""}" # Bios file BOOT_OPTS="" BOOT_DESC="" SECURE=",secure=off" DIR="/usr/share/qemu" case "${BOOT_MODE,,}" in uefi) ROM="AAVMF_CODE.no-secboot.fd" VARS="AAVMF_VARS.fd" ;; secure) SECURE=",secure=on" BOOT_DESC=" securely" ROM="AAVMF_CODE.secboot.fd" VARS="AAVMF_VARS.fd" ;; windows) ROM="AAVMF_CODE.no-secboot.fd" VARS="AAVMF_VARS.fd" BOOT_OPTS="-rtc base=localtime" ;; windows_secure) SECURE=",secure=on" BOOT_DESC=" securely" ROM="AAVMF_CODE.ms.fd" VARS="AAVMF_VARS.ms.fd" BOOT_OPTS="-rtc base=localtime" ;; *) info "Unknown boot mode '${BOOT_MODE}', defaulting to 'uefi'" BOOT_MODE="uefi" ROM="AAVMF_CODE.no-secboot.fd" VARS="AAVMF_VARS.fd" ;; esac if [ -n "$BIOS" ]; then BOOT_OPTS="$BOOT_OPTS -bios $DIR/$BIOS" return 0 fi AAVMF="/usr/share/AAVMF/" DEST="$STORAGE/${BOOT_MODE,,}" if [ ! -s "$DEST.rom" ] || [ ! -f "$DEST.rom" ]; then [ ! -s "$AAVMF/$ROM" ] || [ ! -f "$AAVMF/$ROM" ] && error "UEFI boot file ($AAVMF/$ROM) not found!" && exit 44 rm -f "$DEST.rom" dd if=/dev/zero "of=$DEST.rom" bs=1M count=64 status=none dd "if=$AAVMF/$ROM" "of=$DEST.rom" conv=notrunc status=none fi if [ ! -s "$DEST.vars" ] || [ ! -f "$DEST.vars" ]; then [ ! -s "$AAVMF/$VARS" ] || [ ! -f "$AAVMF/$VARS" ] && error "UEFI vars file ($AAVMF/$VARS) not found!" && exit 45 rm -f "$DEST.vars" dd if=/dev/zero "of=$DEST.vars" bs=1M count=64 status=none dd "if=$AAVMF/$VARS" "of=$DEST.vars" conv=notrunc status=none fi BOOT_OPTS="$BOOT_OPTS -drive file=$DEST.rom,if=pflash,unit=0,format=raw,readonly=on" BOOT_OPTS="$BOOT_OPTS -drive file=$DEST.vars,if=pflash,unit=1,format=raw" return 0