VirtualBox

source: vbox/trunk/src/VBox/Installer/linux/vboxdrv.sh.in@ 48954

Last change on this file since 48954 was 44772, checked in by vboxsync, 12 years ago

Installer/linux: fix still outstanding from r80829.

  • Property svn:eol-style set to LF
  • Property svn:keywords set to Author Date Id Revision
File size: 12.4 KB
Line 
1#! /bin/sh
2# Oracle VM VirtualBox
3# Linux kernel module init script
4
5#
6# Copyright (C) 2006-2013 Oracle Corporation
7#
8# This file is part of VirtualBox Open Source Edition (OSE), as
9# available from http://www.virtualbox.org. This file is free software;
10# you can redistribute it and/or modify it under the terms of the GNU
11# General Public License (GPL) as published by the Free Software
12# Foundation, in version 2 as it comes in the "COPYING" file of the
13# VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14# hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15#
16
17# chkconfig: 35 20 80
18# description: VirtualBox Linux kernel module
19#
20### BEGIN INIT INFO
21# Provides: vboxdrv
22# Required-Start: $syslog
23# Required-Stop:
24# Default-Start: 2 3 4 5
25# Default-Stop: 0 1 6
26# Short-Description: VirtualBox Linux kernel module
27### END INIT INFO
28
29PATH=/sbin:/bin:/usr/sbin:/usr/bin:$PATH
30DEVICE=/dev/vboxdrv
31LOG="/var/log/vbox-install.log"
32VERSION=%VERSION%
33MODPROBE=/sbin/modprobe
34
35if $MODPROBE -c | grep -q '^allow_unsupported_modules *0'; then
36 MODPROBE="$MODPROBE --allow-unsupported-modules"
37fi
38
39[ -f /etc/debian_release -a -f /lib/lsb/init-functions ] || NOLSB=yes
40[ -f /etc/vbox/vbox.cfg ] && . /etc/vbox/vbox.cfg
41export BUILD_TYPE
42export USERNAME
43export USER=$USERNAME
44
45if [ -n "$INSTALL_DIR" ]; then
46 VBOXMANAGE="$INSTALL_DIR/VBoxManage"
47 MODULE_SRC="$INSTALL_DIR/src/vboxhost"
48else
49 VBOXMANAGE="/usr/lib/virtualbox/VBoxManage"
50 MODULE_SRC="/usr/share/virtualbox/src/vboxhost"
51fi
52BUILDINTMP="$MODULE_SRC/build_in_tmp"
53DODKMS="$MODULE_SRC/do_dkms"
54
55# silently exit if the package was uninstalled but not purged,
56# applies to Debian packages only (but shouldn't hurt elsewhere)
57[ ! -f /etc/debian_release -o -x $VBOXMANAGE -a -x $BUILDINTMP ] || exit 0
58
59if [ -n "$NOLSB" ]; then
60 if [ -f /etc/redhat-release ]; then
61 system=redhat
62 elif [ -f /etc/SuSE-release ]; then
63 system=suse
64 elif [ -f /etc/gentoo-release ]; then
65 system=gentoo
66 fi
67fi
68
69[ -r /etc/default/virtualbox ] && . /etc/default/virtualbox
70
71if [ -z "$NOLSB" ]; then
72 . /lib/lsb/init-functions
73 fail_msg() {
74 echo ""
75 log_failure_msg "$1"
76 }
77 succ_msg() {
78 log_end_msg 0
79 }
80 begin_msg() {
81 log_daemon_msg "$@"
82 }
83else
84 if [ "$system" = "redhat" ]; then
85 . /etc/init.d/functions
86 fail_msg() {
87 echo -n " "
88 echo_failure
89 echo
90 echo " ($1)"
91 }
92 succ_msg() {
93 echo -n " "
94 echo_success
95 echo
96 }
97 elif [ "$system" = "suse" ]; then
98 . /etc/rc.status
99 fail_msg() {
100 rc_failed 1
101 rc_status -v
102 echo " ($1)"
103 }
104 succ_msg() {
105 rc_reset
106 rc_status -v
107 }
108 elif [ "$system" = "gentoo" ]; then
109 if [ -f /sbin/functions.sh ]; then
110 . /sbin/functions.sh
111 elif [ -f /etc/init.d/functions.sh ]; then
112 . /etc/init.d/functions.sh
113 fi
114 fail_msg() {
115 eerror "$1"
116 }
117 succ_msg() {
118 eend "$?"
119 }
120 begin_msg() {
121 ebegin "$1"
122 }
123 if [ "`which $0`" = "/sbin/rc" ]; then
124 shift
125 fi
126 else
127 fail_msg() {
128 echo " ...failed!"
129 echo " ($1)"
130 }
131 succ_msg() {
132 echo " ...done."
133 }
134 fi
135 if [ "$system" != "gentoo" ]; then
136 begin_msg() {
137 [ -z "${1:-}" ] && return 1
138 if [ -z "${2:-}" ]; then
139 echo -n "$1"
140 else
141 echo -n "$1: $2"
142 fi
143 }
144 fi
145fi
146
147failure()
148{
149 fail_msg "$1"
150 exit 0
151}
152
153running()
154{
155 lsmod | grep -q "$1[^_-]"
156}
157
158start()
159{
160 begin_msg "Starting VirtualBox kernel modules"
161 if [ -d /proc/xen ]; then
162 failure "Running VirtualBox in a Xen environment is not supported"
163 fi
164 if ! running vboxdrv; then
165 if ! rm -f $DEVICE; then
166 failure "Cannot remove $DEVICE"
167 fi
168 if ! $MODPROBE vboxdrv > /dev/null 2>&1; then
169 failure "modprobe vboxdrv failed. Please use 'dmesg' to find out why"
170 fi
171 sleep .2
172 fi
173 # ensure the character special exists
174 if [ ! -c $DEVICE ]; then
175 MAJOR=`sed -n 's;\([0-9]\+\) vboxdrv;\1;p' /proc/devices`
176 if [ ! -z "$MAJOR" ]; then
177 MINOR=0
178 else
179 MINOR=`sed -n 's;\([0-9]\+\) vboxdrv;\1;p' /proc/misc`
180 if [ ! -z "$MINOR" ]; then
181 MAJOR=10
182 fi
183 fi
184 if [ -z "$MAJOR" ]; then
185 rmmod vboxdrv 2>/dev/null
186 failure "Cannot locate the VirtualBox device"
187 fi
188 if ! mknod -m 0660 $DEVICE c $MAJOR $MINOR 2>/dev/null; then
189 rmmod vboxdrv 2>/dev/null
190 failure "Cannot create device $DEVICE with major $MAJOR and minor $MINOR"
191 fi
192 fi
193 # ensure permissions
194 if ! chown :%GROUP% $DEVICE 2>/dev/null; then
195 rmmod vboxpci 2>/dev/null
196 rmmod vboxnetadp 2>/dev/null
197 rmmod vboxnetflt 2>/dev/null
198 rmmod vboxdrv 2>/dev/null
199 failure "Cannot change group %GROUP% for device $DEVICE"
200 fi
201 if ! $MODPROBE vboxnetflt > /dev/null 2>&1; then
202 failure "modprobe vboxnetflt failed. Please use 'dmesg' to find out why"
203 fi
204 if ! $MODPROBE vboxnetadp > /dev/null 2>&1; then
205 failure "modprobe vboxnetadp failed. Please use 'dmesg' to find out why"
206 fi
207 if ! $MODPROBE vboxpci > /dev/null 2>&1; then
208 failure "modprobe vboxpci failed. Please use 'dmesg' to find out why"
209 fi
210 # Create the /dev/vboxusb directory if the host supports that method
211 # of USB access. The USB code checks for the existance of that path.
212 if grep -q usb_device /proc/devices; then
213 mkdir -p -m 0750 /dev/vboxusb 2>/dev/null
214 chown root:vboxusers /dev/vboxusb 2>/dev/null
215 fi
216 succ_msg
217}
218
219stop()
220{
221 begin_msg "Stopping VirtualBox kernel modules"
222 if running vboxpci; then
223 if ! rmmod vboxpci 2>/dev/null; then
224 failure "Cannot unload module vboxpci"
225 fi
226 fi
227 if running vboxnetadp; then
228 if ! rmmod vboxnetadp 2>/dev/null; then
229 failure "Cannot unload module vboxnetadp"
230 fi
231 fi
232 if running vboxdrv; then
233 if running vboxnetflt; then
234 if ! rmmod vboxnetflt 2>/dev/null; then
235 failure "Cannot unload module vboxnetflt"
236 fi
237 fi
238 if ! rmmod vboxdrv 2>/dev/null; then
239 failure "Cannot unload module vboxdrv"
240 fi
241 if ! rm -f $DEVICE; then
242 failure "Cannot unlink $DEVICE"
243 fi
244 fi
245 succ_msg
246}
247
248# enter the following variables in /etc/default/virtualbox:
249# SHUTDOWN_USERS="foo bar"
250# check for running VMs of user foo and user bar
251# SHUTDOWN=poweroff
252# SHUTDOWN=acpibutton
253# SHUTDOWN=savestate
254# select one of these shutdown methods for running VMs
255stop_vms()
256{
257 wait=0
258 for i in $SHUTDOWN_USERS; do
259 # don't create the ipcd directory with wrong permissions!
260 if [ -d /tmp/.vbox-$i-ipc ]; then
261 export VBOX_IPC_SOCKETID="$i"
262 VMS=`$VBOXMANAGE --nologo list runningvms | sed -e 's/^".*".*{\(.*\)}/\1/' 2>/dev/null`
263 if [ -n "$VMS" ]; then
264 if [ "$SHUTDOWN" = "poweroff" ]; then
265 begin_msg "Powering off remaining VMs"
266 for v in $VMS; do
267 $VBOXMANAGE --nologo controlvm $v poweroff
268 done
269 succ_msg
270 elif [ "$SHUTDOWN" = "acpibutton" ]; then
271 begin_msg "Sending ACPI power button event to remaining VMs"
272 for v in $VMS; do
273 $VBOXMANAGE --nologo controlvm $v acpipowerbutton
274 wait=30
275 done
276 succ_msg
277 elif [ "$SHUTDOWN" = "savestate" ]; then
278 begin_msg "Saving state of remaining VMs"
279 for v in $VMS; do
280 $VBOXMANAGE --nologo controlvm $v savestate
281 done
282 succ_msg
283 fi
284 fi
285 fi
286 done
287 # wait for some seconds when doing ACPI shutdown
288 if [ "$wait" -ne 0 ]; then
289 begin_msg "Waiting for $wait seconds for VM shutdown"
290 sleep $wait
291 succ_msg
292 fi
293}
294
295# setup_script
296setup()
297{
298 stop
299 DKMS=`which dkms 2>/dev/null`
300 if [ -n "$DKMS" ]; then
301 begin_msg "Uninstalling old VirtualBox DKMS kernel modules"
302 $DODKMS uninstall vboxhost vboxdrv vboxnetflt vboxnetadp > $LOG
303 succ_msg
304 fi
305 if find /lib/modules/`uname -r` -name "vboxpci\.*" 2>/dev/null|grep -q vboxpci; then
306 begin_msg "Removing old VirtualBox pci kernel module"
307 find /lib/modules/`uname -r` -name "vboxpci\.*" 2>/dev/null|xargs rm -f 2>/dev/null
308 succ_msg
309 fi
310 if find /lib/modules/`uname -r` -name "vboxnetadp\.*" 2>/dev/null|grep -q vboxnetadp; then
311 begin_msg "Removing old VirtualBox netadp kernel module"
312 find /lib/modules/`uname -r` -name "vboxnetadp\.*" 2>/dev/null|xargs rm -f 2>/dev/null
313 succ_msg
314 fi
315 if find /lib/modules/`uname -r` -name "vboxnetflt\.*" 2>/dev/null|grep -q vboxnetflt; then
316 begin_msg "Removing old VirtualBox netflt kernel module"
317 find /lib/modules/`uname -r` -name "vboxnetflt\.*" 2>/dev/null|xargs rm -f 2>/dev/null
318 succ_msg
319 fi
320 if find /lib/modules/`uname -r` -name "vboxdrv\.*" 2>/dev/null|grep -q vboxdrv; then
321 begin_msg "Removing old VirtualBox kernel module"
322 find /lib/modules/`uname -r` -name "vboxdrv\.*" 2>/dev/null|xargs rm -f 2>/dev/null
323 succ_msg
324 fi
325 if [ -n "$DKMS" ]; then
326 begin_msg "Trying to register the VirtualBox kernel modules using DKMS"
327 if ! $DODKMS install vboxhost $VERSION >> $LOG; then
328 fail_msg "Failed, trying without DKMS"
329 DKMS=""
330 fi
331 fi
332 if [ -z "$DKMS" ]; then
333 begin_msg "Recompiling VirtualBox kernel modules"
334 if ! $BUILDINTMP \
335 --save-module-symvers /tmp/vboxdrv-Module.symvers \
336 --module-source "$MODULE_SRC/vboxdrv" \
337 --no-print-directory install >> $LOG 2>&1; then
338 failure "Look at $LOG to find out what went wrong"
339 fi
340 if ! $BUILDINTMP \
341 --use-module-symvers /tmp/vboxdrv-Module.symvers \
342 --module-source "$MODULE_SRC/vboxnetflt" \
343 --no-print-directory install >> $LOG 2>&1; then
344 failure "Look at $LOG to find out what went wrong"
345 fi
346 if ! $BUILDINTMP \
347 --use-module-symvers /tmp/vboxdrv-Module.symvers \
348 --module-source "$MODULE_SRC/vboxnetadp" \
349 --no-print-directory install >> $LOG 2>&1; then
350 failure "Look at $LOG to find out what went wrong"
351 fi
352 if ! $BUILDINTMP \
353 --use-module-symvers /tmp/vboxdrv-Module.symvers \
354 --module-source "$MODULE_SRC/vboxpci" \
355 --no-print-directory install >> $LOG 2>&1; then
356 failure "Look at $LOG to find out what went wrong"
357 fi
358 fi
359 rm -f /etc/vbox/module_not_compiled
360 succ_msg
361 start
362}
363
364dmnstatus()
365{
366 if running vboxdrv; then
367 str="vboxdrv"
368 if running vboxnetflt; then
369 str="$str, vboxnetflt"
370 if running vboxnetadp; then
371 str="$str, vboxnetadp"
372 fi
373 fi
374 if running vboxpci; then
375 str="$str, vboxpci"
376 fi
377 echo "VirtualBox kernel modules ($str) are loaded."
378 for i in $SHUTDOWN_USERS; do
379 # don't create the ipcd directory with wrong permissions!
380 if [ -d /tmp/.vbox-$i-ipc ]; then
381 export VBOX_IPC_SOCKETID="$i"
382 VMS=`$VBOXMANAGE --nologo list runningvms | sed -e 's/^".*".*{\(.*\)}/\1/' 2>/dev/null`
383 if [ -n "$VMS" ]; then
384 echo "The following VMs are currently running:"
385 for v in $VMS; do
386 echo " $v"
387 done
388 fi
389 fi
390 done
391 else
392 echo "VirtualBox kernel module is not loaded."
393 fi
394}
395
396case "$1" in
397start)
398 start
399 ;;
400stop)
401 stop_vms
402 stop
403 ;;
404stop_vms)
405 stop_vms
406 ;;
407restart)
408 stop && start
409 ;;
410force-reload)
411 stop
412 start
413 ;;
414setup)
415 setup
416 ;;
417status)
418 dmnstatus
419 ;;
420*)
421 echo "Usage: $0 {start|stop|stop_vms|restart|force-reload|status|setup}"
422 exit 1
423esac
424
425exit 0
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette