]> git.pld-linux.org Git - packages/VirtualBox.git/blobdiff - VirtualBox-vboxguest.init
- rebuild for kernel-3.9.6-1
[packages/VirtualBox.git] / VirtualBox-vboxguest.init
old mode 100644 (file)
new mode 100755 (executable)
index 7e36fe2..51de0df
@@ -1,67 +1,78 @@
 #!/bin/sh
 #
 # virtualbox   VirtualBox virtualizer for x86 hardware
-#
-# chkconfig:   345 83 26
-#
-# description: InnoTek VirtualBox is a general-purpose full virtualizer for x86 
+# chkconfig:   345 83 17
+# description: Oracle VirtualBox is a general-purpose full virtualizer for x86 \
 #              hardware. Targeted at server, desktop and embedded use.
-#
-# $Id$
 
 # Source function library
 . /etc/rc.d/init.d/functions
 
-VBOX_DEVICE="/dev/vboxguest"
 VBOX_MODULE="vboxguest"
+VBOX_GUEST_DEVICE="/dev/vboxguest"
+VBOX_USER_DEVICE="/dev/vboxuser"
 
 # Get service config - may override defaults
 [ -f /etc/sysconfig/virtualbox ] && . /etc/sysconfig/virtualbox
 
 setup() {
+       local VBOX_MODULE=$1 VBOX_DEVICE=$2
        modprobe -s $VBOX_MODULE
-       # set proper /dev/vboxdrv for systems with static dev
-       if [ -d /dev/.udev ]; then
-               return
+       RETVAL=$?
+
+       if [ -d /dev/.udev ] || [ -d /run/udev/rules.d ]; then
+               return $RETVAL
        fi
 
        # set proper $VBOX_DEVICE for systems with static dev
        show "Setting $VBOX_DEVICE entry"; busy
        rm -f $VBOX_DEVICE
-       VBOX_MAJOR=$(awk '$2 == "vboxdrv" {print $1}' /proc/devices)
+       VBOX_MAJOR=$(awk -vdevice="${VBOX_DEVICE#/dev/}" '$2 == device {print $1}' /proc/devices)
        if [ -n "$VBOX_MAJOR" ]; then
                VBOX_MINOR=0
        else
-               VBOX_MINOR=$(awk '$2 == "vboxdrv" {print $1}' /proc/misc)
+               VBOX_MINOR=$(awk -vdevice="${VBOX_DEVICE#/dev/}" '$2 == device {print $1}' /proc/misc)
                if [ -n "$VBOX_MINOR" ]; then
                        VBOX_MAJOR=$(awk '$2 == "misc" {print $1}' /proc/devices)
                fi
        fi
+
        if [ -z "$VBOX_MAJOR" ]; then
                /sbin/rmmod $VBOX_MODULE
-               fail
+               RETVAL=1
        elif ! mknod -m 0660 $VBOX_DEVICE c $VBOX_MAJOR $VBOX_MINOR; then
+               RETVAL=$?
                rmmod $VBOX_MODNAME
                fail
-       elif ! chown root:vbox $VBOX_DEVICE; then
-               fail
        else
                ok
        fi
+       return $RETVAL
 }
 
 start() {
-       if [ -f /var/lock/subsys/vboxguest ]; then
+       if [ -f /var/lock/subsys/$VBOX_MODULE ]; then
                return
        fi
-       setup
-       touch /var/lock/subsys/vboxguest
+
+       setup $VBOX_MODULE $VBOX_GUEST_DEVICE || exit $?
+       setup $VBOX_MODULE $VBOX_USER_DEVICE || exit $?
+       touch /var/lock/subsys/$VBOX_MODULE
 }
 
 stop() {
        # NOTE: rmmod will wait if device is in use, so automatic rmmod probably is not the best idea
        /sbin/rmmod $VBOX_MODULE
-       rm -f /var/lock/subsys/vboxguest
+       rm -f /var/lock/subsys/$VBOX_MODULE
+}
+
+condrestart() {
+       if [ -f /var/lock/subsys/$VBOX_MODULE ]; then
+               stop
+               start
+       else
+               RETVAL=$1
+       fi
 }
 
 RETVAL=0
@@ -77,6 +88,12 @@ case "$1" in
        stop
        start
        ;;
+  try-restart)
+       condrestart 0
+       ;;
+  force-reload)
+       condrestart 7
+       ;;
   setup)
        setup
        ;;
@@ -95,7 +112,7 @@ case "$1" in
        fi
        ;;
   *)
-       msg_usage "$0 {start|stop|restart|setup|status}"
+       msg_usage "$0 {start|stop|restart|try-restart|force-reload|setup|status}"
        exit 3
 esac
 
This page took 0.119798 seconds and 4 git commands to generate.