summaryrefslogtreecommitdiffstats
path: root/src/VBox/Installer/darwin/VBoxKEXTs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-11 08:17:27 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-11 08:17:27 +0000
commitf215e02bf85f68d3a6106c2a1f4f7f063f819064 (patch)
tree6bb5b92c046312c4e95ac2620b10ddf482d3fa8b /src/VBox/Installer/darwin/VBoxKEXTs
parentInitial commit. (diff)
downloadvirtualbox-f215e02bf85f68d3a6106c2a1f4f7f063f819064.tar.xz
virtualbox-f215e02bf85f68d3a6106c2a1f4f7f063f819064.zip
Adding upstream version 7.0.14-dfsg.upstream/7.0.14-dfsg
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/VBox/Installer/darwin/VBoxKEXTs')
-rw-r--r--src/VBox/Installer/darwin/VBoxKEXTs/PkgBuildComponent.plist29
-rwxr-xr-xsrc/VBox/Installer/darwin/VBoxKEXTs/VirtualBoxStartup.sh277
-rw-r--r--src/VBox/Installer/darwin/VBoxKEXTs/org.virtualbox.startup.plist17
-rwxr-xr-xsrc/VBox/Installer/darwin/VBoxKEXTs/postflight117
4 files changed, 440 insertions, 0 deletions
diff --git a/src/VBox/Installer/darwin/VBoxKEXTs/PkgBuildComponent.plist b/src/VBox/Installer/darwin/VBoxKEXTs/PkgBuildComponent.plist
new file mode 100644
index 00000000..c7569703
--- /dev/null
+++ b/src/VBox/Installer/darwin/VBoxKEXTs/PkgBuildComponent.plist
@@ -0,0 +1,29 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
+<plist version="1.0">
+<array>
+ <dict>
+ <key>RootRelativeBundlePath</key> <string>VBoxDrv.kext</string>
+ <key>BundleIsRelocatable</key> <false/>
+ <key>BundleIsVersionChecked</key> <false/>
+ <key>BundleHasStrictIdentifier</key> <false/>
+ <key>BundleOverwriteAction</key> <string>upgrade</string>
+ </dict>
+ <dict>
+ <key>RootRelativeBundlePath</key> <string>VBoxNetAdp.kext</string>
+ <key>BundleIsRelocatable</key> <false/>
+ <key>BundleIsVersionChecked</key> <false/>
+ <key>BundleHasStrictIdentifier</key> <false/>
+ <key>BundleOverwriteAction</key> <string>upgrade</string>
+ </dict>
+ <dict>
+ <key>RootRelativeBundlePath</key> <string>VBoxNetFlt.kext</string>
+ <key>BundleIsRelocatable</key> <false/>
+ <key>BundleIsVersionChecked</key> <false/>
+ <key>BundleHasStrictIdentifier</key> <false/>
+ <key>BundleOverwriteAction</key> <string>upgrade</string>
+ <key>BundlePostInstallScriptPath</key> <string>postflight</string>
+ </dict>
+</array>
+</plist>
+
diff --git a/src/VBox/Installer/darwin/VBoxKEXTs/VirtualBoxStartup.sh b/src/VBox/Installer/darwin/VBoxKEXTs/VirtualBoxStartup.sh
new file mode 100755
index 00000000..8700db33
--- /dev/null
+++ b/src/VBox/Installer/darwin/VBoxKEXTs/VirtualBoxStartup.sh
@@ -0,0 +1,277 @@
+#!/bin/sh
+# $Id: VirtualBoxStartup.sh $
+## @file
+# Startup service for loading the kernel extensions and select the set of VBox
+# binaries that matches the kernel architecture.
+#
+
+#
+# Copyright (C) 2007-2023 Oracle and/or its affiliates.
+#
+# This file is part of VirtualBox base platform packages, as
+# available from https://www.virtualbox.org.
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License
+# as published by the Free Software Foundation, in version 3 of the
+# License.
+#
+# This program is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+# General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, see <https://www.gnu.org/licenses>.
+#
+# SPDX-License-Identifier: GPL-3.0-only
+#
+
+if false; then
+ . /etc/rc.common
+else
+ # Fake the startup item functions we're using.
+
+ ConsoleMessage()
+ {
+ if [ "$1" != "-f" ]; then
+ echo "$@"
+ else
+ shift
+ echo "Fatal error: $@"
+ exit 1;
+ fi
+ }
+
+ RunService()
+ {
+ case "$1" in
+ "start")
+ StartService
+ exit $?;
+ ;;
+ "stop")
+ StopService
+ exit $?;
+ ;;
+ "restart")
+ RestartService
+ exit $?;
+ ;;
+ "launchd")
+ if RestartService; then
+ while true;
+ do
+ sleep 3600
+ done
+ fi
+ exit $?;
+ ;;
+ **)
+ echo "Error: Unknown action '$1'"
+ exit 1;
+ esac
+ }
+fi
+
+
+StartService()
+{
+ VBOX_RC=0
+ VBOXDRV="VBoxDrv"
+ MACOS_VERSION_MAJOR=$(sw_vers -productVersion | /usr/bin/sed -e 's/^\([0-9]*\).*$/\1/')
+
+ #
+ # Check that all the directories exist first.
+ #
+ if [ ! -d "/Library/Application Support/VirtualBox/${VBOXDRV}.kext" ]; then
+ ConsoleMessage "Error: /Library/Application Support/VirtualBox/${VBOXDRV}.kext is missing"
+ VBOX_RC=1
+ fi
+ if [ ! -d "/Library/Application Support/VirtualBox/VBoxNetFlt.kext" ]; then
+ ConsoleMessage "Error: /Library/Application Support/VirtualBox/VBoxNetFlt.kext is missing"
+ VBOX_RC=1
+ fi
+ if [ ! -d "/Library/Application Support/VirtualBox/VBoxNetAdp.kext" ]; then
+ ConsoleMessage "Error: /Library/Application Support/VirtualBox/VBoxNetAdp.kext is missing"
+ VBOX_RC=1
+ fi
+
+ #
+ # Check that no drivers are currently running.
+ # (Try stop the service if this is the case.)
+ #
+ if [ $VBOX_RC -eq 0 ]; then
+ if [[ ${MACOS_VERSION_MAJOR} -lt 11 ]]; then
+ if kextstat -lb org.virtualbox.kext.VBoxDrv 2>&1 | grep -q org.virtualbox.kext.VBoxDrv; then
+ ConsoleMessage "Error: ${VBOXDRV}.kext is already loaded"
+ VBOX_RC=1
+ fi
+ if kextstat -lb org.virtualbox.kext.VBoxNetFlt 2>&1 | grep -q org.virtualbox.kext.VBoxNetFlt; then
+ ConsoleMessage "Error: VBoxNetFlt.kext is already loaded"
+ VBOX_RC=1
+ fi
+ if kextstat -lb org.virtualbox.kext.VBoxNetAdp 2>&1 | grep -q org.virtualbox.kext.VBoxNetAdp; then
+ ConsoleMessage "Error: VBoxNetAdp.kext is already loaded"
+ VBOX_RC=1
+ fi
+ else
+ #
+ # Use kmutil directly on BigSur or grep will erroneously trigger because kextstat dumps the kmutil
+ # invocation to stdout...
+ #
+ if kmutil showloaded --list-only -b org.virtualbox.kext.VBoxDrv 2>&1 | grep -q org.virtualbox.kext.VBoxDrv; then
+ ConsoleMessage "Error: ${VBOXDRV}.kext is already loaded"
+ VBOX_RC=1
+ fi
+ if kmutil showloaded --list-only -b org.virtualbox.kext.VBoxNetFlt 2>&1 | grep -q org.virtualbox.kext.VBoxNetFlt; then
+ ConsoleMessage "Error: VBoxNetFlt.kext is already loaded"
+ VBOX_RC=1
+ fi
+ if kmutil showloaded --list-only -b org.virtualbox.kext.VBoxNetAdp 2>&1 | grep -q org.virtualbox.kext.VBoxNetAdp; then
+ ConsoleMessage "Error: VBoxNetAdp.kext is already loaded"
+ VBOX_RC=1
+ fi
+ fi
+ fi
+
+ #
+ # Load the drivers.
+ #
+ if [ $VBOX_RC -eq 0 ]; then
+ if [[ ${MACOS_VERSION_MAJOR} -lt 11 ]]; then
+ ConsoleMessage "Loading ${VBOXDRV}.kext"
+ if ! kextload "/Library/Application Support/VirtualBox/${VBOXDRV}.kext"; then
+ ConsoleMessage "Error: Failed to load /Library/Application Support/VirtualBox/${VBOXDRV}.kext"
+ VBOX_RC=1
+ fi
+
+ ConsoleMessage "Loading VBoxNetFlt.kext"
+ if ! kextload -d "/Library/Application Support/VirtualBox/${VBOXDRV}.kext" "/Library/Application Support/VirtualBox/VBoxNetFlt.kext"; then
+ ConsoleMessage "Error: Failed to load /Library/Application Support/VirtualBox/VBoxNetFlt.kext"
+ VBOX_RC=1
+ fi
+
+ ConsoleMessage "Loading VBoxNetAdp.kext"
+ if ! kextload -d "/Library/Application Support/VirtualBox/${VBOXDRV}.kext" "/Library/Application Support/VirtualBox/VBoxNetAdp.kext"; then
+ ConsoleMessage "Error: Failed to load /Library/Application Support/VirtualBox/VBoxNetAdp.kext"
+ VBOX_RC=1
+ fi
+ else
+ #
+ # On BigSur we can only load by bundle ID because the drivers are baked into a kext collection image
+ # and the real path is never loaded actually.
+ #
+ ConsoleMessage "Loading ${VBOXDRV}.kext"
+ if ! kmutil load -b org.virtualbox.kext.VBoxDrv; then
+ ConsoleMessage "Error: Failed to load org.virtualbox.kext.VBoxDrv"
+ VBOX_RC=1
+ fi
+
+ ConsoleMessage "Loading VBoxNetFlt.kext"
+ if ! kmutil load -b org.virtualbox.kext.VBoxNetFlt; then
+ ConsoleMessage "Error: Failed to load org.virtualbox.kext.VBoxNetFlt"
+ VBOX_RC=1
+ fi
+
+ ConsoleMessage "Loading VBoxNetAdp.kext"
+ if ! kmutil load -b org.virtualbox.kext.VBoxNetAdp; then
+ ConsoleMessage "Error: Failed to load org.virtualbox.kext.VBoxNetAdp"
+ VBOX_RC=1
+ fi
+ fi
+
+ if [ $VBOX_RC -ne 0 ]; then
+ # unload the drivers (ignoring failures)
+ kextunload -b org.virtualbox.kext.VBoxNetAdp
+ kextunload -b org.virtualbox.kext.VBoxNetFlt
+ kextunload -b org.virtualbox.kext.VBoxDrv
+ fi
+ fi
+
+ #
+ # Set the error on failure.
+ #
+ if [ "$VBOX_RC" -ne "0" ]; then
+ ConsoleMessage -f VirtualBox
+ exit $VBOX_RC
+ fi
+}
+
+
+StopService()
+{
+ VBOX_RC=0
+ VBOXDRV="VBoxDrv"
+ VBOXUSB="VBoxUSB"
+ MACOS_VERSION_MAJOR=$(sw_vers -productVersion | /usr/bin/sed -e 's/^\([0-9]*\).*$/\1/')
+
+ if [[ ${MACOS_VERSION_MAJOR} -lt 11 ]]; then
+ if kextstat -lb org.virtualbox.kext.VBoxNetFlt 2>&1 | grep -q org.virtualbox.kext.VBoxNetFlt; then
+ ConsoleMessage "Unloading VBoxNetFlt.kext"
+ if ! kextunload -m org.virtualbox.kext.VBoxNetFlt; then
+ ConsoleMessage "Error: Failed to unload VBoxNetFlt.kext"
+ VBOX_RC=1
+ fi
+ fi
+
+ if kextstat -lb org.virtualbox.kext.VBoxNetAdp 2>&1 | grep -q org.virtualbox.kext.VBoxNetAdp; then
+ ConsoleMessage "Unloading VBoxNetAdp.kext"
+ if ! kextunload -m org.virtualbox.kext.VBoxNetAdp; then
+ ConsoleMessage "Error: Failed to unload VBoxNetAdp.kext"
+ VBOX_RC=1
+ fi
+ fi
+
+ # This must come last because of dependencies.
+ if kextstat -lb org.virtualbox.kext.VBoxDrv 2>&1 | grep -q org.virtualbox.kext.VBoxDrv; then
+ ConsoleMessage "Unloading ${VBOXDRV}.kext"
+ if ! kextunload -m org.virtualbox.kext.VBoxDrv; then
+ ConsoleMessage "Error: Failed to unload VBoxDrv.kext"
+ VBOX_RC=1
+ fi
+ fi
+ else
+ if kmutil showloaded --list-only -b org.virtualbox.kext.VBoxNetFlt 2>&1 | grep -q org.virtualbox.kext.VBoxNetFlt; then
+ ConsoleMessage "Unloading VBoxNetFlt.kext"
+ if ! kmutil unload -b org.virtualbox.kext.VBoxNetFlt; then
+ ConsoleMessage "Error: Failed to unload VBoxNetFlt.kext"
+ VBOX_RC=1
+ fi
+ fi
+
+ if kmutil showloaded --list-only -b org.virtualbox.kext.VBoxNetAdp 2>&1 | grep -q org.virtualbox.kext.VBoxNetAdp; then
+ ConsoleMessage "Unloading VBoxNetAdp.kext"
+ if ! kmutil unload -b org.virtualbox.kext.VBoxNetAdp; then
+ ConsoleMessage "Error: Failed to unload VBoxNetAdp.kext"
+ VBOX_RC=1
+ fi
+ fi
+
+ # This must come last because of dependencies.
+ if kmutil showloaded --list-only -b org.virtualbox.kext.VBoxDrv 2>&1 | grep -q org.virtualbox.kext.VBoxDrv; then
+ ConsoleMessage "Unloading ${VBOXDRV}.kext"
+ if ! kmutil unload -b org.virtualbox.kext.VBoxDrv; then
+ ConsoleMessage "Error: Failed to unload VBoxDrv.kext"
+ VBOX_RC=1
+ fi
+ fi
+ fi
+
+ # Set the error on failure.
+ if [ "$VBOX_RC" -ne "0" ]; then
+ ConsoleMessage -f VirtualBox
+ exit $VBOX_RC
+ fi
+}
+
+
+RestartService()
+{
+ StopService
+ StartService
+}
+
+
+RunService "$1"
+
diff --git a/src/VBox/Installer/darwin/VBoxKEXTs/org.virtualbox.startup.plist b/src/VBox/Installer/darwin/VBoxKEXTs/org.virtualbox.startup.plist
new file mode 100644
index 00000000..490c9ba6
--- /dev/null
+++ b/src/VBox/Installer/darwin/VBoxKEXTs/org.virtualbox.startup.plist
@@ -0,0 +1,17 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
+<plist version="1.0">
+<dict>
+ <key>Label</key> <string>org.virtualbox.startup</string>
+ <key>Disabled</key> <false/>
+ <key>RunAtLoad</key> <true/>
+ <key>KeepAlive</key> <false/>
+ <key>LaunchOnlyOnce</key> <true/>
+ <key>ProgramArguments</key>
+ <array>
+ <string>/Library/Application Support/VirtualBox/LaunchDaemons/VirtualBoxStartup.sh</string>
+ <string>restart</string>
+ </array>
+</dict>
+</plist>
+
diff --git a/src/VBox/Installer/darwin/VBoxKEXTs/postflight b/src/VBox/Installer/darwin/VBoxKEXTs/postflight
new file mode 100755
index 00000000..4f00d2ef
--- /dev/null
+++ b/src/VBox/Installer/darwin/VBoxKEXTs/postflight
@@ -0,0 +1,117 @@
+#!/bin/sh
+# $Id$
+## @file
+# Reloads the new kernel extension at the end of installation.
+#
+
+#
+# Copyright (C) 2007-2023 Oracle and/or its affiliates.
+#
+# This file is part of VirtualBox base platform packages, as
+# available from https://www.virtualbox.org.
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License
+# as published by the Free Software Foundation, in version 3 of the
+# License.
+#
+# This program is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+# General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, see <https://www.gnu.org/licenses>.
+#
+# SPDX-License-Identifier: GPL-3.0-only
+#
+
+#
+# Make sure the old startup items are gone.
+#
+if [ -d /Library/StartupItems/VirtualBox/ ]; then
+ rm -vf "/Library/StartupItems/VirtualBox/StartupParameters.plist"
+ rm -vf "/Library/StartupItems/VirtualBox/VirtualBox"
+ rm -vf "/Library/StartupItems/VirtualBox/Resources/English.lproj/Localizable.strings"
+ test -d "/Library/StartupItems/VirtualBox/Resources/English.lproj/" && rmdir "/Library/StartupItems/VirtualBox/Resources/English.lproj/"
+ test -d "/Library/StartupItems/VirtualBox/Resources/" && rmdir "/Library/StartupItems/VirtualBox/Resources/"
+ test -d "/Library/StartupItems/VirtualBox/" && rmdir "/Library/StartupItems/VirtualBox/"
+fi
+
+#
+# Make sure old kernel extensions are gone (moved to "/Library/Application Support/VirtualBox/" with 4.3).
+#
+rm -Rfv \
+ "/Library/Extensions/VBoxDrv.kext/" \
+ "/Library/Extensions/VBoxNetFlt.kext/" \
+ "/Library/Extensions/VBoxNetAdp.kext/" \
+ "/Library/Extensions/VBoxUSB.kext/" \
+ "/Library/Extensions/VBoxDrvTiger.kext/" \
+ "/Library/Extensions/VBoxUSBTiger.kext/"
+
+#
+# Install the launchd script.
+#
+# Make sure "/Library/LaunchDaemons/ exists first as some uninstallers/users
+# may be silly enough to remove it. We assume that /Library exists and will
+# not try create it because it normally has extra ACLs.
+#
+if [ ! -e "/Library/LaunchDaemons/" ]; then
+ set -e
+ mkdir "/Library/LaunchDaemons"
+ chmod 755 "/Library/LaunchDaemons"
+ chown root:wheel "/Library/LaunchDaemons"
+ set +e
+fi
+rm -vf "/Library/LaunchDaemons/org.virtualbox.startup.plist"
+set -e
+ln -s "../Application Support/VirtualBox/LaunchDaemons/org.virtualbox.startup.plist" \
+ "/Library/LaunchDaemons/org.virtualbox.startup.plist"
+set +e
+
+#
+# Unload any old extension that might be loaded already (ignore failures).
+#
+sync
+if kextstat -lb org.virtualbox.kext.VBoxNetAdp 2>&1 | grep -q org.virtualbox.kext.VBoxNetAdp; then
+ kextunload -m org.virtualbox.kext.VBoxNetAdp
+fi
+if kextstat -lb org.virtualbox.kext.VBoxNetFlt 2>&1 | grep -q org.virtualbox.kext.VBoxNetFlt; then
+ kextunload -m org.virtualbox.kext.VBoxNetFlt
+fi
+if kextstat -lb org.virtualbox.kext.VBoxUSB 2>&1 | grep -q org.virtualbox.kext.VBoxUSB; then
+ kextunload -m org.virtualbox.kext.VBoxUSB
+fi
+if kextstat -lb org.virtualbox.kext.VBoxDrv 2>&1 | grep -q org.virtualbox.kext.VBoxDrv; then
+ kextunload -m org.virtualbox.kext.VBoxDrv
+fi
+
+#
+# Load the extension, exit on first error except on BigSur onwards as an error
+# is expected there and the user has to reboot.
+#
+MACOS_VERSION_MAJOR=$(sw_vers -productVersion | /usr/bin/sed -e 's/^\([0-9]*\).*$/\1/')
+sync
+if [[ ${MACOS_VERSION_MAJOR} -lt 11 ]]; then
+ set -e
+ kextload '/Library/Application Support/VirtualBox/VBoxDrv.kext'
+ kextload -d '/Library/Application Support/VirtualBox/VBoxDrv.kext' '/Library/Application Support/VirtualBox/VBoxNetFlt.kext'
+ kextload -d '/Library/Application Support/VirtualBox/VBoxDrv.kext' '/Library/Application Support/VirtualBox/VBoxNetAdp.kext'
+else
+ VBOX_RC=0
+ if ! kmutil load -p '/Library/Application Support/VirtualBox/VBoxDrv.kext'; then
+ VBOX_RC=1
+ fi
+
+ if ! kmutil load -p '/Library/Application Support/VirtualBox/VBoxNetFlt.kext'; then
+ VBOX_RC=1
+ fi
+
+ if ! kmutil load -p '/Library/Application Support/VirtualBox/VBoxNetAdp.kext'; then
+ VBOX_RC=1
+ fi
+
+ if [ $VBOX_RC -ne 1 ]; then
+ osascript -e 'display dialog "A reboot is required on macOS BigSur and onwards in order to be able to load the installed kernel extensions" buttons { "Ok" } with icon caution'
+ fi
+fi