Handle the QEMU exit code

This commit is contained in:
Chen Chengjun 2026-01-04 09:02:47 +00:00 committed by Tate, Hongliang Tian
parent 976f088712
commit 6288c057b0
7 changed files with 107 additions and 73 deletions

View File

@ -39,7 +39,7 @@ jobs:
- name: Test nix commands - name: Test nix commands
run: | run: |
make nixos NIXOS_DISK_SIZE_IN_MB=6144 NIXOS_TEST_COMMAND='test-nix-commands' make nixos NIXOS_DISK_SIZE_IN_MB=6144 NIXOS_TEST_COMMAND='test-nix-commands'
make run_nixos || true make run_nixos
- name: Check results - name: Check results
run: | run: |
@ -71,7 +71,7 @@ jobs:
- name: Run podman commands - name: Run podman commands
run: | run: |
make nixos NIXOS_DISK_SIZE_IN_MB=8192 NIXOS_TEST_COMMAND='test-podman' make nixos NIXOS_DISK_SIZE_IN_MB=8192 NIXOS_TEST_COMMAND='test-podman'
make run_nixos || true make run_nixos
- name: Check results - name: Check results
run: | run: |

View File

@ -38,8 +38,8 @@ jobs:
image: asterinas/asterinas:0.17.0-20251228 image: asterinas/asterinas:0.17.0-20251228
options: --privileged -v /dev:/dev -v ${{ github.workspace }}:/root/asterinas options: --privileged -v /dev:/dev -v ${{ github.workspace }}:/root/asterinas
run: | run: |
make nixos NIXOS_DISK_SIZE_IN_MB=6144 NIXOS_TEST_COMMAND='hello-asterinas' || true make nixos NIXOS_DISK_SIZE_IN_MB=6144 NIXOS_TEST_COMMAND='hello-asterinas'
make run_nixos || true make run_nixos
- name: Check results - name: Check results
run: | run: |
tail --lines 10 ${{ github.workspace }}/qemu.log | grep -q "^Hello Asterinas!" || (echo "Test NixOS failed" && exit 1) tail --lines 10 ${{ github.workspace }}/qemu.log | grep -q "^Hello Asterinas!" || (echo "Test NixOS failed" && exit 1)

View File

@ -331,7 +331,7 @@ iso:
# Build the Asterinas NixOS ISO installer image and then do installation # Build the Asterinas NixOS ISO installer image and then do installation
run_iso: OVMF = off run_iso: OVMF = off
run_iso: run_iso:
@./tools/nixos/run_iso.sh @./tools/nixos/run.sh iso
# Create an Asterinas NixOS installation on host # Create an Asterinas NixOS installation on host
nixos: BOOT_PROTOCOL = linux-efi-handover64 nixos: BOOT_PROTOCOL = linux-efi-handover64
@ -343,7 +343,7 @@ nixos:
# run the NixOS # run the NixOS
run_nixos: OVMF = off run_nixos: OVMF = off
run_nixos: run_nixos:
@./tools/nixos/run_nixos.sh target/nixos @./tools/nixos/run.sh nixos
# Build the Asterinas NixOS patched packages # Build the Asterinas NixOS patched packages
cachix: cachix:

View File

@ -296,9 +296,14 @@ impl Bundle {
let qemu_exit_code = exit_status.code().unwrap(); let qemu_exit_code = exit_status.code().unwrap();
let kernel_exit_code = qemu_exit_code >> 1; let kernel_exit_code = qemu_exit_code >> 1;
match kernel_exit_code { match kernel_exit_code {
0x10 /*ostd::QemuExitCode::Success*/ => { std::process::exit(0); }, // Success exit through ACPI.
0x20 /*ostd::QemuExitCode::Failed*/ => { std::process::exit(1); }, 0x0 => std::process::exit(0),
_ /* unknown, e.g., a triple fault */ => { std::process::exit(2) }, // Corresponds to `ostd::QemuExitCode::Success`.
0x10 => std::process::exit(0),
// Corresponds to `ostd::QemuExitCode::Failed`.
0x20 => std::process::exit(1),
// Unknown exit code, e.g., a triple fault.
_ => std::process::exit(2),
} }
} }

93
tools/nixos/run.sh Executable file
View File

