Added support for changing virtual sound hardware

Added new configuration file option "sound_card" and new command-line
switch "--sound-card" to change the virtual sound hardware. Allowed
options are "intel-hda" (default), "ac97", "es1370", "sb16", and "none".
Also changed default sound card for Solaris to "ac97" and for FreeDOS to
"sb16".

https://github.com/quickemu-project/quickemu/pull/705
Co-authored-by: Chase Covello <chase@chasecovello.com>
This commit is contained in:
zenobit 2023-09-14 16:28:10 +02:00
parent dee5224103
commit bbf62dea46

View file

@ -235,6 +235,7 @@ function vm_boot() {
local MAC_DISK_DEV="${MAC_DISK_DEV:-ide-hd,bus=ahci.2}" local MAC_DISK_DEV="${MAC_DISK_DEV:-ide-hd,bus=ahci.2}"
local NET_DEVICE="${NET_DEVICE:-virtio-net}" local NET_DEVICE="${NET_DEVICE:-virtio-net}"
local OSK="" local OSK=""
local SOUND=""
local SMM="${SMM:-off}" local SMM="${SMM:-off}"
local USB_HOST_PASSTHROUGH_CONTROLLER="qemu-xhci" local USB_HOST_PASSTHROUGH_CONTROLLER="qemu-xhci"
local VGA="" local VGA=""
@ -487,11 +488,13 @@ function vm_boot() {
if [ "${guest_os}" == "freedos" ] ; then if [ "${guest_os}" == "freedos" ] ; then
# fix for #382 # fix for #382
SMM="on" SMM="on"
SOUND_CARD="sb16"
fi fi
if [[ "${guest_os}" == *"solaris" ]]; then if [[ "${guest_os}" == *"solaris" ]]; then
MACHINE_TYPE="pc" MACHINE_TYPE="pc"
USB_CONTROLLER="xhci" USB_CONTROLLER="xhci"
SOUND_CARD="ac97"
fi fi
if [ -z "${disk_size}" ]; then if [ -z "${disk_size}" ]; then
@ -792,6 +795,16 @@ function vm_boot() {
# Add fullscreen options # Add fullscreen options
VIDEO="${VGA} ${VIDEO} ${FULLSCREEN}" VIDEO="${VGA} ${VIDEO} ${FULLSCREEN}"
# Build the sound hardware configuration
if [ "${SOUND_CARD}" == "intel-hda" ]; then
SOUND="-device intel-hda -device hda-duplex,audiodev=audio0"
elif [ "${SOUND_CARD}" == "ac97" ] || [ "${SOUND_CARD}" == "es1370" ] || [ "${SOUND_CARD}" == "sb16" ]; then
SOUND="-device ${SOUND_CARD},audiodev=audio0"
elif [ "${SOUND_CARD}" == "none" ]; then
SOUND=""
fi
echo " - Sound: ${SOUND_CARD}"
# Set the hostname of the VM # Set the hostname of the VM
local NET="user,hostname=${VMNAME}" local NET="user,hostname=${VMNAME}"
@ -920,7 +933,7 @@ function vm_boot() {
-m ${RAM_VM} ${BALLOON} -m ${RAM_VM} ${BALLOON}
${VIDEO} -display ${DISPLAY_RENDER} ${VIDEO} -display ${DISPLAY_RENDER}
-audiodev ${AUDIO_DEV} -audiodev ${AUDIO_DEV}
-device intel-hda -device hda-duplex,audiodev=audio0 ${SOUND}
-rtc base=localtime,clock=host,driftfix=slew) -rtc base=localtime,clock=host,driftfix=slew)
# Only enable SPICE is using SPICE display # Only enable SPICE is using SPICE display
@ -1330,7 +1343,7 @@ function usage() {
echo " --viewer <viewer> : Choose an alternative viewer. @Options: 'spicy' (default), 'remote-viewer', 'none'" echo " --viewer <viewer> : Choose an alternative viewer. @Options: 'spicy' (default), 'remote-viewer', 'none'"
echo " --ssh-port <port> : Set ssh-port manually" echo " --ssh-port <port> : Set ssh-port manually"
echo " --spice-port <port> : Set spice-port manually" echo " --spice-port <port> : Set spice-port manually"
echo " --public-dir <path> : expose share directory. @Options: '' (default: xdg-user-dir PUBLICSHARE), '<directory>', 'none'" echo " --public-dir <path> : Expose share directory. @Options: '' (default: xdg-user-dir PUBLICSHARE), '<directory>', 'none'"
echo " --monitor <type> : Set monitor connection type. @Options: 'socket' (default), 'telnet', 'none'" echo " --monitor <type> : Set monitor connection type. @Options: 'socket' (default), 'telnet', 'none'"
echo " --monitor-telnet-host <ip/host> : Set telnet host for monitor. (default: 'localhost')" echo " --monitor-telnet-host <ip/host> : Set telnet host for monitor. (default: 'localhost')"
echo " --monitor-telnet-port <port> : Set telnet port for monitor. (default: '4440')" echo " --monitor-telnet-port <port> : Set telnet port for monitor. (default: '4440')"
@ -1342,6 +1355,7 @@ function usage() {
echo " --keyboard_layout <layout> : Set keyboard layout." echo " --keyboard_layout <layout> : Set keyboard layout."
echo " --mouse <type> : Set mouse. @Options: 'tablet' (default), 'ps2', 'usb', 'virtio'" echo " --mouse <type> : Set mouse. @Options: 'tablet' (default), 'ps2', 'usb', 'virtio'"
echo " --usb-controller <type> : Set usb-controller. @Options: 'ehci' (default), 'xhci', 'none'" echo " --usb-controller <type> : Set usb-controller. @Options: 'ehci' (default), 'xhci', 'none'"
echo " --sound-card <type> : Set sound card. @Options: 'intel-hda' (default), 'ac97', 'es1370', 'sb16', 'none'"
echo " --extra_args <arguments> : Pass additional arguments to qemu" echo " --extra_args <arguments> : Pass additional arguments to qemu"
echo " --version : Print version" echo " --version : Print version"
exit 1 exit 1
@ -1354,6 +1368,13 @@ function display_param_check() {
fi fi
} }
function sound_card_param_check() {
if [ "${SOUND_CARD}" != "intel-hda" ] && [ "${SOUND_CARD}" != "ac97" ] && [ "${SOUND_CARD}" != "es1370" ] && [ "${SOUND_CARD}" != "sb16" ] && [ "${SOUND_CARD}" != "none" ]; then
echo "ERROR! Requested sound card '${SOUND_CARD}' is not recognised."
exit 1
fi
}
function viewer_param_check() { function viewer_param_check() {
if [ "${VIEWER}" != "none" ] && [ "${VIEWER}" != "spicy" ] && [ "${VIEWER}" != "remote-viewer" ]; then if [ "${VIEWER}" != "none" ] && [ "${VIEWER}" != "spicy" ] && [ "${VIEWER}" != "remote-viewer" ]; then
echo "ERROR! Requested viewer '${VIEWER}' is not recognised." echo "ERROR! Requested viewer '${VIEWER}' is not recognised."
@ -1474,6 +1495,8 @@ keyboard="usb"
keyboard_layout="en-us" keyboard_layout="en-us"
# options: ps2, usb, tablet, virtio # options: ps2, usb, tablet, virtio
mouse="tablet" mouse="tablet"
# options: intel-hda, ac97, es1370, sb16, none
sound_card="intel-hda"
BRAILLE="" BRAILLE=""
DELETE_DISK=0 DELETE_DISK=0
@ -1512,6 +1535,7 @@ KEYBOARD_LAYOUT=""
MOUSE="" MOUSE=""
USB_CONTROLLER="" USB_CONTROLLER=""
EXTRA_ARGS="" EXTRA_ARGS=""
SOUND_CARD=""
# shellcheck disable=SC2155 # shellcheck disable=SC2155
readonly LAUNCHER=$(basename "${0}") readonly LAUNCHER=$(basename "${0}")
@ -1665,6 +1689,10 @@ else
EXTRA_ARGS="${2}" EXTRA_ARGS="${2}"
shift; shift;
shift;; shift;;
-sound-card|--sound-card)
SOUND_CARD="${2}"
shift;
shift;;
-version|--version) -version|--version)
echo "${VERSION}" echo "${VERSION}"
exit;; exit;;
@ -1767,6 +1795,11 @@ if [ -n "${VM}" ] && [ -e "${VM}" ]; then
exit 1 exit 1
fi fi
if [ -z "${SOUND_CARD}" ]; then
SOUND_CARD="${sound_card}"
fi
sound_card_param_check
# Check if vm is already run # Check if vm is already run
VM_PID=0 VM_PID=0
VM_UP=0 VM_UP=0