summaryrefslogtreecommitdiffstats
path: root/source/k/build-all-kernels.sh
diff options
context:
space:
mode:
Diffstat (limited to 'source/k/build-all-kernels.sh')
-rwxr-xr-xsource/k/build-all-kernels.sh147
1 files changed, 147 insertions, 0 deletions
diff --git a/source/k/build-all-kernels.sh b/source/k/build-all-kernels.sh
new file mode 100755
index 000000000..b1ea68907
--- /dev/null
+++ b/source/k/build-all-kernels.sh
@@ -0,0 +1,147 @@
+#!/bin/sh
+
+# Copyright 2018 Patrick J. Volkerding, Sebeka, Minnesota, USA
+# 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.
+
+# This script uses the SlackBuild scripts present here to build a
+# complete set of kernel packages for the currently running architecture.
+# It needs to be run once on 64-bit (uname -m = x86_64) and once on IA32
+# (uname -m = i586 or i686).
+
+cd $(dirname $0) ; CWD=$(pwd)
+
+BUILD=${BUILD:-1}
+if [ -z "$VERSION" ]; then
+ # Get $VERSION from the newest kernel tarball:
+ VERSION=${VERSION:-$(/bin/ls -t linux-*.tar.?z | head -n 1 | rev | cut -f 3- -d . | cut -f 1 -d - | rev)}
+fi
+TMP=${TMP:-/tmp}
+
+# By default, install the packages as we build them and update the initrd.
+INSTALL_PACKAGES=${INSTALL_PACKAGES:-YES}
+
+# A list of recipes for build may be passed in the $RECIPES variable, otherwise
+# we have defaults based on uname -m:
+if [ -z "$RECIPES" ]; then
+ if uname -m | grep -wq x86_64 ; then
+ RECIPES="x86_64"
+ elif uname -m | grep -wq i.86 ; then
+ RECIPES="IA32_NO_SMP IA32_SMP"
+ else
+ echo "Error: no build recipes available for $(uname -m)"
+ exit 1
+ fi
+fi
+
+# Main build loop:
+for recipe in $RECIPES ; do
+
+ # Build recipes are defined here. These will select the appropriate .config
+ # files and package naming scheme, and define the output location.
+ if [ "$recipe" = "x86_64" ]; then
+ # Recipe for x86_64:
+ CONFIG_SUFFIX=".x64"
+ unset LOCALVERSION
+ OUTPUT=${OUTPUT:-${TMP}/output-x86_64-${VERSION}}
+ elif [ "$recipe" = "IA32_SMP" ]; then
+ # Recipe for IA32_SMP:
+ unset CONFIG_SUFFIX
+ LOCALVERSION="-smp"
+ OUTPUT=${OUTPUT:-${TMP}/output-ia32-${VERSION}}
+ elif [ "$recipe" = "IA32_NO_SMP" ]; then
+ # Recipe for IA32_NO_SMP:
+ unset CONFIG_SUFFIX
+ unset LOCALVERSION
+ OUTPUT=${OUTPUT:-${TMP}/output-ia32-${VERSION}}
+ else
+ echo "Error: recipe ${recipe} not implemented"
+ exit 1
+ fi
+
+ echo
+ echo "*************************************************"
+ echo "* Building kernels for recipe ${recipe}..."
+ echo "*************************************************"
+ echo
+ sleep 3
+
+ # Build kernel-source package:
+ KERNEL_SOURCE_PACKAGE_NAME=$(PRINT_PACKAGE_NAME=YES KERNEL_CONFIG="config-generic${LOCALVERSION}-${VERSION}${LOCALVERSION}${CONFIG_SUFFIX}" VERSION=$VERSION BUILD=$BUILD ./kernel-source.SlackBuild)
+ KERNEL_CONFIG="config-generic${LOCALVERSION}-${VERSION}${LOCALVERSION}${CONFIG_SUFFIX}" VERSION=$VERSION BUILD=$BUILD ./kernel-source.SlackBuild
+ mkdir -p $OUTPUT
+ mv ${TMP}/${KERNEL_SOURCE_PACKAGE_NAME} $OUTPUT || exit 1
+ if [ "${INSTALL_PACKAGES}" = "YES" ]; then
+ installpkg ${OUTPUT}/${KERNEL_SOURCE_PACKAGE_NAME} || exit 1
+ fi
+
+ # Build kernel-huge package:
+ # We will build in the just-built kernel tree. First, let's put back the
+ # symlinks:
+ ( cd $TMP/package-kernel-source
+ sh install/doinst.sh
+ )
+ KERNEL_HUGE_PACKAGE_NAME=$(PRINT_PACKAGE_NAME=YES KERNEL_NAME=huge KERNEL_SOURCE=$TMP/package-kernel-source/usr/src/linux KERNEL_CONFIG=./kernel-configs/config-huge${LOCALVERSION}-${VERSION}${LOCALVERSION}${CONFIG_SUFFIX} CONFIG_SUFFIX=${CONFIG_SUFFIX} KERNEL_OUTPUT_DIRECTORY=$OUTPUT/kernels/huge$(echo ${LOCALVERSION} | tr -d -).s BUILD=$BUILD ./kernel-generic.SlackBuild)
+ KERNEL_NAME=huge KERNEL_SOURCE=$TMP/package-kernel-source/usr/src/linux KERNEL_CONFIG=./kernel-configs/config-huge${LOCALVERSION}-${VERSION}${LOCALVERSION}${CONFIG_SUFFIX} CONFIG_SUFFIX=${CONFIG_SUFFIX} KERNEL_OUTPUT_DIRECTORY=$OUTPUT/kernels/huge$(echo ${LOCALVERSION} | tr -d -).s BUILD=$BUILD ./kernel-generic.SlackBuild
+ mv ${TMP}/${KERNEL_HUGE_PACKAGE_NAME} $OUTPUT || exit 1
+ if [ "${INSTALL_PACKAGES}" = "YES" ]; then
+ installpkg ${OUTPUT}/${KERNEL_HUGE_PACKAGE_NAME} || exit 1
+ fi
+
+ # Build kernel-generic package:
+ KERNEL_GENERIC_PACKAGE_NAME=$(PRINT_PACKAGE_NAME=YES KERNEL_NAME=generic KERNEL_SOURCE=$TMP/package-kernel-source/usr/src/linux KERNEL_CONFIG=./kernel-configs/config-generic${LOCALVERSION}-${VERSION}${LOCALVERSION}${CONFIG_SUFFIX} CONFIG_SUFFIX=${CONFIG_SUFFIX} KERNEL_OUTPUT_DIRECTORY=$OUTPUT/kernels/generic$(echo ${LOCALVERSION} | tr -d -).s BUILD=$BUILD ./kernel-generic.SlackBuild)
+ KERNEL_NAME=generic KERNEL_SOURCE=$TMP/package-kernel-source/usr/src/linux KERNEL_CONFIG=./kernel-configs/config-generic${LOCALVERSION}-${VERSION}${LOCALVERSION}${CONFIG_SUFFIX} CONFIG_SUFFIX=${CONFIG_SUFFIX} KERNEL_OUTPUT_DIRECTORY=$OUTPUT/kernels/generic$(echo ${LOCALVERSION} | tr -d -).s BUILD=$BUILD ./kernel-generic.SlackBuild
+ mv ${TMP}/${KERNEL_GENERIC_PACKAGE_NAME} $OUTPUT || exit 1
+ if [ "${INSTALL_PACKAGES}" = "YES" ]; then
+ installpkg ${OUTPUT}/${KERNEL_GENERIC_PACKAGE_NAME} || exit 1
+ fi
+
+ # Build kernel-modules (for the just built generic kernel, but most of them
+ # will also work with the huge kernel):
+ KERNEL_MODULES_PACKAGE_NAME=$(PRINT_PACKAGE_NAME=YES KERNEL_SOURCE=$TMP/package-kernel-source/usr/src/linux KERNEL_CONFIG=$TMP/package-kernel-source/usr/src/linux/.config BUILD=$BUILD ./kernel-modules.SlackBuild)
+ KERNEL_SOURCE=$TMP/package-kernel-source/usr/src/linux KERNEL_CONFIG=$TMP/package-kernel-source/usr/src/linux/.config BUILD=$BUILD ./kernel-modules.SlackBuild
+ mv ${TMP}/${KERNEL_MODULES_PACKAGE_NAME} $OUTPUT || exit 1
+ if [ "${INSTALL_PACKAGES}" = "YES" ]; then
+ installpkg ${OUTPUT}/${KERNEL_MODULES_PACKAGE_NAME} || exit 1
+ fi
+
+ # Build kernel-headers:
+ KERNEL_HEADERS_PACKAGE_NAME=$(PRINT_PACKAGE_NAME=YES KERNEL_SOURCE=$TMP/package-kernel-source/usr/src/linux BUILD=$BUILD ./kernel-headers.SlackBuild)
+ KERNEL_SOURCE=$TMP/package-kernel-source/usr/src/linux BUILD=$BUILD ./kernel-headers.SlackBuild
+ mv ${TMP}/${KERNEL_HEADERS_PACKAGE_NAME} $OUTPUT || exit 1
+ if [ "${INSTALL_PACKAGES}" = "YES" ]; then
+ upgradepkg --reinstall --install-new ${OUTPUT}/${KERNEL_HEADERS_PACKAGE_NAME} || exit 1
+ fi
+
+ # Update initrd:
+ if [ "${INSTALL_PACKAGES}" = "YES" ]; then
+ # We should already have this...
+ #LOCALVERSION="$(cat $TMP/package-kernel-source/usr/src/linux/.config 2> /dev/null | grep CONFIG_LOCALVERSION= | cut -f 2 -d = | tr -d \")"
+ if [ -r /etc/mkinitrd.conf ]; then
+ mkinitrd -F /etc/mkinitrd.conf -k ${VERSION}${LOCALVERSION}
+ else # try this?
+ sh /usr/share/mkinitrd/mkinitrd_command_generator.sh -k ${VERSION}${LOCALVERSION} | sed "s/-c -k/-k/g" | bash
+ fi
+ fi
+
+ echo
+ echo "${recipe} kernel packages done!"
+ echo
+
+done