@ -0,0 +1,93 @@
#!/bin/sh
# SPDX-License-Identifier: MPL-2.0
# Run a NixOS installation or NixOS ISO installer image built by the root Makefile inside a VM
#
# Usage: ./run.sh [nixos | iso]
set -e
usage() {
echo "Usage: $0 [nixos | iso]"
exit 1
}
if [ "$#" -ne 1 ]; then
usage
fi
MODE=$1
SCRIPT_DIR=$(dirname "$0")
ASTERINAS_DIR=$(realpath "${SCRIPT_DIR}/../..")
# Base QEMU arguments
BASE_QEMU_ARGS="qemu-system-x86_64 \
-bios /root/ovmf/release/OVMF.fd \
"
# Mode-specific QEMU arguments
case "$MODE" in
nixos)
NIXOS_DIR="${ASTERINAS_DIR}/target/nixos"
QEMU_ARGS="${BASE_QEMU_ARGS} \
-drive if=none,format=raw,id=u0,file=${NIXOS_DIR}/asterinas.img \
-device virtio-blk-pci,drive=u0,disable-legacy=on,disable-modern=off \
"
;;
iso)
ASTER_IMAGE_PATH=${ASTERINAS_DIR}/target/nixos/asterinas.img
NIXOS_DISK_SIZE_IN_MB=${NIXOS_DISK_SIZE_IN_MB:-8192}
ISO_IMAGE_PATH=$(find "${ASTERINAS_DIR}/target/nixos/iso_image/iso" -name "*.iso" | head -n 1)
if [ ! -f "$ISO_IMAGE_PATH" ]; then
echo "Error: ISO_IMAGE not found!"
exit 1
fi
rm -f "${ASTER_IMAGE_PATH}"
echo "Creating image at ${ASTER_IMAGE_PATH} of size ${NIXOS_DISK_SIZE_IN_MB}MB......"
dd if=/dev/zero of="${ASTER_IMAGE_PATH}" bs=1M count=${NIXOS_DISK_SIZE_IN_MB} status=none
echo "Image created successfully!"
QEMU_ARGS="${BASE_QEMU_ARGS} \
-cdrom ${ISO_IMAGE_PATH} -boot d \
-drive if=none,format=raw,id=u0,file=${ASTER_IMAGE_PATH} \
-device virtio-blk-pci,drive=u0,disable-legacy=on,disable-modern=off \
"
;;
*)
usage
;;
esac
if [ "${ENABLE_KVM}" = "1" ]; then
QEMU_ARGS="${QEMU_ARGS} -accel kvm"
fi
COMMON_QEMU_ARGS=$(${ASTERINAS_DIR}/tools/qemu_args.sh common 2>/dev/null)
QEMU_ARGS="
${QEMU_ARGS} \
${COMMON_QEMU_ARGS} \
"
# The kernel uses a specific value to signal a successful shutdown via the
# isa-debug-exit device.
KERNEL_SUCCESS_EXIT_CODE=16 # 0x10 in hexadecimal
# QEMU translates the value written to the isa-debug-exit device into a final
# process exit code using following formula.
QEMU_SUCCESS_EXIT_CODE=$(((KERNEL_SUCCESS_EXIT_CODE << 1) | 1))
# Execute QEMU
# shellcheck disable=SC2086
${QEMU_ARGS} || exit_code=$?
exit_code=${exit_code:-0}
# Check if the execution was successful:
# - Exit code 0: Normal successful exit (e.g., ACPI shutdown or clean termination)
# - Exit code $QEMU_SUCCESS_EXIT_CODE: Kernel signaled success via isa-debug-exit device
if [ ${exit_code} -eq 0 ] || [ ${exit_code} -eq ${QEMU_SUCCESS_EXIT_CODE} ]; then
exit 0
fi
exit ${exit_code}

View File

@ -1,40 +0,0 @@
#!/bin/bash
# SPDX-License-Identifier: MPL-2.0
set -e
SCRIPT_DIR=$(cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd)
ASTERINAS_DIR=$(realpath ${SCRIPT_DIR}/../..)
ASTER_IMAGE_PATH=${ASTERINAS_DIR}/target/nixos/asterinas.img
NIXOS_DISK_SIZE_IN_MB=${NIXOS_DISK_SIZE_IN_MB:-8192}
ISO_IMAGE_PATH=$(realpath ${ASTERINAS_DIR}/target/nixos/iso_image/iso/*.iso)
if [ ! -f "$ISO_IMAGE_PATH" ]; then
echo "Error: ISO_IMAGE not found!"
exit 1
fi
rm -f ${ASTER_IMAGE_PATH}
echo "Creating image at ${ASTER_IMAGE_PATH} of size ${NIXOS_DISK_SIZE_IN_MB}MB......"
dd if=/dev/zero of=${ASTER_IMAGE_PATH} bs=1M count=${NIXOS_DISK_SIZE_IN_MB}
echo "Image created successfully!"
QEMU_ARGS="qemu-system-x86_64 \
-bios /root/ovmf/release/OVMF.fd \
-cdrom ${ISO_IMAGE_PATH} -boot d \
-drive if=none,format=raw,id=u0,file=${ASTER_IMAGE_PATH} \
-device virtio-blk-pci,drive=u0,disable-legacy=on,disable-modern=off \
"
if [ "${ENABLE_KVM}" = "1" ]; then
QEMU_ARGS="${QEMU_ARGS} -accel kvm"
fi
COMMON_QEMU_ARGS=$(${SCRIPT_DIR}/../qemu_args.sh common 2>/dev/null)
QEMU_ARGS="
${QEMU_ARGS} \
${COMMON_QEMU_ARGS} \
"
${QEMU_ARGS}

View File

@ -1,24 +0,0 @@
#!/bin/sh
# SPDX-License-Identifier: MPL-2.0
set -e
NIXOS_DIR=$(realpath $1)
QEMU_ARGS="qemu-system-x86_64 \
-bios /root/ovmf/release/OVMF.fd \
-drive if=none,format=raw,id=u0,file=${NIXOS_DIR}/asterinas.img \
-device virtio-blk-pci,drive=u0,disable-legacy=on,disable-modern=off \
"
if [ "${ENABLE_KVM}" = "1" ]; then
QEMU_ARGS="${QEMU_ARGS} -accel kvm"
fi
COMMON_QEMU_ARGS=$(${NIXOS_DIR}/../../tools/qemu_args.sh common 2>/dev/null)
QEMU_ARGS="
${QEMU_ARGS} \
${COMMON_QEMU_ARGS} \
"
${QEMU_ARGS}