rhel6.6) target="2.6-rhel6.6";;
rhel6*) target="2.6-rhel6";;
rhel7*) target="3.10-rhel7";;
+ rhel8*) target="4.18-rhel8";;
sles10*) target="2.6-sles10";;
sles11.4) target="$(uname -r | cut -d . -f 1,2)-sles11sp4";;
sles11.3) target="$(uname -r | cut -d . -f 1,2)-sles11sp3";;
3.12-sles12 | 4.4-sles12)
CANONICAL_TARGET="sles12"
;;
+ 4.18-rhel8*)
+ CANONICAL_TARGET="rhel8"
+ ;;
3.10-rhel7*)
CANONICAL_TARGET="rhel7"
;;
--- /dev/null
+# vim:expandtab:shiftwidth=4:softtabstop=4:tabstop=4:
+
+source ${LBUILD_DIR}/lbuild-rhel
+
+# increment this if you have made a change that should force a new kernel
+# to build built
+BUILD_GEN+=".0"
+
+SPEC_NAME="kernel.spec"
+DEVEL_PATH_ARCH_DELIMETER="."
+USE_KABI=false
+
+# force local definition of %dist into ~/.rpmmacros
+# to avoid verbose extended strings like ".el8.centos"
+# in kernel version and rpm names
+#
+RMAC=$HOME/.rpmmacros
+grep '^%dist' $RMAC &> /dev/null || echo '%dist .el8' >> $RMAC
+
+# We modify the RHEL8 kmodtool script, because it expects
+# the kernel source to be in the correct packaged RHEL location.
+# lbuild does not put the source in correct packaged RHEL location.
+RHEL_KMODTOOL=/usr/lib/rpm/redhat/kmodtool
+LBUILD_KMODTOOL="${LBUILD_DIR}/rhel8/kmodtool"
+cp $RHEL_KMODTOOL $LBUILD_KMODTOOL
+pushd ${LBUILD_DIR}/rhel8
+patch -p1 < kmodtool.patch
+# Replace the hardcoded /usr/src/kernels with our build path
+tmp="${TOPDIR}/reused/usr/src/kernels"
+tmp="${tmp//\//\\/}"
+sed -i "s/\/usr\/src\/kernels/${tmp}/g" ${LBUILD_DIR}/rhel8/kmodtool
+chmod 755 kmodtool
+popd
+# Next we replace %kernel_module_package with one that is nearly
+# identical, but calls lbuild's modified kmodtool script.
+# We need to cleanout the previous entry
+sed -i "/^%kernel_module_package/,/^)}$/d" $RMAC
+sed -e "s|REPLACE_ME|$LBUILD_KMODTOOL|" -e "s/\/usr\/src\/kernels/${tmp}/g" \
+ ${LBUILD_DIR}/rhel8/rpmmacros.template > ${LBUILD_DIR}/rhel8/rpmmacros
+cat ${LBUILD_DIR}/rhel8/rpmmacros >> $RMAC
+
+patch_spec() {
+ local buildid="$1"
+
+ # the el8 .spec file requires patch names to begin with "patch-3."
+ # so rename the lustre patch from lbuild to one the .spec will like
+ mv $TOPDIR/SOURCES/linux-${lnxmaj}-lustre.patch \
+ $TOPDIR/SOURCES/patch-${lnxmaj}-lustre.patch
+
+ # edit the SPEC with our changes
+ patch_spec_common "$buildid"
+ sed -i -e '/^# empty final patch to facilitate testing of kernel patches/i\
+# adds Lustre patches\
+Patch99995: patch-%{version}-lustre.patch' \
+ -e '/^ApplyOptionalPatch linux-kernel-test.patch/i\
+\
+# lustre patch\
+ApplyOptionalPatch patch-%{version}-lustre.patch\
+' \
+ -e '/rm -f include\/generated\/kernel.cross/i\
+ # lustre kernel config.\
+ if [ -f %{_topdir}/lustre/lustre/kernel_patches/kernel_configs/kernel-%{version}-4.18-rhel8-%{_target_cpu}.config ]; then\
+ echo "# $Arch" > configs/kernel-%{version}-%{_target_cpu}.config\
+ cat %{_topdir}/lustre/lustre/kernel_patches/kernel_configs/kernel-%{version}-4.18-rhel8-%{_target_cpu}.config >> configs/kernel-%{version}-%{_target_cpu}.config\
+ fi'\
+ -e '/^# Dynamically generate kernel/a echo "CONFIG_BH_LRU_SIZE=16" >> config-generic'\
+ -e '/^%define listnewconfig_fail 1/s/1/0/'\
+ SPECS/$SPEC_NAME 2>&1 || \
+ fatal 1 "Error while editing SPECS/$SPEC_NAME"
+
+
+ return 0
+
+}
+
+unpack_linux_devel_rpm-rhel8() {
+ local callers_rpm="$1"
+
+ unpack_linux_devel_rpm-rhel "$callers_rpm"
+
+
+ return 0
+
+}
+
+get_rpmbuildopts() {
+
+ if $KERNEL_LUSTRE_NAMING; then
+ echo -e "--define \"variant -lustre\" \c"
+ fi
+ echo "--with firmware"
+
+ return 0
+
+}
+
+find_linux_rpm-rhel8() {
+ local prefix="$1"
+ local wanted_kernel="$2"
+ local pathtorpms=${3:-"$KERNELRPMSBASE/$lnxmaj/$DISTROMAJ/$TARGET_ARCH"}
+
+ find_linux_rpm-rhel "$prefix" "$wanted_kernel" "$pathtorpms"
+
+}
+
+kernel_srpm_location() {
+
+ echo "http://vault.centos.org/centos/8/updates/Source/SPackages/"
+
+}
+
+kernel_debuginfo_location() {
+
+ echo "http://debuginfo.centos.org/8/x86_64/"
+
+}
+
+cleanup_rpmmacros() {
+ sed -i "/^%kernel_module_package/,/^)}$/d" $RMAC
+}
+
+apply_kmod_requires_conflicts() {
+ if $PATCHLESS; then
+ # don't allow the patched kernel to be considered as a valid kernel
+ # for the patchless client
+ echo "Conflicts: kernel-lustre" >> rpm/kmp-lustre.preamble
+ fi
+}
--- /dev/null
+kmodtool
+rpmmacros
--- /dev/null
+lbuild does not install the kernel source in the standard RHEL7 location.
+RHEL's kmodtool (starting in RHEL7) expects the source to be in the standard
+location, and when it fails to find it it adds an extra $arch onto the end
+of verrel. With lbuild, verrel already contains the arch, so we change the
+kmodtool script so that it does not add another.
+
+--- old/kmodtool 2016-06-07 14:36:20.810907740 -0700
++++ new/kmodtool 2016-06-07 14:37:55.335652424 -0700
+@@ -62,7 +62,7 @@ get_kernel_release ()
+ local versuffix=${verrel#$verprefix}
+ verrel=$(ls -Ud /usr/src/kernels/$verprefix*$versuffix.$arch | sort -V | tail -n 1)
+ verrel=${verrel##*/}
+- [[ -z $verrel ]] && verrel=$1.$arch
++ [[ -z $verrel ]] && verrel=$1
+ echo "$verrel"
+ }
+
--- /dev/null
+%kernel_module_package(n:v:r:s:f:xp:) %{expand:%( \
+ %global kmodtool %{-s*}%{!-s:REPLACE_ME} \
+ %global kmod_version %{-v*}%{!-v:%{version}} \
+ %global kmod_release %{-r*}%{!-r:%{release}} \
+ %global latest_kernel %(rpm -q --qf '%{VERSION}-%{RELEASE}.%{ARCH}\\\\n' `rpm -q kernel-devel | /usr/lib/rpm/redhat/rpmsort -r | head -n 1` | head -n 1) \
+ %{!?kernel_version:%{expand:%%global kernel_version %{latest_kernel}}} \
+ %global kverrel %(%{kmodtool} verrel %{?kernel_version} 2>/dev/null) \
+ flavors="default" \
+ if [ -z "%*" ]; then \
+ flavors_to_build=$flavors \
+ elif [ -z "%{-x}" ]; then \
+ flavors_to_build="%*" \
+ else \
+ flavors_to_build=" $flavors "\
+ for i in %* \
+ do \
+ flavors_to_build=${flavors_to_build//$i /}
+ done \
+ fi \
+ echo "%%global flavors_to_build ${flavors_to_build:-%%nil}" \
+ echo "%%global kernel_source() /usr/src/kernels/%kverrel\\\$([ %%%%{1} = default ] || echo ".%%%%{1}")" \
+ echo "%%global kernel_module_package_moddir() extra" \
+ if [ ! -z "%{-f*}" ] \
+ then \
+ filelist="%{-f*}" \
+ fi \
+ if [ ! -z "%{-p*}" ] \
+ then \
+ preamble="%{-p*}" \
+ fi \
+ if [ -z "%{kmodtool_generate_buildreqs}" ] \
+ then \
+ nobuildreqs="yes" \
+ fi \
+ override_filelist="$filelist" override_preamble="$preamble" nobuildreqs="$nobuildreqs" kmod_version=%kmod_version kmod_release=%kmod_release %{kmodtool} rpmtemplate %{-n*}%{!-n:%name} %{kverrel} $flavors_to_build 2>/dev/null \
+)}
-#!/usr/bin/env python
+#!/usr/bin/env python2
#
# GPL HEADER START
#
%if %{_vendor}=="redhat" || %{_vendor}=="fedora"
%global kmod_name kmod-%{lustre_name}
- %define mkconf_options
+ %define mkconf_options %{nil}
%else #for Suse / Ubuntu
%global kmod_name %{lustre_name}-kmp
%define mkconf_options "-k updates"
+TBD Whamcloud
+ * version 2.12.3
+ * See https://wiki.whamcloud.com/display/PUB/Lustre+Support+Matrix
+ for currently supported client and server kernel versions.
+ * Server known to build on the following kernels (others may also work):
+ 2.6.32-696.18.7.el6 (RHEL6.9)
+ 3.10.0-862.14.4.el7 (RHEL7.5)
+ 3.10.0-957.10.1.el7 (RHEL7.6)
+ 4.4.120-92.70 (SLES12 SP2)
+ 4.4.162-94.69 (SLES12 SP3)
+ 4.4.0-142 (Ubuntu 16.04)
+ 4.15.0-45 (Ubuntu 18.04)
+ vanilla linux 4.6.7 (ZFS only)
+ * ldiskfs needs an ldiskfs patch series for that kernel, ZFS does not
+ * Client known to build on unpatched kernels (others may also work):
+ 2.6.32-696.18.7.el6 (RHEL6.9)
+ 2.6.32-754.6.3.el6 (RHEL6.10)
+ 3.10.0-862.14.4.el7 (RHEL7.5)
+ 3.10.0-957.10.1.el7 (RHEL7.6)
+ 4.14.0-49.13.1.el7a (RHEL7.5)
+ 4.14.0-115.2.2.el7a (RHEL7.6)
+ 4.18.0-80.el8 (RHEL8.0)
+ 4.4.120-92.70 (SLES12 SP2)
+ 4.4.162-94.69 (SLES12 SP3)
+ 4.12.14-95.13 (SLES12 SP4)
+ 4.4.0-142 (Ubuntu 16.04)
+ 4.15.0-45 (Ubuntu 18.04)
+ vanilla linux 4.15.0 (ZFS only)
+ * Recommended e2fsprogs version: 1.44.5.wc1 or newer
+ * Recommended ZFS / SPL version: 0.7.13
+ * NFS export disabled when stack size < 8192 (32-bit Lustre clients),
+ since the NFSv4 export of Lustre filesystem with 4K stack may cause a
+ stack overflow. For more information, please refer to bugzilla 17630.
+ * NFSv4 reexport to 32-bit NFS client nodes requires Lustre client on
+ the re-exporting nodes to be mounted with "32bitapi" mount option
+ * Note for Ubuntu 14.04.5:
+ The 4.4.0 series is the HWE Kernel derived from 16.04 (Xenial).
+ See: https://wiki.ubuntu.com/Kernel/LTSEnablementStack
+
2019-05-26 Whamcloud
* version 2.12.2
* See https://wiki.whamcloud.com/display/PUB/Lustre+Support+Matrix
lustre/include/Makefile
lustre/include/lustre/Makefile
lustre/include/uapi/linux/lustre/Makefile
+lustre/kernel_patches/targets/4.18-rhel8.target
lustre/kernel_patches/targets/3.10-rhel7.6.target
lustre/kernel_patches/targets/3.10-rhel7.5.target
lustre/kernel_patches/targets/4.14-rhel7.5.target
--- /dev/null
+lnxmaj="4.18.0"
+lnxrel="80.el8"
+
+KERNEL_SRPM=kernel-${lnxmaj}-${lnxrel}.src.rpm
+SERIES=""
+EXTRA_VERSION=${lnxrel}_lustre.@VERSION@
+LUSTRE_VERSION=@VERSION@
+
+DEVEL_PATH_ARCH_DELIMETER="."
+OFED_VERSION=inkernel
+
+BASE_ARCHS="i686 x86_64 ia64 ppc64"
+BIGMEM_ARCHS=""
+BOOT_ARCHS=""
+JENSEN_ARCHS=""
+#SMP_ARCHS="i686 x86_64 ia64 ppc64"
+# RHEL8 doesn't use smp specific kernels
+SMP_ARCHS=""
+UP_ARCHS=""
+
+for cc in gcc ; do
+ if which $cc >/dev/null 2>/dev/null ; then
+ export CC=$cc
+ break
+ fi
+done
-#!/usr/bin/env python
+#!/usr/bin/env python2
# Copyright (c) 2014, Lawrence Livermore National Security, LLC.
# Produced at the Lawrence Livermore National Laboratory.