VirtualBox

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

Last change on this file since 43876 was 43729, checked in by vboxsync, 12 years ago

Installer/linux: do not try to remove DKMS modules either if DKMS is not installed as this will silently fail.

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