1 | #! /bin/sh
|
---|
2 | #
|
---|
3 | # Linux Additions kernel module init script ($Revision: 44528 $)
|
---|
4 | #
|
---|
5 |
|
---|
6 | #
|
---|
7 | # Copyright (C) 2006-2012 Oracle Corporation
|
---|
8 | #
|
---|
9 | # This file is part of VirtualBox Open Source Edition (OSE), as
|
---|
10 | # available from http://www.virtualbox.org. This file is free software;
|
---|
11 | # you can redistribute it and/or modify it under the terms of the GNU
|
---|
12 | # General Public License (GPL) as published by the Free Software
|
---|
13 | # Foundation, in version 2 as it comes in the "COPYING" file of the
|
---|
14 | # VirtualBox OSE distribution. VirtualBox OSE is distributed in the
|
---|
15 | # hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
|
---|
16 | #
|
---|
17 |
|
---|
18 |
|
---|
19 | # chkconfig: 357 30 70
|
---|
20 | # description: VirtualBox Linux Additions kernel modules
|
---|
21 | #
|
---|
22 | ### BEGIN INIT INFO
|
---|
23 | # Provides: vboxadd
|
---|
24 | # Required-Start:
|
---|
25 | # Required-Stop:
|
---|
26 | # Default-Start: 2 3 4 5
|
---|
27 | # Default-Stop: 0 1 6
|
---|
28 | # Description: VirtualBox Linux Additions kernel modules
|
---|
29 | ### END INIT INFO
|
---|
30 |
|
---|
31 | PATH=$PATH:/bin:/sbin:/usr/sbin
|
---|
32 | PACKAGE=VBoxGuestAdditions
|
---|
33 | LOG="/var/log/vboxadd-install.log"
|
---|
34 | MODPROBE=/sbin/modprobe
|
---|
35 | OLDMODULES="vboxguest vboxadd vboxsf vboxvfs vboxvideo"
|
---|
36 |
|
---|
37 | if $MODPROBE -c | grep -q '^allow_unsupported_modules *0'; then
|
---|
38 | MODPROBE="$MODPROBE --allow-unsupported-modules"
|
---|
39 | fi
|
---|
40 |
|
---|
41 | # Check architecture
|
---|
42 | cpu=`uname -m`;
|
---|
43 | case "$cpu" in
|
---|
44 | i[3456789]86|x86)
|
---|
45 | cpu="x86"
|
---|
46 | lib_path="/usr/lib"
|
---|
47 | ;;
|
---|
48 | x86_64|amd64)
|
---|
49 | cpu="amd64"
|
---|
50 | if test -d "/usr/lib64"; then
|
---|
51 | lib_path="/usr/lib64"
|
---|
52 | else
|
---|
53 | lib_path="/usr/lib"
|
---|
54 | fi
|
---|
55 | ;;
|
---|
56 | esac
|
---|
57 |
|
---|
58 | if [ -f /etc/arch-release ]; then
|
---|
59 | system=arch
|
---|
60 | elif [ -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 | elif [ -f /etc/lfs-release -a -d /etc/rc.d/init.d ]; then
|
---|
67 | system=lfs
|
---|
68 | else
|
---|
69 | system=other
|
---|
70 | fi
|
---|
71 |
|
---|
72 | if [ "$system" = "arch" ]; then
|
---|
73 | USECOLOR=yes
|
---|
74 | . /etc/rc.d/functions
|
---|
75 | fail_msg() {
|
---|
76 | stat_fail
|
---|
77 | }
|
---|
78 |
|
---|
79 | succ_msg() {
|
---|
80 | stat_done
|
---|
81 | }
|
---|
82 |
|
---|
83 | begin() {
|
---|
84 | stat_busy "$1"
|
---|
85 | }
|
---|
86 | fi
|
---|
87 |
|
---|
88 | if [ "$system" = "redhat" ]; then
|
---|
89 | . /etc/init.d/functions
|
---|
90 | fail_msg() {
|
---|
91 | echo_failure
|
---|
92 | echo
|
---|
93 | }
|
---|
94 | succ_msg() {
|
---|
95 | echo_success
|
---|
96 | echo
|
---|
97 | }
|
---|
98 | begin() {
|
---|
99 | echo -n "$1"
|
---|
100 | }
|
---|
101 | fi
|
---|
102 |
|
---|
103 | if [ "$system" = "suse" ]; then
|
---|
104 | . /etc/rc.status
|
---|
105 | fail_msg() {
|
---|
106 | rc_failed 1
|
---|
107 | rc_status -v
|
---|
108 | }
|
---|
109 | succ_msg() {
|
---|
110 | rc_reset
|
---|
111 | rc_status -v
|
---|
112 | }
|
---|
113 | begin() {
|
---|
114 | echo -n "$1"
|
---|
115 | }
|
---|
116 | fi
|
---|
117 |
|
---|
118 | if [ "$system" = "gentoo" ]; then
|
---|
119 | if [ -f /sbin/functions.sh ]; then
|
---|
120 | . /sbin/functions.sh
|
---|
121 | elif [ -f /etc/init.d/functions.sh ]; then
|
---|
122 | . /etc/init.d/functions.sh
|
---|
123 | fi
|
---|
124 | fail_msg() {
|
---|
125 | eend 1
|
---|
126 | }
|
---|
127 | succ_msg() {
|
---|
128 | eend $?
|
---|
129 | }
|
---|
130 | begin() {
|
---|
131 | ebegin $1
|
---|
132 | }
|
---|
133 | if [ "`which $0`" = "/sbin/rc" ]; then
|
---|
134 | shift
|
---|
135 | fi
|
---|
136 | fi
|
---|
137 |
|
---|
138 | if [ "$system" = "lfs" ]; then
|
---|
139 | . /etc/rc.d/init.d/functions
|
---|
140 | fail_msg() {
|
---|
141 | echo_failure
|
---|
142 | }
|
---|
143 | succ_msg() {
|
---|
144 | echo_ok
|
---|
145 | }
|
---|
146 | begin() {
|
---|
147 | echo $1
|
---|
148 | }
|
---|
149 | fi
|
---|
150 |
|
---|
151 | if [ "$system" = "other" ]; then
|
---|
152 | fail_msg() {
|
---|
153 | echo " ...fail!"
|
---|
154 | }
|
---|
155 | succ_msg() {
|
---|
156 | echo " ...done."
|
---|
157 | }
|
---|
158 | begin() {
|
---|
159 | echo -n $1
|
---|
160 | }
|
---|
161 | fi
|
---|
162 |
|
---|
163 | show_error()
|
---|
164 | {
|
---|
165 | if [ "$system" = "gentoo" ]; then
|
---|
166 | eerror $1
|
---|
167 | fi
|
---|
168 | fail_msg
|
---|
169 | echo "($1)"
|
---|
170 | }
|
---|
171 |
|
---|
172 | fail()
|
---|
173 | {
|
---|
174 | show_error "$1"
|
---|
175 | exit 1
|
---|
176 | }
|
---|
177 |
|
---|
178 | dev=/dev/vboxguest
|
---|
179 | userdev=/dev/vboxuser
|
---|
180 | config=/var/lib/VBoxGuestAdditions/config
|
---|
181 | owner=vboxadd
|
---|
182 | group=1
|
---|
183 |
|
---|
184 | test_for_gcc_and_make()
|
---|
185 | {
|
---|
186 | which make > /dev/null 2>&1 || printf "\nThe make utility was not found. If the following module compilation fails then\nthis could be the reason and you should try installing it.\n"
|
---|
187 | which gcc > /dev/null 2>&1 || printf "\nThe gcc utility was not found. If the following module compilation fails then\nthis could be the reason and you should try installing it.\n"
|
---|
188 | }
|
---|
189 |
|
---|
190 | test_sane_kernel_dir()
|
---|
191 | {
|
---|
192 | KERN_VER=`uname -r`
|
---|
193 | KERN_DIR="/lib/modules/$KERN_VER/build"
|
---|
194 | if [ -d "$KERN_DIR" ]; then
|
---|
195 | KERN_REL=`make -sC $KERN_DIR --no-print-directory kernelrelease 2>/dev/null || true`
|
---|
196 | if [ -z "$KERN_REL" -o "x$KERN_REL" = "x$KERN_VER" ]; then
|
---|
197 | return 0
|
---|
198 | fi
|
---|
199 | fi
|
---|
200 | printf "\nThe headers for the current running kernel were not found. If the following\nmodule compilation fails then this could be the reason.\n"
|
---|
201 | if [ "$system" = "redhat" ]; then
|
---|
202 | if echo "$KERN_VER" | grep -q "uek"; then
|
---|
203 | printf "The missing package can be probably installed with\nyum install kernel-uek-devel-$KERN_VER\n"
|
---|
204 | else
|
---|
205 | printf "The missing package can be probably installed with\nyum install kernel-devel-$KERN_VER\n"
|
---|
206 | fi
|
---|
207 | elif [ "$system" = "suse" ]; then
|
---|
208 | KERN_VER_SUSE=`echo "$KERN_VER" | sed 's/.*-\([^-]*\)/\1/g'`
|
---|
209 | KERN_VER_BASE=`echo "$KERN_VER" | sed 's/\(.*\)-[^-]*/\1/g'`
|
---|
210 | printf "The missing package can be probably installed with\nzypper install kernel-$KERN_VER_SUSE-devel-$KERN_VER_BASE\n"
|
---|
211 | elif [ "$system" = "debian" ]; then
|
---|
212 | printf "The missing package can be probably installed with\napt-get install linux-headers-$KERN_VER\n"
|
---|
213 | fi
|
---|
214 | }
|
---|
215 |
|
---|
216 | running_vboxguest()
|
---|
217 | {
|
---|
218 | lsmod | grep -q "vboxguest[^_-]"
|
---|
219 | }
|
---|
220 |
|
---|
221 | running_vboxadd()
|
---|
222 | {
|
---|
223 | lsmod | grep -q "vboxadd[^_-]"
|
---|
224 | }
|
---|
225 |
|
---|
226 | running_vboxsf()
|
---|
227 | {
|
---|
228 | lsmod | grep -q "vboxsf[^_-]"
|
---|
229 | }
|
---|
230 |
|
---|
231 | running_vboxvideo()
|
---|
232 | {
|
---|
233 | lsmod | grep -q "vboxvideo[^_-]"
|
---|
234 | }
|
---|
235 |
|
---|
236 | do_vboxguest_non_udev()
|
---|
237 | {
|
---|
238 | if [ ! -c $dev ]; then
|
---|
239 | maj=`sed -n 's;\([0-9]\+\) vboxguest;\1;p' /proc/devices`
|
---|
240 | if [ ! -z "$maj" ]; then
|
---|
241 | min=0
|
---|
242 | else
|
---|
243 | min=`sed -n 's;\([0-9]\+\) vboxguest;\1;p' /proc/misc`
|
---|
244 | if [ ! -z "$min" ]; then
|
---|
245 | maj=10
|
---|
246 | fi
|
---|
247 | fi
|
---|
248 | test -z "$maj" && {
|
---|
249 | rmmod vboxguest 2>/dev/null
|
---|
250 | fail "Cannot locate the VirtualBox device"
|
---|
251 | }
|
---|
252 |
|
---|
253 | mknod -m 0664 $dev c $maj $min || {
|
---|
254 | rmmod vboxguest 2>/dev/null
|
---|
255 | fail "Cannot create device $dev with major $maj and minor $min"
|
---|
256 | }
|
---|
257 | fi
|
---|
258 | chown $owner:$group $dev 2>/dev/null || {
|
---|
259 | rm -f $dev 2>/dev/null
|
---|
260 | rm -f $userdev 2>/dev/null
|
---|
261 | rmmod vboxguest 2>/dev/null
|
---|
262 | fail "Cannot change owner $owner:$group for device $dev"
|
---|
263 | }
|
---|
264 |
|
---|
265 | if [ ! -c $userdev ]; then
|
---|
266 | maj=10
|
---|
267 | min=`sed -n 's;\([0-9]\+\) vboxuser;\1;p' /proc/misc`
|
---|
268 | if [ ! -z "$min" ]; then
|
---|
269 | mknod -m 0666 $userdev c $maj $min || {
|
---|
270 | rm -f $dev 2>/dev/null
|
---|
271 | rmmod vboxguest 2>/dev/null
|
---|
272 | fail "Cannot create device $userdev with major $maj and minor $min"
|
---|
273 | }
|
---|
274 | chown $owner:$group $userdev 2>/dev/null || {
|
---|
275 | rm -f $dev 2>/dev/null
|
---|
276 | rm -f $userdev 2>/dev/null
|
---|
277 | rmmod vboxguest 2>/dev/null
|
---|
278 | fail "Cannot change owner $owner:$group for device $userdev"
|
---|
279 | }
|
---|
280 | fi
|
---|
281 | fi
|
---|
282 | }
|
---|
283 |
|
---|
284 | start()
|
---|
285 | {
|
---|
286 | begin "Starting the VirtualBox Guest Additions ";
|
---|
287 | uname -r | grep -q '^2\.6' 2>/dev/null &&
|
---|
288 | ps -A -o comm | grep -q '/*udevd$' 2>/dev/null ||
|
---|
289 | no_udev=1
|
---|
290 | running_vboxguest || {
|
---|
291 | rm -f $dev || {
|
---|
292 | fail "Cannot remove $dev"
|
---|
293 | }
|
---|
294 |
|
---|
295 | rm -f $userdev || {
|
---|
296 | fail "Cannot remove $userdev"
|
---|
297 | }
|
---|
298 |
|
---|
299 | $MODPROBE vboxguest >/dev/null 2>&1 || {
|
---|
300 | fail "modprobe vboxguest failed"
|
---|
301 | }
|
---|
302 | case "$no_udev" in 1)
|
---|
303 | sleep .5;;
|
---|
304 | esac
|
---|
305 | }
|
---|
306 | case "$no_udev" in 1)
|
---|
307 | do_vboxguest_non_udev;;
|
---|
308 | esac
|
---|
309 |
|
---|
310 | running_vboxsf || {
|
---|
311 | $MODPROBE vboxsf > /dev/null 2>&1 || {
|
---|
312 | if dmesg | grep "vboxConnect failed" > /dev/null 2>&1; then
|
---|
313 | fail_msg
|
---|
314 | echo "Unable to start shared folders support. Make sure that your VirtualBox build"
|
---|
315 | echo "supports this feature."
|
---|
316 | exit 1
|
---|
317 | fi
|
---|
318 | fail "modprobe vboxsf failed"
|
---|
319 | }
|
---|
320 | }
|
---|
321 |
|
---|
322 | # This is needed as X.Org Server 1.13 does not auto-load the module.
|
---|
323 | running_vboxvideo || $MODPROBE vboxvideo > /dev/null 2>&1
|
---|
324 |
|
---|
325 | # Mount all shared folders from /etc/fstab. Normally this is done by some
|
---|
326 | # other startup script but this requires the vboxdrv kernel module loaded.
|
---|
327 | # This isn't necessary anymore as the vboxsf module is autoloaded.
|
---|
328 | # mount -a -t vboxsf
|
---|
329 |
|
---|
330 | succ_msg
|
---|
331 | return 0
|
---|
332 | }
|
---|
333 |
|
---|
334 | stop()
|
---|
335 | {
|
---|
336 | begin "Stopping VirtualBox Additions ";
|
---|
337 | if ! umount -a -t vboxsf 2>/dev/null; then
|
---|
338 | fail "Cannot unmount vboxsf folders"
|
---|
339 | fi
|
---|
340 | if running_vboxsf; then
|
---|
341 | rmmod vboxsf 2>/dev/null || fail "Cannot unload module vboxsf"
|
---|
342 | fi
|
---|
343 | if running_vboxguest; then
|
---|
344 | rmmod vboxguest 2>/dev/null || fail "Cannot unload module vboxguest"
|
---|
345 | rm -f $userdev || fail "Cannot unlink $userdev"
|
---|
346 | rm -f $dev || fail "Cannot unlink $dev"
|
---|
347 | fi
|
---|
348 | succ_msg
|
---|
349 | return 0
|
---|
350 | }
|
---|
351 |
|
---|
352 | restart()
|
---|
353 | {
|
---|
354 | stop && start
|
---|
355 | return 0
|
---|
356 | }
|
---|
357 |
|
---|
358 | # Remove any existing VirtualBox guest kernel modules from the disk, but not
|
---|
359 | # from the kernel as they may still be in use
|
---|
360 | cleanup_modules()
|
---|
361 | {
|
---|
362 | if [ -n "$(which dkms 2>/dev/null)" ]; then
|
---|
363 | begin "Removing existing VirtualBox DKMS kernel modules"
|
---|
364 | $DODKMS uninstall $OLDMODULES > $LOG
|
---|
365 | succ_msg
|
---|
366 | fi
|
---|
367 | begin "Removing existing VirtualBox non-DKMS kernel modules"
|
---|
368 | for i in $OLDMODULES; do
|
---|
369 | find /lib/modules -name $i\* | xargs rm 2>/dev/null
|
---|
370 | done
|
---|
371 | succ_msg
|
---|
372 | }
|
---|
373 |
|
---|
374 | # Build and install the VirtualBox guest kernel modules
|
---|
375 | setup_modules()
|
---|
376 | {
|
---|
377 | # don't stop the old modules here -- they might be in use
|
---|
378 | cleanup_modules
|
---|
379 | begin "Building the VirtualBox Guest Additions kernel modules"
|
---|
380 |
|
---|
381 | # Short cut out if a dkms build succeeds
|
---|
382 | if [ -n "$(which dkms 2>/dev/null)" ] &&
|
---|
383 | $DODKMS install vboxguest $INSTALL_VER >> $LOG 2>&1; then
|
---|
384 | succ_msg
|
---|
385 | return 0
|
---|
386 | fi
|
---|
387 |
|
---|
388 | test_for_gcc_and_make
|
---|
389 | test_sane_kernel_dir
|
---|
390 |
|
---|
391 | echo
|
---|
392 | begin "Building the main Guest Additions module"
|
---|
393 | if ! $BUILDINTMP \
|
---|
394 | --save-module-symvers /tmp/vboxguest-Module.symvers \
|
---|
395 | --module-source $MODULE_SRC/vboxguest \
|
---|
396 | --no-print-directory install >> $LOG 2>&1; then
|
---|
397 | show_error "Look at $LOG to find out what went wrong"
|
---|
398 | return 1
|
---|
399 | fi
|
---|
400 | succ_msg
|
---|
401 | begin "Building the shared folder support module"
|
---|
402 | if ! $BUILDINTMP \
|
---|
403 | --use-module-symvers /tmp/vboxguest-Module.symvers \
|
---|
404 | --module-source $MODULE_SRC/vboxsf \
|
---|
405 | --no-print-directory install >> $LOG 2>&1; then
|
---|
406 | show_error "Look at $LOG to find out what went wrong"
|
---|
407 | return 1
|
---|
408 | fi
|
---|
409 | succ_msg
|
---|
410 | if expr `uname -r` '<' '2.6.27' > /dev/null; then
|
---|
411 | echo "Not building the VirtualBox advanced graphics driver as this Linux version is"
|
---|
412 | echo "too old to use it."
|
---|
413 | else
|
---|
414 | begin "Building the OpenGL support module"
|
---|
415 | if ! $BUILDINTMP \
|
---|
416 | --use-module-symvers /tmp/vboxguest-Module.symvers \
|
---|
417 | --module-source $MODULE_SRC/vboxvideo \
|
---|
418 | --no-print-directory install >> $LOG 2>&1; then
|
---|
419 | show_error "Look at $LOG to find out what went wrong"
|
---|
420 | return 1
|
---|
421 | fi
|
---|
422 | succ_msg
|
---|
423 | fi
|
---|
424 | depmod
|
---|
425 | return 0
|
---|
426 | }
|
---|
427 |
|
---|
428 | # Do non-kernel bits needed for the kernel modules to work properly (user
|
---|
429 | # creation, udev, mount helper...)
|
---|
430 | extra_setup()
|
---|
431 | {
|
---|
432 | begin "Doing non-kernel setup of the Guest Additions"
|
---|
433 | echo "Creating user for the Guest Additions." >> $LOG
|
---|
434 | # This is the LSB version of useradd and should work on recent
|
---|
435 | # distributions
|
---|
436 | useradd -d /var/run/vboxadd -g 1 -r -s /bin/false vboxadd >/dev/null 2>&1
|
---|
437 | # And for the others, we choose a UID ourselves
|
---|
438 | useradd -d /var/run/vboxadd -g 1 -u 501 -o -s /bin/false vboxadd >/dev/null 2>&1
|
---|
439 |
|
---|
440 | # Add a group "vboxsf" for Shared Folders access
|
---|
441 | # All users which want to access the auto-mounted Shared Folders have to
|
---|
442 | # be added to this group.
|
---|
443 | groupadd -f vboxsf >/dev/null 2>&1
|
---|
444 |
|
---|
445 | # Create udev description file
|
---|
446 | if [ -d /etc/udev/rules.d ]; then
|
---|
447 | echo "Creating udev rule for the Guest Additions kernel module." >> $LOG
|
---|
448 | udev_call=""
|
---|
449 | udev_app=`which udevadm 2> /dev/null`
|
---|
450 | if [ $? -eq 0 ]; then
|
---|
451 | udev_call="${udev_app} version 2> /dev/null"
|
---|
452 | else
|
---|
453 | udev_app=`which udevinfo 2> /dev/null`
|
---|
454 | if [ $? -eq 0 ]; then
|
---|
455 | udev_call="${udev_app} -V 2> /dev/null"
|
---|
456 | fi
|
---|
457 | fi
|
---|
458 | udev_fix="="
|
---|
459 | if [ "${udev_call}" != "" ]; then
|
---|
460 | udev_out=`${udev_call}`
|
---|
461 | udev_ver=`expr "$udev_out" : '[^0-9]*\([0-9]*\)'`
|
---|
462 | if [ "$udev_ver" = "" -o "$udev_ver" -lt 55 ]; then
|
---|
463 | udev_fix=""
|
---|
464 | fi
|
---|
465 | fi
|
---|
466 | ## @todo 60-vboxadd.rules -> 60-vboxguest.rules ?
|
---|
467 | echo "KERNEL=${udev_fix}\"vboxguest\", NAME=\"vboxguest\", OWNER=\"vboxadd\", MODE=\"0660\"" > /etc/udev/rules.d/60-vboxadd.rules
|
---|
468 | echo "KERNEL=${udev_fix}\"vboxuser\", NAME=\"vboxuser\", OWNER=\"vboxadd\", MODE=\"0666\"" >> /etc/udev/rules.d/60-vboxadd.rules
|
---|
469 | fi
|
---|
470 |
|
---|
471 | # Put mount.vboxsf in the right place
|
---|
472 | ln -sf "$lib_path/$PACKAGE/mount.vboxsf" /sbin
|
---|
473 | # At least Fedora 11 and Fedora 12 require the correct security context when
|
---|
474 | # executing this command from service scripts. Shouldn't hurt for other
|
---|
475 | # distributions.
|
---|
476 | chcon -u system_u -t mount_exec_t "$lib_path/$PACKAGE/mount.vboxsf" > /dev/null 2>&1
|
---|
477 | # And at least Fedora 15 needs this for the acceleration support check to
|
---|
478 | # work
|
---|
479 | redhat_release=`cat /etc/redhat-release 2> /dev/null`
|
---|
480 | case "$redhat_release" in Fedora\ release\ 15* )
|
---|
481 | for i in "$lib_path"/*.so
|
---|
482 | do
|
---|
483 | restorecon "$i" >/dev/null
|
---|
484 | done
|
---|
485 | ;;
|
---|
486 | esac
|
---|
487 |
|
---|
488 | succ_msg
|
---|
489 | }
|
---|
490 |
|
---|
491 | # setup_script
|
---|
492 | setup()
|
---|
493 | {
|
---|
494 | if test -r $config; then
|
---|
495 | . $config
|
---|
496 | else
|
---|
497 | fail "Configuration file $config not found"
|
---|
498 | fi
|
---|
499 | test -n "$INSTALL_DIR" -a -n "$INSTALL_VER" ||
|
---|
500 | fail "Configuration file $config not complete"
|
---|
501 | export BUILD_TYPE
|
---|
502 | export USERNAME
|
---|
503 |
|
---|
504 | MODULE_SRC="$INSTALL_DIR/src/vboxguest-$INSTALL_VER"
|
---|
505 | BUILDINTMP="$MODULE_SRC/build_in_tmp"
|
---|
506 | DODKMS="$MODULE_SRC/do_dkms"
|
---|
507 | chcon -t bin_t "$BUILDINTMP" > /dev/null 2>&1
|
---|
508 | chcon -t bin_t "$DODKMS" > /dev/null 2>&1
|
---|
509 |
|
---|
510 | setup_modules
|
---|
511 | mod_succ="$?"
|
---|
512 | extra_setup
|
---|
513 | if [ "$mod_succ" -eq "0" ]; then
|
---|
514 | if running_vboxguest || running_vboxadd; then
|
---|
515 | printf "You should restart your guest to make sure the new modules are actually used\n\n"
|
---|
516 | else
|
---|
517 | start
|
---|
518 | fi
|
---|
519 | fi
|
---|
520 | }
|
---|
521 |
|
---|
522 | # cleanup_script
|
---|
523 | cleanup()
|
---|
524 | {
|
---|
525 | if test -r $config; then
|
---|
526 | . $config
|
---|
527 | test -n "$INSTALL_DIR" -a -n "$INSTALL_VER" ||
|
---|
528 | fail "Configuration file $config not complete"
|
---|
529 | DODKMS="$INSTALL_DIR/src/vboxguest-$INSTALL_VER/do_dkms"
|
---|
530 | elif test -x ./do_dkms; then # Executing as part of the installer...
|
---|
531 | DODKMS=./do_dkms
|
---|
532 | else
|
---|
533 | fail "Configuration file $config not found"
|
---|
534 | fi
|
---|
535 |
|
---|
536 | # Delete old versions of VBox modules.
|
---|
537 | cleanup_modules
|
---|
538 | depmod
|
---|
539 |
|
---|
540 | # Remove old module sources
|
---|
541 | for i in $OLDMODULES; do
|
---|
542 | rm -rf /usr/src/$i-*
|
---|
543 | done
|
---|
544 |
|
---|
545 | # Remove other files
|
---|
546 | rm /sbin/mount.vboxsf 2>/dev/null
|
---|
547 | rm /etc/udev/rules.d/60-vboxadd.rules 2>/dev/null
|
---|
548 | }
|
---|
549 |
|
---|
550 | dmnstatus()
|
---|
551 | {
|
---|
552 | if running_vboxguest; then
|
---|
553 | echo "The VirtualBox Additions are currently running."
|
---|
554 | else
|
---|
555 | echo "The VirtualBox Additions are not currently running."
|
---|
556 | fi
|
---|
557 | }
|
---|
558 |
|
---|
559 | case "$1" in
|
---|
560 | start)
|
---|
561 | start
|
---|
562 | ;;
|
---|
563 | stop)
|
---|
564 | stop
|
---|
565 | ;;
|
---|
566 | restart)
|
---|
567 | restart
|
---|
568 | ;;
|
---|
569 | setup)
|
---|
570 | setup
|
---|
571 | ;;
|
---|
572 | cleanup)
|
---|
573 | cleanup
|
---|
574 | ;;
|
---|
575 | status)
|
---|
576 | dmnstatus
|
---|
577 | ;;
|
---|
578 | *)
|
---|
579 | echo "Usage: $0 {start|stop|restart|status|setup}"
|
---|
580 | exit 1
|
---|
581 | esac
|
---|
582 |
|
---|
583 | exit
|
---|