#!/bin/bash ## Check if the script is being run as root [[ "$EUID" -ne 0 ]] && echo "Please run as root" && exit 1 ## Tap interface tap_interface(){ tap_start(){ if [[ ! $(ip tuntap list | grep $1) ]]; then ip tuntap add mode tap user $VM_USER name $TAP_INTERFACE ip addr add dev $1 $TAP_IP ip link set dev $1 up fi } tap_stop(){ if [[ $(ip tuntap list | grep $1) ]]; then ip link set dev $1 down ip tuntap del mode tap name $TAP_INTERFACE fi } if [ $1 == start ]; then tap_start $TAP_INTERFACE; elif [ $1 == stop ]; then tap_stop $TAP_INTERFACE; fi } ## DHCP Server (DNSmasq) dhcp_server(){ dhcp_start(){ [[ -f /var/run/dnsmasq.pid ]] || dnsmasq --conf-file=$DNSMASQ_CONF } dhcp_stop(){ [[ -f /var/run/dnsmasq.pid ]] && sudo kill -15 $(cat /var/run/dnsmasq.pid) && sudo rm /var/run/dnsmasq.pid } if [ $1 == start ]; then dhcp_start; elif [ $1 == stop ]; then dhcp_stop; fi } ## Samba server samba_server(){ samba_start(){ [[ -f /var/run/smbd.pid ]] || sudo smbd --configfile=$SMB_CONF } samba_stop(){ [[ -f /var/run/smbd.pid ]] && sudo kill -15 $(cat /var/run/smbd.pid) } if [ $1 == start ]; then samba_start; elif [ $1 == stop ]; then samba_stop; fi } ## Load the config file source "${BASH_SOURCE%/*}/config" ## Memory lock limit [[ $ULIMIT != $ULIMIT_TARGET ]] && ulimit -l $ULIMIT_TARGET ## Kill the Display Manager systemctl stop lightdm sleep 1 ## Remove the framebuffer and console echo 0 > /sys/class/vtconsole/vtcon0/bind echo 0 > /sys/class/vtconsole/vtcon1/bind echo efi-framebuffer.0 > /sys/bus/platform/drivers/efi-framebuffer/unbind ## Unload the Kernel Modules that use the GPU modprobe -r nvidia_drm modprobe -r nvidia_modeset modprobe -r nvidia modprobe -r snd_hda_intel ## Load vfio modprobe vfio-pci ## Detach the GPU echo $videoid > /sys/bus/pci/drivers/vfio-pci/new_id echo $videobusid > /sys/bus/pci/devices/$videobusid/driver/unbind echo $videobusid > /sys/bus/pci/drivers/vfio-pci/bind echo $videoid > /sys/bus/pci/drivers/vfio-pci/remove_id echo $audioid > /sys/bus/pci/drivers/vfio-pci/new_id echo $audiobusid > /sys/bus/pci/devices/$audiobusid/driver/unbind echo $audiobusid > /sys/bus/pci/drivers/vfio-pci/bind echo $audioid > /sys/bus/pci/drivers/vfio-pci/remove_id ## Start the network tap_interface start dhcp_server start samba_server start qemu-system-x86_64 -runas $VM_USER -enable-kvm \ -nographic -vga none -parallel none -serial none \ -m $MACOS_RAM \ -cpu Penryn,kvm=on,vendor=GenuineIntel,+invtsc,vmware-cpuid-freq=on,$MACOS_OPTIONS\ -machine pc-q35-2.11 \ -smp $MACOS_CORES,sockets=1,cores=$(( $MACOS_CORES / 2 )),threads=2 \ -device vfio-pci,host=$IOMMU_GPU,multifunction=on,x-vga=on,romfile=$VBIOS \ -device vfio-pci,host=$IOMMU_GPU_AUDIO \ -usb -device usb-kbd -device usb-tablet \ -device nec-usb-xhci,id=xhci \ -netdev tap,id=net0,ifname=$TAP_INTERFACE,script=no,downscript=no \ -device e1000-82545em,netdev=net0,id=net0,mac=52:54:00:c9:18:27 \ -device isa-applesmc,osk="ourhardworkbythesewordsguardedpleasedontsteal(c)AppleComputerInc" \ -drive if=pflash,format=raw,readonly,file=$MACOS_OVMF \ -drive if=pflash,format=raw,file=$MACOS_OVMF_VARS \ -smbios type=2 \ -device ide-drive,bus=ide.2,drive=Clover \ -drive id=Clover,if=none,snapshot=on,format=qcow2,file=$MACOS_CLOVER \ -device ide-drive,bus=ide.0,drive=ISO \ -drive id=ISO,if=none,snapshot=on,media=cdrom,file=$MACOS_ISO \ -device ide-drive,bus=ide.1,drive=HDD \ -drive id=HDD,file=$MACOS_IMG,media=disk,format=qcow2,if=none >> $LOG 2>&1 & ## Wait for QEMU wait ## Stop the network tap_interface stop dhcp_server stop samba_server stop ## Unload vfio module modprobe -r vfio-pci modprobe -r vfio_iommu_type1 modprobe -r vfio ## Load the kernel modules modprobe snd_hda_intel modprobe nvidia_drm modprobe nvidia_modeset modprobe nvidia ## Reload the framebuffer and console echo 1 > /sys/class/vtconsole/vtcon0/bind nvidia-xconfig --query-gpu-info > /dev/null 2>&1 echo efi-framebuffer.0 > /sys/bus/platform/drivers/efi-framebuffer/bind # Reload the Display Manager to access X systemctl start lightdm ## Restore ulimit ulimit -l $ULIMIT