From 305b0cd90e6f7bd7158d5bc90fbd7c411e3203dd Mon Sep 17 00:00:00 2001 From: Martin Wimpress Date: Sat, 24 Jan 2026 20:27:03 +0000 Subject: [PATCH] fix(quickemu): derive qemu share path from binary location - Add get_qemu_share_path() to resolve the QEMU binary realpath and derive a matching share directory (handles symlinks, Nix store paths, Homebrew, MacPorts and custom builds) - Replace ad-hoc brew/system logic in configure_bios with resolved share path - Fallback to /usr/share when no qemu firmware directory is found Improve firmware/OVMF lookup reliability for non-system QEMU installations. Signed-off-by: Martin Wimpress --- quickemu | 47 ++++++++++++++++++++++++++++++++++++++++------- 1 file changed, 40 insertions(+), 7 deletions(-) diff --git a/quickemu b/quickemu index b3ea8aa..8b6cbad 100755 --- a/quickemu +++ b/quickemu @@ -842,6 +842,44 @@ function is_firmware_qcow2() { [ "$magic" = "514649fb" ] && echo "true" || echo "false" } +# Derive QEMU share path from binary location +# Handles Nix, Homebrew, MacPorts, system packages, custom builds +function get_qemu_share_path() { + local qemu_bin="${QEMU}" + local qemu_real qemu_prefix share_path + + # Resolve the actual binary path (handles symlinks, Nix store paths) + if command -v realpath &>/dev/null; then + qemu_real=$(realpath "${qemu_bin}" 2>/dev/null) || qemu_real="${qemu_bin}" + else + # macOS fallback: follow symlink chain manually + qemu_real="${qemu_bin}" + while [ -L "${qemu_real}" ]; do + local link_target + link_target=$(readlink "${qemu_real}") + # Handle relative symlinks + if [[ "${link_target}" != /* ]]; then + qemu_real="$(dirname "${qemu_real}")/${link_target}" + else + qemu_real="${link_target}" + fi + done + fi + + # /path/to/bin/qemu-system-x86_64 -> /path/to/share + qemu_prefix="$(dirname "$(dirname "${qemu_real}")")" + share_path="${qemu_prefix}/share" + + # Validate: must contain qemu firmware directory + if [ -d "${share_path}/qemu" ]; then + echo "${share_path}" + return 0 + fi + + # Fallback for system installations + echo "/usr/share" +} + function configure_bios() { # Always Boot macOS using EFI if [ "${guest_os}" == "macos" ]; then @@ -900,13 +938,8 @@ function configure_bios() { # OVMF_CODE.secboot.fd is like OVMF_CODE_4M.fd, but will abort if QEMU # does not support SMM. - local SHARE_PATH="/usr/share" - if [ "${OS_KERNEL}" == "Darwin" ]; then - # Do not assume brew; quickemu could have been installed via Nix - if command -v brew &>/dev/null; then - SHARE_PATH="$(brew --prefix qemu)/share" - fi - fi + local SHARE_PATH + SHARE_PATH=$(get_qemu_share_path) # https://bugzilla.redhat.com/show_bug.cgi?id=1929357#c5 # TODO: Check if macOS should use 'edk2-i386-vars.fd'