diff options
Diffstat (limited to 'system/virtualbox-addons')
-rw-r--r-- | system/virtualbox-addons/LocalConfig.kmk | 10 | ||||
-rw-r--r-- | system/virtualbox-addons/README | 10 | ||||
-rw-r--r-- | system/virtualbox-addons/README.SLACKWARE | 35 | ||||
-rw-r--r-- | system/virtualbox-addons/doinst.sh | 32 | ||||
-rw-r--r-- | system/virtualbox-addons/rc.vboxadd.diff | 36 | ||||
-rw-r--r-- | system/virtualbox-addons/slack-desc | 19 | ||||
-rw-r--r-- | system/virtualbox-addons/virtualbox-addons.SlackBuild | 165 | ||||
-rw-r--r-- | system/virtualbox-addons/virtualbox-addons.info | 10 |
8 files changed, 317 insertions, 0 deletions
diff --git a/system/virtualbox-addons/LocalConfig.kmk b/system/virtualbox-addons/LocalConfig.kmk new file mode 100644 index 000000000000..2051b447551d --- /dev/null +++ b/system/virtualbox-addons/LocalConfig.kmk @@ -0,0 +1,10 @@ +# Modify building of VirtualBox to get a cleaner system + +# build only guest-additions +VBOX_ONLY_ADDITIONS := 1 + +KBUILD_MSG_STYLE := brief + +VBOX_OSE := 1 + +VBOX_WITH_PAM = diff --git a/system/virtualbox-addons/README b/system/virtualbox-addons/README new file mode 100644 index 000000000000..dc61b13938ec --- /dev/null +++ b/system/virtualbox-addons/README @@ -0,0 +1,10 @@ +This is the userspace part of the VirtualBox Guest Additions. +Together with virtualbox-kernel-addons they enable shared folders, +shared clipboard, etcetera, inside your Slackware guest machines. + +See README.SLACKWARE for setup information. + +NOTE: This will not build on x86_64 + +This package is intended to be used on GUEST / VIRTUAL MACHINES running +Slackware, NOT the host system. diff --git a/system/virtualbox-addons/README.SLACKWARE b/system/virtualbox-addons/README.SLACKWARE new file mode 100644 index 000000000000..da28c0fd410b --- /dev/null +++ b/system/virtualbox-addons/README.SLACKWARE @@ -0,0 +1,35 @@ +You'll need to add the following lines to /etc/rc.d/rc.local: + + # Start vboxadd + if [ -x /etc/rc.d/rc.vboxadd ]; then + /etc/rc.d/rc.vboxadd start + fi + + # Start vboxadd-service + if [ -x /etc/rc.d/rc.vboxadd-service ]; then + /etc/rc.d/rc.vboxadd-service start + fi + +This will load the support kernel module and will setup the network +configuration for VirtualBox. + +You should then add the following to /etc/rc.d/rc.local_shutdown: + + # Stop vboxadd + if [ -x /etc/rc.d/rc.vboxadd ]; then + /etc/rc.d/rc.vboxadd stop + fi + + # Stop vboxadd-service + if [ -x /etc/rc.d/rc.vboxadd-service ]; then + /etc/rc.d/rc.vboxadd-service stop + fi + +You might want to add "/usr/bin/VBoxClient" +to your xinitrc file if you use a desktop environment that doesn't +respect /etc/xdg/autostart or /usr/share/autostart + +To use the vboxvideo xorg driver, you have to create an xorg.conf +and specifiy to use that driver in there. Xorg will NOT pick that +driver by default. + diff --git a/system/virtualbox-addons/doinst.sh b/system/virtualbox-addons/doinst.sh new file mode 100644 index 000000000000..58fdc15a9ad3 --- /dev/null +++ b/system/virtualbox-addons/doinst.sh @@ -0,0 +1,32 @@ +config() { + NEW="$1" + OLD="$(dirname $NEW)/$(basename $NEW .new)" + # If there's no config file by that name, mv it over: + if [ ! -r $OLD ]; then + mv $NEW $OLD + elif [ "$(cat $OLD | md5sum)" = "$(cat $NEW | md5sum)" ]; then + # toss the redundant copy + rm $NEW + fi + # Otherwise, we leave the .new copy for the admin to consider... +} + +preserve_perms() { + NEW="$1" + OLD="$(dirname $NEW)/$(basename $NEW .new)" + if [ -e $OLD ]; then + cp -a $OLD ${NEW}.incoming + cat $NEW > ${NEW}.incoming + mv ${NEW}.incoming $NEW + fi + config $NEW +} + +preserve_perms etc/rc.d/rc.vboxadd.new +preserve_perms etc/rc.d/rc.vboxadd-service.new + +# remove existing fdi cache to recognize newly installed fdi files +# and restart hal to regenerate the cache +rm -f var/cache/hald/fdi-cache +chroot . /etc/rc.d/rc.hald restart + diff --git a/system/virtualbox-addons/rc.vboxadd.diff b/system/virtualbox-addons/rc.vboxadd.diff new file mode 100644 index 000000000000..138defbb71a9 --- /dev/null +++ b/system/virtualbox-addons/rc.vboxadd.diff @@ -0,0 +1,36 @@ +--- vboxadd.sh 2011-02-17 17:31:03.000000000 +0100 ++++ vboxadd.sh.new 2011-04-03 13:50:51.367000031 +0200 +@@ -465,31 +465,13 @@ + # setup_script + setup() + { +- setup_modules +- mod_succ="$?" +- extra_setup +- if [ "$mod_succ" -eq "0" ]; then +- if running_vboxguest || running_vboxadd; then +- printf "You should restart your guest to make sure the new modules are actually used\n\n" +- else +- start +- fi +- fi ++ echo "Not implemented! Please use the virtualbox-kernel-addons.SlackBuild available at SlackBuilds.org instead." + } + + # cleanup_script + cleanup() + { +- # Delete old versions of VBox modules. +- cleanup_modules +- depmod +- +- # Remove old module sources +- rm -rf /usr/src/vboxadd-* /usr/src/vboxguest-* /usr/src/vboxvfs-* /usr/src/vboxsf-* /usr/src/vboxvideo-* +- +- # Remove other files +- rm /sbin/mount.vboxsf 2>/dev/null +- rm /etc/udev/rules.d/60-vboxadd.rules 2>/dev/null ++ echo "Not implemented! Please use removepkg or pkgtool to remove virtualbox-addons and/or virtualbox-kernel-addons instead." + } + + dmnstatus() diff --git a/system/virtualbox-addons/slack-desc b/system/virtualbox-addons/slack-desc new file mode 100644 index 000000000000..c872ae93c1ed --- /dev/null +++ b/system/virtualbox-addons/slack-desc @@ -0,0 +1,19 @@ +# HOW TO EDIT THIS FILE: +# The "handy ruler" below makes it easier to edit a package description. Line +# up the first '|' above the ':' following the base package name, and the '|' +# on the right side marks the last column you can put a character in. You must +# make exactly 11 lines for the formatting to be correct. It's also +# customary to leave one space after the ':'. + + |-----handy-ruler------------------------------------------------------| +virtualbox-addons: virtualbox-addons (VirtualBox Guest Additions) +virtualbox-addons: +virtualbox-addons: This is the userspace part of the VirtualBox Guest Additions. +virtualbox-addons: Together with virtualbox-kernel-addons, they enable shared folders, +virtualbox-addons: folders, shared clipboard, etcetera usage inside guest machines. +virtualbox-addons: +virtualbox-addons: Homepage: http://www.virtualbox.org +virtualbox-addons: +virtualbox-addons: +virtualbox-addons: +virtualbox-addons: diff --git a/system/virtualbox-addons/virtualbox-addons.SlackBuild b/system/virtualbox-addons/virtualbox-addons.SlackBuild new file mode 100644 index 000000000000..6dbf9d155cd7 --- /dev/null +++ b/system/virtualbox-addons/virtualbox-addons.SlackBuild @@ -0,0 +1,165 @@ +#!/bin/sh + +# Slackware build script for virtualbox-ose-addons + +# Copyright 2008-2011 Heinz Wiesinger, Amsterdam, The Netherlands +# All rights reserved. +# +# Redistribution and use of this script, with or without modification, is +# permitted provided that the following conditions are met: +# +# 1. Redistributions of this script must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# +# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ''AS IS'' AND ANY EXPRESS OR IMPLIED +# WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF +# MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO +# EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, +# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; +# OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, +# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR +# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF +# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +PRGNAM=virtualbox-addons +SRCNAM=VirtualBox +VERSION=4.0.4 +BUILD=${BUILD:-1} +TAG=${TAG:-_SBo} + +if [ -z "$ARCH" ]; then + case "$( uname -m )" in + i?86) ARCH=i486 ;; + arm*) ARCH=arm ;; + *) ARCH=$( uname -m ) ;; + esac +fi + +CWD=$(pwd) +TMP=${TMP:-/tmp/SBo} +PKG=$TMP/package-$PRGNAM +OUTPUT=${OUTPUT:-/tmp} + +if ! grep ^vboxadd: /etc/passwd 2>&1 > /dev/null; then + echo " You must have a vboxadd user to run this script." + echo " # useradd -u 215 -d /var/run/vboxadd -g 1 -s /bin/sh vboxadd" + exit 1 +fi + +# kmk doesn't support MAKEFLAGS, so we use JOBS here +JOBS=${JOBS:-3} + +# set xorg-server version +XSERVER=$(X -version 2>&1 | grep Server | cut -d " " -f 4 | sed "s/\.//" | cut -d "." -f 1) + +if [ "$ARCH" = "i486" ]; then + SLKCFLAGS="-O2 -march=i486 -mtune=i686" + LIBDIRSUFFIX="" + TARGET="x86" +elif [ "$ARCH" = "i686" ]; then + SLKCFLAGS="-O2 -march=i686 -mtune=i686" + LIBDIRSUFFIX="" + TARGET="x86" +elif [ "$ARCH" = "x86_64" ]; then + SLKCFLAGS="-O2 -fPIC" + LIBDIRSUFFIX="64" + TARGET="amd64" +fi + +set -e + +rm -rf $PKG +mkdir -p $TMP $PKG $OUTPUT +cd $TMP +rm -rf $SRCNAM-${VERSION}_OSE +tar xvf $CWD/$SRCNAM-${VERSION}.tar.bz2 +cd $SRCNAM-${VERSION}_OSE +chown -R root:root . +chmod -R u+w,go+r-w,a-s . + +# We set the environment variables manually to avoid dependency on acpica +export BUILD_PLATFORM="linux" +export BUILD_PLATFORM_ARCH="$TARGET" +export BUILD_TARGET="linux" +export BUILD_TARGET_ARCH="$TARGET" +export BUILD_TARGET_CPU="$ARCH" +export BUILD_TYPE="release" +export PATH_KBUILD="$TMP/$SRCNAM-${VERSION}_OSE/kBuild" +export PATH_DEVTOOLS="$TMP/$SRCNAM-${VERSION}_OSE/tools" +path_kbuild_bin="$PATH_KBUILD/bin/$BUILD_TARGET.$BUILD_PLATFORM_ARCH" +export PATH_KBUILD_BIN="$path_kbuild_bin" +path_dev_bin="$PATH_DEVTOOLS/$BUILD_TARGET.$BUILD_PLATFORM_ARCH"/bin +echo "$PATH" | grep -q "$path_kbuild_bin" || PATH="$path_kbuild_bin:$PATH" +echo "$PATH" | grep -q "$path_dev_bin" || PATH="$path_dev_bin:$PATH" +export PATH +unset path_kbuild_bin path_dev_bin + +kmk -j ${JOBS} LOCALCFG=$CWD/LocalConfig.kmk + +mkdir -p $PKG/lib/udev/rules.d $PKG/sbin \ + $PKG/etc/{xdg/autostart,rc.d,X11/xorg.conf.d} \ + $PKG/usr/{src,bin,sbin,share/autostart} \ + $PKG/usr/lib$LIBDIRSUFFIX/xorg/modules/{drivers,input} + +patch -d src/VBox/Additions/linux/installer/ -i $CWD/rc.vboxadd.diff +cp -f src/VBox/Additions/linux/installer/vboxadd.sh \ + $PKG/etc/rc.d/rc.vboxadd.new +cp -f src/VBox/Additions/linux/installer/vboxadd-service.sh \ + $PKG/etc/rc.d/rc.vboxadd-service.new + +cp -f src/VBox/Additions/x11/Installer/vboxclient.desktop \ + $PKG/etc/xdg/autostart/ +cp -f src/VBox/Additions/x11/Installer/vboxclient.desktop \ + $PKG/usr/share/autostart/ +install -m 755 src/VBox/Additions/x11/Installer/98vboxadd-xclient \ + $PKG/usr/bin/VBoxClient-all + +echo "KERNEL==\"vboxguest\", NAME=\"vboxguest\", OWNER=\"vboxadd\", MODE=\"0660\"" \ + > $PKG/lib/udev/rules.d/60-vboxadd.rules +echo "KERNEL==\"vboxuser\", NAME=\"vboxuser\", OWNER=\"vboxadd\", MODE=\"0666\"" \ + >> $PKG/lib/udev/rules.d/60-vboxadd.rules + +install -m 644 src/VBox/Additions/linux/installer/70-xorg-vboxmouse.rules \ + $PKG/lib/udev/rules.d/ + +install -m 644 src/VBox/Additions/x11/Installer/50-vboxmouse.conf \ + $PKG/etc/X11/xorg.conf.d/ + +cd out/linux.$TARGET/release/bin/additions + cp -rf src/vboxguest $PKG/usr/src/vboxguest-$VERSION + cp -rf src/vboxsf $PKG/usr/src/vboxsf-$VERSION + cp -rf src/vboxvideo $PKG/usr/src/vboxvideo-$VERSION + install -m 755 VBoxControl $PKG/usr/bin/ + install -m 755 VBoxClient $PKG/usr/bin/ + install -m 755 VBoxService $PKG/usr/sbin/ + install -m 4755 mount.vboxsf $PKG/sbin/mount.vboxsf + install -m 644 vboxvideo_drv_$XSERVER.so \ + $PKG/usr/lib$LIBDIRSUFFIX/xorg/modules/drivers/vboxvideo_drv.so + install -m 644 vboxmouse_drv_$XSERVER.so \ + $PKG/usr/lib$LIBDIRSUFFIX/xorg/modules/input/vboxmouse_drv.so + + install -m 644 VBoxOGLcrutil.so $PKG/usr/lib$LIBDIRSUFFIX + install -m 644 VBoxOGLerrorspu.so $PKG/usr/lib$LIBDIRSUFFIX + install -m 644 VBoxOGLarrayspu.so $PKG/usr/lib$LIBDIRSUFFIX + install -m 644 VBoxOGLfeedbackspu.so $PKG/usr/lib$LIBDIRSUFFIX + install -m 644 VBoxOGLpackspu.so $PKG/usr/lib$LIBDIRSUFFIX + install -m 644 VBoxOGLpassthroughspu.so $PKG/usr/lib$LIBDIRSUFFIX + install -m 644 VBoxOGL.so $PKG/usr/lib$LIBDIRSUFFIX + + mkdir -p $PKG/usr/lib$LIBDIRSUFFIX/xorg/modules/dri + ln -s /usr/lib$LIBDIRSUFFIX/VBoxOGL.so \ + $PKG/usr/lib$LIBDIRSUFFIX/xorg/modules/dri/vboxvideo_dri.so +cd - + +mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION +cp -f COPYING COPYING.CDDL $PKG/usr/doc/$PRGNAM-$VERSION +cat $CWD/README.SLACKWARE > $PKG/usr/doc/$PRGNAM-$VERSION/README.SLACKWARE +cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild + +mkdir -p $PKG/install +cat $CWD/slack-desc > $PKG/install/slack-desc +cat $CWD/doinst.sh > $PKG/install/doinst.sh + +cd $PKG +/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.${PKGTYPE:-tgz} diff --git a/system/virtualbox-addons/virtualbox-addons.info b/system/virtualbox-addons/virtualbox-addons.info new file mode 100644 index 000000000000..14b07d3b19e1 --- /dev/null +++ b/system/virtualbox-addons/virtualbox-addons.info @@ -0,0 +1,10 @@ +PRGNAM="virtualbox-ose-addons" +VERSION="4.0.4" +HOMEPAGE="http://www.virtualbox.org" +DOWNLOAD="http://download.virtualbox.org/virtualbox/4.0.4/VirtualBox-4.0.4.tar.bz2" +MD5SUM="b4770ca14d1a8cbad9b3eb0e0028ff4b" +DOWNLOAD_x86_64="UNTESTED" +MD5SUM_x86_64="" +MAINTAINER="Heinz Wiesinger" +EMAIL="pprkut@liwjatan.at" +APPROVED="rworkman" |