packages: VirtualBox/VirtualBox-vboxguest.init (NEW) - new; cp-ed from Virt...

adamg adamg at pld-linux.org
Tue Dec 1 08:47:42 CET 2009


Author: adamg                        Date: Tue Dec  1 07:47:42 2009 GMT
Module: packages                      Tag: HEAD
---- Log message:
- new; cp-ed from VirtualBox-vboxadd.init

---- Files affected:
packages/VirtualBox:
   VirtualBox-vboxguest.init (NONE -> 1.1)  (NEW)

---- Diffs:

================================================================
Index: packages/VirtualBox/VirtualBox-vboxguest.init
diff -u /dev/null packages/VirtualBox/VirtualBox-vboxguest.init:1.1
--- /dev/null	Tue Dec  1 08:47:42 2009
+++ packages/VirtualBox/VirtualBox-vboxguest.init	Tue Dec  1 08:47:37 2009
@@ -0,0 +1,92 @@
+#!/bin/sh
+#
+# virtualbox	VirtualBox virtualizer for x86 hardware
+#
+# chkconfig:	345 83 26
+#
+# description:	InnoTek 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"
+
+# Get service config - may override defaults
+[ -f /etc/sysconfig/virtualbox ] && . /etc/sysconfig/virtualbox
+
+start() {
+	if [ ! -f /var/lock/subsys/vboxguest ]; then
+		modprobe -s $VBOX_MODULE
+		# set proper /dev/vboxdrv for systems with static dev
+		if ! [ -d /dev/.udev/ ]; then
+			show "Setting $VBOX_DEVICE entry"
+			busy
+			rm -f $VBOX_DEVICE
+			VBOX_MAJOR=$(awk '$2 == "vboxdrv" {print $1}' /proc/devices)
+			if [ -n "$VBOX_MAJOR" ]; then
+				VBOX_MINOR=0
+			else
+				VBOX_MINOR=$(awk '$2 == "vboxdrv" {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
+			elif ! mknod -m 0660 $VBOX_DEVICE c $VBOX_MAJOR $VBOX_MINOR; then
+				rmmod $VBOX_MODNAME
+				fail
+			elif ! chown root:vbox $VBOX_DEVICE; then
+				fail
+			else
+				ok
+			fi
+		fi
+		touch /var/lock/subsys/vboxguest
+	fi
+}
+
+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
+}
+
+RETVAL=0
+# See how we were called.
+case "$1" in
+  start)
+  	start
+	;;
+  stop)
+  	stop
+	;;
+  restart)
+	stop
+	start
+	;;
+  status)
+	if ! is_module $VBOX_MODULE; then
+		echo "$VBOX_MODULE module is loaded"
+	else
+		echo "$VBOX_MODULE module is not loaded"
+		RETVAL=3
+	fi
+	if [ ! -c $VBOX_DEVICE ]; then
+		echo "$VBOX_DEVICE does not exist"
+		RETVAL=3
+	else
+		echo "$VBOX_DEVICE exists with major/minor $(ls -l $VBOX_DEVICE | awk '{print $5 $6}')"
+	fi
+	;;
+  *)
+	msg_usage "$0 {start|stop|restart|status}"
+	exit 3
+esac
+
+exit $RETVAL
================================================================


More information about the pld-cvs-commit mailing list