123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404 |
- #!/bin/sh
- # shellcheck disable=SC2086 # FIXME: fix these globing warnings
- set -e
- die() {
- echo "die: $*"
- exit 1
- }
- SCRIPT_DIR="$(dirname "${0}")"
- # https://www.shellcheck.net/wiki/SC1090 No need to shellcheck private config.
- # shellcheck source=/dev/null
- [ -x "$SCRIPT_DIR/../run-local.sh" ] && . "$SCRIPT_DIR/../run-local.sh"
- #SERENITY_PACKET_LOGGING_ARG="-object filter-dump,id=hue,netdev=breh,file=e1000.pcap"
- # FIXME: Enable for SERENITY_ARCH=aarch64 if on an aarch64 host?
- # Check if SERENITY_KVM_SUPPORT is unset
- if [ -z ${SERENITY_KVM_SUPPORT+x} ]; then
- KVM_SUPPORT="0"
- [ -e /dev/kvm ] && [ -r /dev/kvm ] && [ -w /dev/kvm ] && [ "$SERENITY_ARCH" != "aarch64" ] && KVM_SUPPORT="1"
- else
- KVM_SUPPORT="$SERENITY_KVM_SUPPORT"
- fi
- [ -z "$SERENITY_BOCHS_BIN" ] && SERENITY_BOCHS_BIN="bochs"
- # To support virtualization acceleration on mac
- # we need to use 64-bit qemu
- if [ "$(uname)" = "Darwin" ] && [ "$(uname -m)" = "x86_64" ]; then
- [ -z "$SERENITY_QEMU_BIN" ] && SERENITY_QEMU_BIN="qemu-system-x86_64"
- if $SERENITY_QEMU_BIN --accel help | grep -q hvf; then
- SERENITY_VIRT_TECH_ARG="--accel hvf"
- fi
- fi
- # Prepend the toolchain qemu directory so we pick up QEMU from there
- PATH="$SCRIPT_DIR/../Toolchain/Local/qemu/bin:$PATH"
- # Also prepend the i686 toolchain directory because that's where most
- # people will have their QEMU binaries if they built them before the
- # directory was changed to Toolchain/Local/qemu.
- PATH="$SCRIPT_DIR/../Toolchain/Local/i686/bin:$PATH"
- SERENITY_RUN="${SERENITY_RUN:-$1}"
- if [ -z "$SERENITY_QEMU_BIN" ]; then
- if command -v wslpath >/dev/null; then
- # Some Windows systems don't have reg.exe's directory on the PATH by default.
- PATH=$PATH:/mnt/c/Windows/System32
- QEMU_INSTALL_DIR=$(reg.exe query 'HKLM\Software\QEMU' /v Install_Dir /t REG_SZ | grep '^ Install_Dir' | sed 's/ / /g' | cut -f4- -d' ')
- if [ -z "$QEMU_INSTALL_DIR" ]; then
- if [ "$KVM_SUPPORT" -eq "0" ]; then
- die "Could not determine where QEMU for Windows is installed. Please make sure QEMU is installed or set SERENITY_QEMU_BIN if it is already installed."
- fi
- else
- KVM_SUPPORT="0"
- QEMU_BINARY_PREFIX="$(wslpath -- "${QEMU_INSTALL_DIR}" | tr -d '\r\n')/"
- QEMU_BINARY_SUFFIX=".exe"
- fi
- fi
- if [ "$SERENITY_ARCH" = "aarch64" ]; then
- SERENITY_QEMU_BIN="${QEMU_BINARY_PREFIX}qemu-system-aarch64${QEMU_BINARY_SUFFIX}"
- elif [ "$SERENITY_ARCH" = "x86_64" ]; then
- SERENITY_QEMU_BIN="${QEMU_BINARY_PREFIX}qemu-system-x86_64${QEMU_BINARY_SUFFIX}"
- else
- SERENITY_QEMU_BIN="${QEMU_BINARY_PREFIX}qemu-system-i386${QEMU_BINARY_SUFFIX}"
- fi
- fi
- [ "$KVM_SUPPORT" -eq "1" ] && SERENITY_VIRT_TECH_ARG="-enable-kvm"
- # For default values, see Kernel/CommandLine.cpp
- [ -z "$SERENITY_KERNEL_CMDLINE" ] && SERENITY_KERNEL_CMDLINE="hello"
- [ -z "$SERENITY_RAM_SIZE" ] && SERENITY_RAM_SIZE=1G
- [ -z "$SERENITY_DISK_IMAGE" ] && {
- if [ "$SERENITY_RUN" = q35grub ] || [ "$SERENITY_RUN" = qgrub ]; then
- SERENITY_DISK_IMAGE="grub_disk_image"
- elif [ "$SERENITY_RUN" = qextlinux ]; then
- SERENITY_DISK_IMAGE="extlinux_disk_image"
- else
- SERENITY_DISK_IMAGE="_disk_image"
- fi
- if command -v wslpath >/dev/null; then
- case "$SERENITY_QEMU_BIN" in
- /mnt/?/*)
- SERENITY_DISK_IMAGE=$(wslpath -w "$SERENITY_DISK_IMAGE")
- ;;
- esac
- fi
- }
- if ! command -v "$SERENITY_QEMU_BIN" >/dev/null 2>&1 ; then
- die "Please install QEMU version 5.0 or newer or use the Toolchain/BuildQemu.sh script."
- fi
- SERENITY_QEMU_MIN_REQ_VERSION=5
- installed_major_version=$("$SERENITY_QEMU_BIN" -version | head -n 1 | sed -E 's/QEMU emulator version ([1-9][0-9]*|0).*/\1/')
- installed_minor_version=$("$SERENITY_QEMU_BIN" -version | head -n 1 | sed -E 's/QEMU emulator version [0-9]+\.([1-9][0-9]*|0).*/\1/')
- if [ "$installed_major_version" -lt "$SERENITY_QEMU_MIN_REQ_VERSION" ]; then
- echo "Required QEMU >= 5.0! Found $($SERENITY_QEMU_BIN -version | head -n 1)"
- echo "Please install a newer version of QEMU or use the Toolchain/BuildQemu.sh script."
- die
- fi
- NATIVE_WINDOWS_QEMU="0"
- if command -v wslpath >/dev/null; then
- case "$SERENITY_QEMU_BIN" in
- /mnt/?/*)
- if [ -z "$SERENITY_VIRT_TECH_ARG" ]; then
- if [ "$installed_major_version" -gt 5 ]; then
- SERENITY_VIRT_TECH_ARG="-accel whpx,kernel-irqchip=off -accel tcg"
- else
- SERENITY_VIRT_TECH_ARG="-accel whpx -accel tcg"
- fi
- fi
- [ -z "$SERENITY_QEMU_CPU" ] && SERENITY_QEMU_CPU="max,vmx=off"
- SERENITY_KERNEL_CMDLINE="$SERENITY_KERNEL_CMDLINE disable_virtio"
- NATIVE_WINDOWS_QEMU="1"
- ;;
- esac
- fi
- [ -z "$SERENITY_QEMU_CPU" ] && SERENITY_QEMU_CPU="max"
- if [ "$SERENITY_ARCH" != "aarch64" ]; then
- [ -z "$SERENITY_CPUS" ] && SERENITY_CPUS="2"
- if [ "$SERENITY_CPUS" -le 8 ]; then
- # Explicitly disable x2APIC so we can test it more easily
- SERENITY_QEMU_CPU="$SERENITY_QEMU_CPU,-x2apic"
- fi
- if [ -z "$SERENITY_SPICE" ] && "${SERENITY_QEMU_BIN}" -chardev help | grep -iq qemu-vdagent; then
- SERENITY_SPICE_SERVER_CHARDEV="-chardev qemu-vdagent,clipboard=on,mouse=off,id=vdagent,name=vdagent"
- elif "${SERENITY_QEMU_BIN}" -chardev help | grep -iq spicevmc; then
- SERENITY_SPICE_SERVER_CHARDEV="-chardev spicevmc,id=vdagent,name=vdagent"
- fi
- fi
- if [ "$(uname)" = "Darwin" ]; then
- SERENITY_AUDIO_BACKEND="-audiodev coreaudio,id=snd0"
- elif [ "$NATIVE_WINDOWS_QEMU" -eq "1" ]; then
- SERENITY_AUDIO_BACKEND="-audiodev dsound,id=snd0"
- elif "$SERENITY_QEMU_BIN" -audio-help 2>&1 | grep -- "-audiodev id=sdl" >/dev/null; then
- SERENITY_AUDIO_BACKEND="-audiodev sdl,id=snd0"
- else
- SERENITY_AUDIO_BACKEND="-audiodev pa,timer-period=2000,id=snd0"
- fi
- if [ "$installed_major_version" -eq 5 ] && [ "$installed_minor_version" -eq 0 ]; then
- SERENITY_AUDIO_HW="-soundhw pcspk"
- else
- SERENITY_AUDIO_HW="-machine pcspk-audiodev=snd0"
- fi
- SERENITY_SCREENS="${SERENITY_SCREENS:-1}"
- if [ "$SERENITY_SPICE" ]; then
- SERENITY_QEMU_DISPLAY_BACKEND="${SERENITY_QEMU_DISPLAY_BACKEND:-spice-app}"
- elif [ "$NATIVE_WINDOWS_QEMU" -eq "1" ]; then
- # QEMU for windows does not like gl=on, so detect if we are building in wsl, and if so, disable it
- # Also, when using the GTK backend we run into this problem: https://github.com/SerenityOS/serenity/issues/7657
- SERENITY_QEMU_DISPLAY_BACKEND="${SERENITY_QEMU_DISPLAY_BACKEND:-sdl,gl=off}"
- elif [ $SERENITY_SCREENS -gt 1 ] && "${SERENITY_QEMU_BIN}" --display help | grep -iq sdl; then
- SERENITY_QEMU_DISPLAY_BACKEND="${SERENITY_QEMU_DISPLAY_BACKEND:-sdl,gl=off}"
- elif ! command -v wslpath >/dev/null && ("${SERENITY_QEMU_BIN}" --display help | grep -iq sdl) && (ldconfig -p | grep -iq virglrenderer); then
- SERENITY_QEMU_DISPLAY_BACKEND="${SERENITY_QEMU_DISPLAY_BACKEND:-sdl,gl=on}"
- elif "${SERENITY_QEMU_BIN}" --display help | grep -iq cocoa; then
- # QEMU for OSX seems to only support cocoa
- SERENITY_QEMU_DISPLAY_BACKEND="${SERENITY_QEMU_DISPLAY_BACKEND:-cocoa,gl=off}"
- else
- SERENITY_QEMU_DISPLAY_BACKEND="${SERENITY_QEMU_DISPLAY_BACKEND:-gtk,gl=off}"
- fi
- if [ "$SERENITY_SCREENS" -gt 1 ]; then
- SERENITY_QEMU_DISPLAY_DEVICE="virtio-vga,max_outputs=$SERENITY_SCREENS "
- # QEMU appears to always relay absolute mouse coordinates relative to the screen that the mouse is
- # pointed to, without any way for us to know what screen it was. So, when dealing with multiple
- # displays force using relative coordinates only
- SERENITY_KERNEL_CMDLINE="$SERENITY_KERNEL_CMDLINE vmmouse=off"
- else
- SERENITY_QEMU_DISPLAY_DEVICE="VGA,vgamem_mb=64 "
- fi
- # Check if SERENITY_NVME_ENABLE is unset
- if [ -z ${SERENITY_NVME_ENABLE+x} ]; then
- SERENITY_BOOT_DRIVE="-drive file=${SERENITY_DISK_IMAGE},format=raw,index=0,media=disk"
- else
- if [ "$SERENITY_NVME_ENABLE" -eq 1 ]; then
- SERENITY_BOOT_DRIVE="-drive file=${SERENITY_DISK_IMAGE},format=raw,index=0,media=disk,if=none,id=disk"
- SERENITY_BOOT_DRIVE="$SERENITY_BOOT_DRIVE -device i82801b11-bridge,id=bridge4 -device sdhci-pci,bus=bridge4"
- SERENITY_BOOT_DRIVE="$SERENITY_BOOT_DRIVE -device nvme,serial=deadbeef,drive=disk,bus=bridge4"
- else
- SERENITY_BOOT_DRIVE="-drive file=${SERENITY_DISK_IMAGE},format=raw,index=0,media=disk"
- fi
- fi
- if [ -z "$SERENITY_DISABLE_GDB_SOCKET" ]; then
- SERENITY_EXTRA_QEMU_ARGS="$SERENITY_EXTRA_QEMU_ARGS -s"
- fi
- if [ -z "$SERENITY_ETHERNET_DEVICE_TYPE" ]; then
- SERENITY_ETHERNET_DEVICE_TYPE="e1000"
- fi
- if [ -z "$SERENITY_MACHINE" ]; then
- if [ "$SERENITY_ARCH" = "aarch64" ]; then
- SERENITY_MACHINE="-M raspi3 -serial stdio"
- else
- SERENITY_MACHINE="
- -m $SERENITY_RAM_SIZE
- -smp $SERENITY_CPUS
- -display $SERENITY_QEMU_DISPLAY_BACKEND
- -device $SERENITY_QEMU_DISPLAY_DEVICE
- -device virtio-serial,max_ports=2
- -device virtconsole,chardev=stdout
- -device isa-debugcon,chardev=stdout
- -device virtio-rng-pci
- $SERENITY_AUDIO_BACKEND
- $SERENITY_AUDIO_HW
- -device ac97,audiodev=snd0
- -device pci-bridge,chassis_nr=1,id=bridge1 -device $SERENITY_ETHERNET_DEVICE_TYPE,bus=bridge1
- -device i82801b11-bridge,bus=bridge1,id=bridge2 -device sdhci-pci,bus=bridge2
- -device i82801b11-bridge,id=bridge3 -device sdhci-pci,bus=bridge3
- -device ich9-ahci,bus=bridge3
- -chardev stdio,id=stdout,mux=on
- $SERENITY_BOOT_DRIVE
- "
- fi
- fi
- if [ "$NATIVE_WINDOWS_QEMU" -ne "1" ]; then
- SERENITY_MACHINE="$SERENITY_MACHINE
- -qmp unix:qmp-sock,server,nowait"
- fi
- [ -z "$SERENITY_COMMON_QEMU_ARGS" ] && SERENITY_COMMON_QEMU_ARGS="
- $SERENITY_EXTRA_QEMU_ARGS
- $SERENITY_MACHINE
- -cpu $SERENITY_QEMU_CPU
- -d guest_errors
- -usb
- $SERENITY_SPICE_SERVER_CHARDEV
- "
- if [ "$SERENITY_ARCH" != "aarch64" ]; then
- if "${SERENITY_QEMU_BIN}" -chardev help | grep -iq spice; then
- SERENITY_COMMON_QEMU_ARGS="$SERENITY_COMMON_QEMU_ARGS
- -spice port=5930,agent-mouse=off,disable-ticketing=on
- -device virtserialport,chardev=vdagent,nr=1
- "
- fi
- fi
- [ -z "$SERENITY_COMMON_QEMU_Q35_ARGS" ] && SERENITY_COMMON_QEMU_Q35_ARGS="
- $SERENITY_EXTRA_QEMU_ARGS
- -m $SERENITY_RAM_SIZE
- -cpu $SERENITY_QEMU_CPU
- -machine q35
- -d guest_errors
- -smp $SERENITY_CPUS
- -vga none
- -device bochs-display
- -device ich9-usb-ehci1,bus=pcie.0,multifunction=on,addr=0x5.0x0
- -device ich9-usb-ehci2,bus=pcie.0,addr=0x5.0x2
- -device ich9-usb-uhci1,bus=pcie.0,multifunction=on,addr=0x7.0x0
- -device ich9-usb-uhci2,bus=pcie.0,addr=0x7.0x1
- -device ich9-usb-uhci3,bus=pcie.0,addr=0x7.0x2
- -device ich9-usb-uhci4,bus=pcie.0,addr=0x7.0x3
- -device ich9-usb-uhci5,bus=pcie.0,addr=0x7.0x4
- -device ich9-usb-uhci6,bus=pcie.0,addr=0x7.0x5
- -device pcie-root-port,port=0x10,chassis=1,id=pcie.1,bus=pcie.0,multifunction=on,addr=0x6
- -device pcie-root-port,port=0x11,chassis=2,id=pcie.2,bus=pcie.0,addr=0x6.0x1
- -device pcie-root-port,port=0x12,chassis=3,id=pcie.3,bus=pcie.0,addr=0x6.0x2
- -device pcie-root-port,port=0x13,chassis=4,id=pcie.4,bus=pcie.0,addr=0x6.0x3
- -device pcie-root-port,port=0x14,chassis=5,id=pcie.5,bus=pcie.0,addr=0x6.0x4
- -device pcie-root-port,port=0x15,chassis=6,id=pcie.6,bus=pcie.0,addr=0x6.0x5
- -device pcie-root-port,port=0x16,chassis=7,id=pcie.7,bus=pcie.0,addr=0x6.0x6
- -device pcie-root-port,port=0x17,chassis=8,id=pcie.8,bus=pcie.0,addr=0x6.0x7
- -device bochs-display,bus=pcie.6,addr=0x10.0x0
- -device ich9-intel-hda,bus=pcie.2,addr=0x03.0x0
- -device nec-usb-xhci,bus=pcie.2,addr=0x11.0x0
- -device pci-bridge,chassis_nr=1,id=bridge1,bus=pcie.4,addr=0x3.0x0
- -device sdhci-pci,bus=bridge1,addr=0x1.0x0
- -display $SERENITY_QEMU_DISPLAY_BACKEND
- -device ahci,id=ahci
- -device virtio-serial
- -chardev stdio,id=stdout,mux=on
- -device virtconsole,chardev=stdout
- -device isa-debugcon,chardev=stdout
- -device virtio-rng-pci
- $SERENITY_AUDIO_BACKEND
- $SERENITY_AUDIO_HW
- $SERENITY_BOOT_DRIVE
- "
- export SDL_VIDEO_X11_DGAMOUSE=0
- : "${SERENITY_BUILD:=.}"
- cd -P -- "$SERENITY_BUILD" || die "Could not cd to \"$SERENITY_BUILD\""
- if [ "$SERENITY_RUN" = "b" ]; then
- # Meta/run.sh b: bochs
- [ -z "$SERENITY_BOCHSRC" ] && {
- # Make sure that SERENITY_SOURCE_DIR is set and not empty
- [ -z "$SERENITY_SOURCE_DIR" ] && die 'SERENITY_SOURCE_DIR not set or empty'
- SERENITY_BOCHSRC="$SERENITY_SOURCE_DIR/Meta/bochsrc"
- }
- "$SERENITY_BOCHS_BIN" -q -f "$SERENITY_BOCHSRC"
- elif [ "$SERENITY_RUN" = "qn" ]; then
- # Meta/run.sh qn: qemu without network
- "$SERENITY_QEMU_BIN" \
- $SERENITY_COMMON_QEMU_ARGS \
- -device $SERENITY_ETHERNET_DEVICE_TYPE \
- -kernel Kernel/Prekernel/Prekernel \
- -initrd Kernel/Kernel \
- -append "${SERENITY_KERNEL_CMDLINE}"
- elif [ "$SERENITY_RUN" = "qtap" ]; then
- # Meta/run.sh qtap: qemu with tap
- sudo ip tuntap del dev tap0 mode tap || true
- sudo ip tuntap add dev tap0 mode tap user "$(id -u)"
- "$SERENITY_QEMU_BIN" \
- $SERENITY_COMMON_QEMU_ARGS \
- $SERENITY_VIRT_TECH_ARG \
- $SERENITY_PACKET_LOGGING_ARG \
- -netdev tap,ifname=tap0,id=br0 \
- -device $SERENITY_ETHERNET_DEVICE_TYPE,netdev=br0 \
- -kernel Kernel/Prekernel/Prekernel \
- -initrd Kernel/Kernel \
- -append "${SERENITY_KERNEL_CMDLINE}"
- sudo ip tuntap del dev tap0 mode tap
- elif [ "$SERENITY_RUN" = "qgrub" ] || [ "$SERENITY_RUN" = "qextlinux" ]; then
- # Meta/run.sh qgrub: qemu with grub/extlinux
- "$SERENITY_QEMU_BIN" \
- $SERENITY_COMMON_QEMU_ARGS \
- $SERENITY_VIRT_TECH_ARG \
- $SERENITY_PACKET_LOGGING_ARG \
- -netdev user,id=breh,hostfwd=tcp:127.0.0.1:8888-10.0.2.15:8888,hostfwd=tcp:127.0.0.1:8823-10.0.2.15:23 \
- -device $SERENITY_ETHERNET_DEVICE_TYPE,netdev=breh
- elif [ "$SERENITY_RUN" = "q35" ]; then
- # Meta/run.sh q35: qemu (q35 chipset) with SerenityOS
- echo "Starting SerenityOS with QEMU Q35 machine, Commandline: ${SERENITY_KERNEL_CMDLINE}"
- "$SERENITY_QEMU_BIN" \
- $SERENITY_COMMON_QEMU_Q35_ARGS \
- $SERENITY_VIRT_TECH_ARG \
- -netdev user,id=breh,hostfwd=tcp:127.0.0.1:8888-10.0.2.15:8888,hostfwd=tcp:127.0.0.1:8823-10.0.2.15:23 \
- -device $SERENITY_ETHERNET_DEVICE_TYPE,netdev=breh \
- -kernel Kernel/Prekernel/Prekernel \
- -initrd Kernel/Kernel \
- -append "${SERENITY_KERNEL_CMDLINE}"
- elif [ "$SERENITY_RUN" = "q35grub" ]; then
- # Meta/run.sh q35grub: qemu (q35 chipset) with SerenityOS, using a grub disk image
- "$SERENITY_QEMU_BIN" \
- $SERENITY_COMMON_QEMU_Q35_ARGS \
- $SERENITY_VIRT_TECH_ARG \
- -netdev user,id=breh,hostfwd=tcp:127.0.0.1:8888-10.0.2.15:8888,hostfwd=tcp:127.0.0.1:8823-10.0.2.15:23 \
- -device $SERENITY_ETHERNET_DEVICE_TYPE,netdev=breh
- elif [ "$SERENITY_RUN" = "ci" ]; then
- # Meta/run.sh ci: qemu in text mode
- echo "Running QEMU in CI"
- "$SERENITY_QEMU_BIN" \
- $SERENITY_EXTRA_QEMU_ARGS \
- $SERENITY_VIRT_TECH_ARG \
- -m $SERENITY_RAM_SIZE \
- -cpu $SERENITY_QEMU_CPU \
- -d guest_errors \
- -no-reboot \
- -smp ${SERENITY_CPUS} \
- -drive file=${SERENITY_DISK_IMAGE},format=raw,index=0,media=disk \
- -device ich9-ahci \
- -nographic \
- -display none \
- -debugcon file:debug.log \
- -kernel Kernel/Prekernel/Prekernel \
- -initrd Kernel/Kernel \
- -append "${SERENITY_KERNEL_CMDLINE}"
- else
- # Meta/run.sh: qemu with user networking
- if [ "$SERENITY_ARCH" = "aarch64" ]; then
- SERENITY_NETFLAGS=
- else
- SERENITY_NETFLAGS="
- -netdev user,id=breh,hostfwd=tcp:127.0.0.1:8888-10.0.2.15:8888,hostfwd=tcp:127.0.0.1:8823-10.0.2.15:23,hostfwd=tcp:127.0.0.1:8000-10.0.2.15:8000,hostfwd=tcp:127.0.0.1:2222-10.0.2.15:22 \
- -device $SERENITY_ETHERNET_DEVICE_TYPE,netdev=breh \
- "
- fi
- "$SERENITY_QEMU_BIN" \
- $SERENITY_COMMON_QEMU_ARGS \
- $SERENITY_VIRT_TECH_ARG \
- $SERENITY_PACKET_LOGGING_ARG \
- $SERENITY_NETFLAGS \
- -kernel Kernel/Prekernel/Prekernel \
- -initrd Kernel/Kernel \
- -append "${SERENITY_KERNEL_CMDLINE}"
- fi
|