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 |
|
---|
29 | PATH=/sbin:/bin:/usr/sbin:/usr/bin:$PATH
|
---|
30 | DEVICE=/dev/vboxdrv
|
---|
31 | LOG="/var/log/vbox-install.log"
|
---|
32 | MODPROBE=/sbin/modprobe
|
---|
33 |
|
---|
34 | if $MODPROBE -c | grep -q '^allow_unsupported_modules *0'; then
|
---|
35 | MODPROBE="$MODPROBE --allow-unsupported-modules"
|
---|
36 | fi
|
---|
37 |
|
---|
38 | [ -f /etc/debian_release -a -f /lib/lsb/init-functions ] || NOLSB=yes
|
---|
39 | if [ ! -f /etc/vbox/vbox.cfg ]; then
|
---|
40 | echo "/etc/vbox/vbox.cfg not found" # Fiddle this and do it nicely.
|
---|
41 | exit 1
|
---|
42 | fi
|
---|
43 | . /etc/vbox/vbox.cfg
|
---|
44 | export BUILD_TYPE
|
---|
45 | export USERNAME
|
---|
46 | export USER=$USERNAME
|
---|
47 |
|
---|
48 | if [ -n "$INSTALL_DIR" ]; then
|
---|
49 | VBOXMANAGE="$INSTALL_DIR/VBoxManage"
|
---|
50 | MODULE_SRC="$INSTALL_DIR/src/vboxhost"
|
---|
51 | else
|
---|
52 | VBOXMANAGE="/usr/lib/virtualbox/VBoxManage"
|
---|
53 | MODULE_SRC="/usr/share/virtualbox/src/vboxhost"
|
---|
54 | fi
|
---|
55 | BUILDINTMP="$MODULE_SRC/build_in_tmp"
|
---|
56 | DODKMS="$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 |
|
---|
62 | if [ -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
|
---|
70 | fi
|
---|
71 |
|
---|
72 | [ -r /etc/default/virtualbox ] && . /etc/default/virtualbox
|
---|
73 |
|
---|
74 | if [ -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 | }
|
---|
86 | else
|
---|
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
|
---|
148 | fi
|
---|
149 |
|
---|
150 | failure()
|
---|
151 | {
|
---|
152 | fail_msg "$1"
|
---|
153 | exit 0
|
---|
154 | }
|
---|
155 |
|
---|
156 | running()
|
---|
157 | {
|
---|
158 | lsmod | grep -q "$1[^_-]"
|
---|
159 | }
|
---|
160 |
|
---|
161 | start()
|
---|
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 |
|
---|
222 | stop()
|
---|
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
|
---|
258 | stop_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
|
---|
299 | setup()
|
---|
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 |
|
---|
367 | dmnstatus()
|
---|
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 |
|
---|
399 | case "$1" in
|
---|
400 | start)
|
---|
401 | start
|
---|
402 | ;;
|
---|
403 | stop)
|
---|
404 | stop_vms
|
---|
405 | stop
|
---|
406 | ;;
|
---|
407 | stop_vms)
|
---|
408 | stop_vms
|
---|
409 | ;;
|
---|
410 | restart)
|
---|
411 | stop && start
|
---|
412 | ;;
|
---|
413 | force-reload)
|
---|
414 | stop
|
---|
415 | start
|
---|
416 | ;;
|
---|
417 | setup)
|
---|
418 | setup
|
---|
419 | ;;
|
---|
420 | status)
|
---|
421 | dmnstatus
|
---|
422 | ;;
|
---|
423 | *)
|
---|
424 | echo "Usage: $0 {start|stop|stop_vms|restart|force-reload|status|setup}"
|
---|
425 | exit 1
|
---|
426 | esac
|
---|
427 |
|
---|
428 | exit 0
|
---|