aboutsummaryrefslogtreecommitdiff
path: root/sys/kernel/kernel-ratten/kernel-ratten.SlackBuild
diff options
context:
space:
mode:
Diffstat (limited to 'sys/kernel/kernel-ratten/kernel-ratten.SlackBuild')
-rwxr-xr-xsys/kernel/kernel-ratten/kernel-ratten.SlackBuild180
1 files changed, 180 insertions, 0 deletions
diff --git a/sys/kernel/kernel-ratten/kernel-ratten.SlackBuild b/sys/kernel/kernel-ratten/kernel-ratten.SlackBuild
new file mode 100755
index 00000000..98b19af0
--- /dev/null
+++ b/sys/kernel/kernel-ratten/kernel-ratten.SlackBuild
@@ -0,0 +1,180 @@
+#!/bin/bash
+#
+# kernel-ratten.SlackBuild is free software; you can redistribute it and/or modify it under the
+# terms of the GNU General Public License as published by the Free Software
+# Foundation; either version 2 of the License, or any later version.
+#
+# kernel-ratten.SlackBuild is distributed in the hope that it will be useful, but WITHOUT ANY
+# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
+# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License along with
+# this program; if not, write to the Free Software Foundation, Inc., 59 Temple
+# Place - Suite 330, Boston, MA 02111-1307, USA
+#
+# slackbuild for kernel-ratten
+# by rhatto at riseup.net
+#
+
+if [ -s "slack-required" ]; then
+ echo Recomended and required packages for building kernel-ratten are:
+ cat slack-required | sed -e 's/^/\t/'
+ if [ "$INTERACT" != "no" ]; then
+ echo If you dont have those installed, press Ctrl-C. Otherwise, hit ENTER.
+ read crap
+# else
+# echo Sleeping 3 seconds...
+# sleep 3
+ fi
+fi
+
+if [ -f ~/.slackbuildrc ]; then
+ source ~/.slackbuildrc
+elif [ -f /etc/slackbuildrc ]; then
+ source /etc/slackbuildrc
+fi
+
+CWD="`pwd`"
+
+PACKAGE="kernel-ratten"
+PATCHSET="bs-rt"
+ARCH="x86_64"
+SPLASH="/etc/bootsplash/themes/Slack-Black-Tux/config/bootsplash-1024x768.cfg"
+BUILD=${BUILD:=1rha}
+KERNEL_VERSION=${KERNEL_VERSION:=2.6.18}
+EXTRAVERSION=${EXTRAVERSION:=1}
+PATCH_VERSION=${PATCH_VERSION:=3.1.6-2.6.15}
+REALTIME_PATCH=${REALTIME_PATCH:=rt-lsm-0.8.7-kernel.patch}
+TMP=${TMP:=/tmp}
+SRC_DIR=${SRC:=$CWD}
+REPOS=${REPOS:=$TMP}
+
+# ------- error codes for createpkg --------------
+ERROR_WGET=31; ERROR_MAKE=32; ERROR_INSTALL=33
+ERROR_MD5=34; ERROR_CONF=35; ERROR_HELP=36
+ERROR_TAR=37; ERROR_MKPKG=38; ERROR_GPG=39
+ERROR_PATCH=40
+
+if [ ! -f "$SPLASH" ]; then
+ echo error: file not found: $SPLASH
+ exit 1
+fi
+
+if [ ! -z "$EXTRAVERSION" ]; then
+ KERNEL_VERSION="$KERNEL_VERSION.$EXTRAVERSION"
+fi
+
+RTOOL="wget"
+KERNEL="linux-$KERNEL_VERSION.tar.bz2"
+PATCH="bootsplash-$PATCH_VERSION.diff"
+KERNEL_URL="http://www.kernel.org/pub/linux/kernel/v2.6/$KERNEL"
+PATCH_URL="ftp://ftp.openbios.org/pub/bootsplash/kernel/$PATCH"
+
+SRC_DIR="$SRC_DIR/kernel"
+mkdir -p $SRC_DIR
+
+if [ "$RTOOL" == "wget" ]; then
+
+ if [ ! -f "$SRC_DIR/$KERNEL" ]; then
+ rm -f $SRC_DIR/$KERNEL.sign
+ wget "$KERNEL_URL" -O "$SRC_DIR/$KERNEL" || exit $ERROR_WGET
+ wget "$KERNEL_URL.sign" -O "$SRC_DIR/$KERNEL.sign" || exit $ERROR_WGET
+ fi
+
+ if [ ! -f "$SRC_DIR/$PATCH" ]; then
+ wget "$PATCH_URL" -O "$SRC_DIR/$PATCH" || exit $ERROR_WGET
+ fi
+
+fi
+
+TMP="$TMP/$PACKAGE"
+rm -rf $TMP
+mkdir -p $TMP
+cd $TMP
+
+rm -rf linux-$KERNEL_VERSION*
+tar jxvf $SRC_DIR/$KERNEL || exit $ERROR_TAR
+
+if [ ! -z "$PATCHSET" ]; then
+ mv linux-$KERNEL_VERSION linux-$KERNEL_VERSION-$PATCHSET
+ KERNEL_VERSION="$KERNEL_VERSION-$PATCHSET"
+fi
+
+cp $CWD/config-$KERNEL_VERSION linux-$KERNEL_VERSION/.config
+cd linux-$KERNEL_VERSION
+
+if [ ! -z "$EXTRAVERSION" ] && [ ! -z "$PATCHSET" ]; then
+ sed -e "s/^EXTRAVERSION =.*$/EXTRAVERSION = \.$EXTRAVERSION-$PATCHSET/" Makefile > Makefile.tmp
+elif [ ! -z "$PATCHSET" ]; then
+ sed -e "s/^EXTRAVERSION =*$/EXTRAVERSION = -$PATCHSET/" Makefile > Makefile.tmp
+fi
+
+mv Makefile.tmp Makefile
+patch -p1 < $CWD/$REALTIME_PATCH || exit $ERROR_PATCH
+patch -p1 < $SRC_DIR/$PATCH || exit $ERROR_TAR
+
+make oldconfig || exit $ERROR_MAKE
+time make || exit $ERROR_MAKE
+
+if [ -d "/lib/modules/$KERNEL_VERSION" ]; then
+ ( cd /lib/modules && mv $KERNEL_VERSION $KERNEL_VERSION.old )
+fi
+
+make modules_install || exit $ERROR_INSTALL
+
+# make the package
+
+CWD="`pwd`"
+
+PKG="$TMP/package-$PACKAGE"
+
+mkdir -p $PKG/{install,boot,lib/modules,usr/doc}
+
+cp -Rp /lib/modules/$KERNEL_VERSION $PKG/lib/modules
+
+if [ -d "/lib/modules/$KERNEL_VERSION.old" ]; then
+ ( cd /lib/modules && mv $KERNEL_VERSION $KERNEL_VERSION.delete && mv $KERNEL_VERSION.old $KERNEL_VERSION && rm -rf $KERNEL_VERSION.delete )
+fi
+
+cp System.map $PKG/boot/System.map-$KERNEL_VERSION
+cp .config $PKG/boot/config-$KERNEL_VERSION
+cp arch/$ARCH/boot/bzImage $PKG/boot/vmlinuz-$KERNEL_VERSION
+
+cat << EOF > $PKG/install/slack-desc
+kernel-ratten: kernel-ratten (linux kernel $KERNEL_VERSION for ratten AMD64 workstation)
+kernel-ratten:
+kernel-ratten: This is the kernel for the RATTEN workstation.
+kernel-ratten:
+kernel-ratten:
+kernel-ratten:
+kernel-ratten:
+kernel-ratten:
+kernel-ratten:
+kernel-ratten:
+kernel-ratten:
+EOF
+
+VERSION="`echo $KERNEL_VERSION | sed -e 's/-/_/g'`"
+
+# docs
+mkdir -p $PKG/usr/doc/$PACKAGE-$VERSION
+# cp -r Documentation $PKG/usr/doc/$PACKAGE-$VERSION/
+for file in COPYING CREDITS MAINTAINERS README REPORTING-BUGS; do
+ cp $CWD/$file* $PKG/usr/doc/$PACKAGE-$VERSION/
+done
+
+mkinitrd -c -k $KERNEL_VERSION -o $PKG/boot/initrd.gz
+splash -s -f $SPLASH > $PKG/boot/initrd.gz
+
+cd $PKG
+
+( cd boot && ln -s vmlinuz-$KERNEL_VERSION vmlinuz )
+( cd boot && ln -s config-$KERNEL_VERSION config )
+( cd boot && ln -s System.map-$KERNEL_VERSION System.map )
+
+makepkg -c y -l y $REPOS/$PACKAGE-$VERSION-$ARCH-$BUILD.tgz || exit $ERROR_MKPKG
+
+if [ "$CLEANUP" == "yes" ]; then
+ rm -rf $TMP
+fi
+