2022-12-20 13:42:38 +00:00
|
|
|
{ lib, stdenv, buildPackages, runCommand, nettools, bc, bison, flex, perl, rsync, gmp, libmpc, mpfr, openssl
|
2022-03-31 18:11:26 +00:00
|
|
|
, libelf, cpio, elfutils, zstd, python3Minimal, zlib, pahole
|
2022-09-23 21:23:31 +00:00
|
|
|
, fetchpatch
|
2017-04-29 23:52:17 +00:00
|
|
|
}:
|
2012-07-29 05:23:51 +00:00
|
|
|
|
|
|
|
let
|
2022-12-20 13:42:38 +00:00
|
|
|
lib_ = lib;
|
|
|
|
stdenv_ = stdenv;
|
|
|
|
|
2014-01-01 03:46:43 +00:00
|
|
|
readConfig = configfile: import (runCommand "config.nix" {} ''
|
|
|
|
echo "{" > "$out"
|
|
|
|
while IFS='=' read key val; do
|
|
|
|
[ "x''${key#CONFIG_}" != "x$key" ] || continue
|
|
|
|
no_firstquote="''${val#\"}";
|
|
|
|
echo ' "'"$key"'" = "'"''${no_firstquote%\"}"'";' >> "$out"
|
|
|
|
done < "${configfile}"
|
|
|
|
echo "}" >> $out
|
|
|
|
'').outPath;
|
2022-12-20 13:42:38 +00:00
|
|
|
in lib.makeOverridable ({
|
2012-07-29 08:31:40 +00:00
|
|
|
# The kernel version
|
|
|
|
version,
|
2021-10-27 21:53:14 +00:00
|
|
|
# Position of the Linux build expression
|
|
|
|
pos ? null,
|
2021-07-12 04:58:16 +00:00
|
|
|
# Additional kernel make flags
|
|
|
|
extraMakeFlags ? [],
|
2022-12-21 11:49:37 +00:00
|
|
|
# The name of the kernel module directory
|
|
|
|
# Needs to be X.Y.Z[-extra], so pad with zeros if needed.
|
|
|
|
modDirVersion ? lib.versions.pad 3 version,
|
2012-07-29 08:31:40 +00:00
|
|
|
# The kernel source (tarball, git checkout, etc.)
|
|
|
|
src,
|
2016-01-05 14:22:43 +00:00
|
|
|
# a list of { name=..., patch=..., extraConfig=...} patches
|
2012-08-02 03:02:17 +00:00
|
|
|
kernelPatches ? [],
|
2017-10-28 19:09:54 +00:00
|
|
|
# The kernel .config file
|
2012-08-01 10:18:03 +00:00
|
|
|
configfile,
|
|
|
|
# Manually specified nixexpr representing the config
|
2012-07-29 08:52:34 +00:00
|
|
|
# If unspecified, this will be autodetected from the .config
|
2021-01-15 14:45:37 +00:00
|
|
|
config ? lib.optionalAttrs allowImportFromDerivation (readConfig configfile),
|
2019-01-12 00:34:33 +00:00
|
|
|
# Custom seed used for CONFIG_GCC_PLUGIN_RANDSTRUCT if enabled. This is
|
|
|
|
# automatically extended with extra per-version and per-config values.
|
|
|
|
randstructSeed ? "",
|
2022-12-21 11:49:37 +00:00
|
|
|
# Extra meta attributes
|
2017-12-04 08:33:39 +00:00
|
|
|
extraMeta ? {},
|
2020-11-01 22:05:38 +00:00
|
|
|
|
|
|
|
# for module compatibility
|
|
|
|
isZen ? false,
|
|
|
|
isLibre ? false,
|
|
|
|
isHardened ? false,
|
|
|
|
|
2012-07-29 17:26:39 +00:00
|
|
|
# Whether to utilize the controversial import-from-derivation feature to parse the config
|
2018-01-28 18:50:18 +00:00
|
|
|
allowImportFromDerivation ? false,
|
2018-03-23 09:08:06 +00:00
|
|
|
# ignored
|
2022-12-20 13:42:38 +00:00
|
|
|
features ? null, lib ? lib_, stdenv ? stdenv_,
|
2012-07-29 08:31:40 +00:00
|
|
|
}:
|
|
|
|
|
2012-07-29 08:48:50 +00:00
|
|
|
let
|
2021-01-15 14:45:37 +00:00
|
|
|
inherit (lib)
|
2018-02-15 16:27:25 +00:00
|
|
|
hasAttr getAttr optional optionals optionalString optionalAttrs maintainers platforms;
|
2014-01-01 03:46:43 +00:00
|
|
|
|
2017-12-28 08:11:36 +00:00
|
|
|
# Dependencies that are required to build kernel modules
|
2023-01-13 19:15:08 +00:00
|
|
|
moduleBuildDependencies = [
|
|
|
|
perl
|
|
|
|
libelf
|
|
|
|
# module makefiles often run uname commands to find out the kernel version
|
|
|
|
(buildPackages.deterministic-uname.override { inherit modDirVersion; })
|
|
|
|
] ++ optional (lib.versionAtLeast version "5.13") zstd;
|
2017-12-28 08:11:36 +00:00
|
|
|
|
2021-01-23 01:33:55 +00:00
|
|
|
drvAttrs = config_: kernelConf: kernelPatches: configfile:
|
2014-01-01 04:09:42 +00:00
|
|
|
let
|
|
|
|
config = let attrName = attr: "CONFIG_" + attr; in {
|
|
|
|
isSet = attr: hasAttr (attrName attr) config;
|
2012-08-12 01:21:06 +00:00
|
|
|
|
2014-01-01 04:09:42 +00:00
|
|
|
getValue = attr: if config.isSet attr then getAttr (attrName attr) config else null;
|
|
|
|
|
|
|
|
isYes = attr: (config.getValue attr) == "y";
|
|
|
|
|
|
|
|
isNo = attr: (config.getValue attr) == "n";
|
|
|
|
|
|
|
|
isModule = attr: (config.getValue attr) == "m";
|
|
|
|
|
|
|
|
isEnabled = attr: (config.isModule attr) || (config.isYes attr);
|
|
|
|
|
|
|
|
isDisabled = attr: (!(config.isSet attr)) || (config.isNo attr);
|
|
|
|
} // config_;
|
|
|
|
|
|
|
|
isModular = config.isYes "MODULES";
|
|
|
|
|
2021-10-14 17:41:32 +00:00
|
|
|
buildDTBs = kernelConf.DTB or false;
|
|
|
|
|
2016-04-16 18:27:04 +00:00
|
|
|
in (optionalAttrs isModular { outputs = [ "out" "dev" ]; }) // {
|
2021-11-07 11:07:14 +00:00
|
|
|
passthru = rec {
|
2018-02-11 10:58:08 +00:00
|
|
|
inherit version modDirVersion config kernelPatches configfile
|
|
|
|
moduleBuildDependencies stdenv;
|
2021-04-04 14:55:56 +00:00
|
|
|
inherit isZen isHardened isLibre;
|
|
|
|
isXen = lib.warn "The isXen attribute is deprecated. All Nixpkgs kernels that support it now have Xen enabled." true;
|
2021-11-07 11:07:14 +00:00
|
|
|
baseVersion = lib.head (lib.splitString "-rc" version);
|
|
|
|
kernelOlder = lib.versionOlder baseVersion;
|
|
|
|
kernelAtLeast = lib.versionAtLeast baseVersion;
|
2014-01-01 04:09:42 +00:00
|
|
|
};
|
|
|
|
|
2014-01-02 04:56:24 +00:00
|
|
|
inherit src;
|
2014-01-01 04:09:42 +00:00
|
|
|
|
2019-01-11 11:32:53 +00:00
|
|
|
patches =
|
|
|
|
map (p: p.patch) kernelPatches
|
|
|
|
# Required for deterministic builds along with some postPatch magic.
|
2022-10-23 16:28:32 +00:00
|
|
|
++ optional (lib.versionOlder version "5.19") ./randstruct-provide-seed.patch
|
2022-07-11 11:07:37 +00:00
|
|
|
++ optional (lib.versionAtLeast version "5.19") ./randstruct-provide-seed-5.19.patch
|
2022-09-23 21:23:31 +00:00
|
|
|
# Linux 5.12 marked certain PowerPC-only symbols as GPL, which breaks
|
|
|
|
# OpenZFS; this was fixed in Linux 5.19 so we backport the fix
|
|
|
|
# https://github.com/openzfs/zfs/pull/13367
|
|
|
|
++ optional (lib.versionAtLeast version "5.12" &&
|
|
|
|
lib.versionOlder version "5.19" &&
|
|
|
|
stdenv.hostPlatform.isPower)
|
|
|
|
(fetchpatch {
|
|
|
|
url = "https://git.kernel.org/pub/scm/linux/kernel/git/powerpc/linux.git/patch/?id=d9e5c3e9e75162f845880535957b7fd0b4637d23";
|
|
|
|
hash = "sha256-bBOyJcP6jUvozFJU0SPTOf3cmnTQ6ZZ4PlHjiniHXLU=";
|
|
|
|
});
|
2014-01-02 04:56:24 +00:00
|
|
|
|
2023-03-17 18:41:07 +00:00
|
|
|
preUnpack = ''
|
|
|
|
# The same preUnpack is used to build the configfile,
|
|
|
|
# which does not have $dev.
|
|
|
|
if [ -n "$dev" ]; then
|
|
|
|
mkdir -p $dev/lib/modules/${modDirVersion}
|
|
|
|
cd $dev/lib/modules/${modDirVersion}
|
|
|
|
fi
|
|
|
|
'';
|
|
|
|
|
|
|
|
postUnpack = ''
|
|
|
|
mv -Tv "$sourceRoot" source 2>/dev/null || :
|
|
|
|
export sourceRoot=$PWD/source
|
|
|
|
'';
|
|
|
|
|
2022-08-20 23:49:42 +00:00
|
|
|
postPatch = ''
|
2017-10-29 01:06:18 +00:00
|
|
|
sed -i Makefile -e 's|= depmod|= ${buildPackages.kmod}/bin/depmod|'
|
2020-12-23 15:31:05 +00:00
|
|
|
|
2022-08-21 08:07:58 +00:00
|
|
|
# fixup for pre-5.4 kernels using the $(cd $foo && /bin/pwd) pattern
|
|
|
|
# FIXME: remove when no longer needed
|
|
|
|
substituteInPlace Makefile tools/scripts/Makefile.include --replace /bin/pwd pwd
|
|
|
|
|
2020-12-23 15:31:05 +00:00
|
|
|
# Don't include a (random) NT_GNU_BUILD_ID, to make the build more deterministic.
|
|
|
|
# This way kernels can be bit-by-bit reproducible depending on settings
|
|
|
|
# (e.g. MODULE_SIG and SECURITY_LOCKDOWN_LSM need to be disabled).
|
|
|
|
# See also https://kernelnewbies.org/BuildId
|
2021-07-10 20:17:52 +00:00
|
|
|
sed -i Makefile -e 's|--build-id=[^ ]*|--build-id=none|'
|
2020-12-23 15:31:05 +00:00
|
|
|
|
2022-08-20 23:49:42 +00:00
|
|
|
# Some linux-hardened patches now remove certain files in the scripts directory, so the file may not exist.
|
|
|
|
[[ -f scripts/ld-version.sh ]] && patchShebangs scripts/ld-version.sh
|
2014-01-01 04:09:42 +00:00
|
|
|
|
2019-01-11 11:32:53 +00:00
|
|
|
# Set randstruct seed to a deterministic but diversified value. Note:
|
|
|
|
# we could have instead patched gen-random-seed.sh to take input from
|
|
|
|
# the buildFlags, but that would require also patching the kernel's
|
|
|
|
# toplevel Makefile to add a variable export. This would be likely to
|
|
|
|
# cause future patch conflicts.
|
2022-09-17 14:19:08 +00:00
|
|
|
for file in scripts/gen-randstruct-seed.sh scripts/gcc-plugins/gen-random-seed.sh; do
|
|
|
|
if [ -f "$file" ]; then
|
|
|
|
substituteInPlace "$file" \
|
|
|
|
--replace NIXOS_RANDSTRUCT_SEED \
|
2022-08-20 23:49:42 +00:00
|
|
|
$(echo ${randstructSeed}${src} ${placeholder "configfile"} | sha256sum | cut -d ' ' -f 1 | tr -d '\n')
|
2022-09-17 14:19:08 +00:00
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
2021-10-14 23:27:54 +00:00
|
|
|
|
|
|
|
patchShebangs scripts
|
2022-08-17 18:08:06 +00:00
|
|
|
|
|
|
|
# also patch arch-specific install scripts
|
|
|
|
for i in $(find arch -name install.sh); do
|
|
|
|
patchShebangs "$i"
|
|
|
|
done
|
2019-01-11 11:32:53 +00:00
|
|
|
'';
|
|
|
|
|
2014-01-01 04:09:42 +00:00
|
|
|
configurePhase = ''
|
|
|
|
runHook preConfigure
|
2018-01-28 18:50:18 +00:00
|
|
|
|
2023-03-17 18:40:11 +00:00
|
|
|
export buildRoot=$(mktemp -d)
|
2018-01-28 18:50:18 +00:00
|
|
|
|
|
|
|
echo "manual-config configurePhase buildRoot=$buildRoot pwd=$PWD"
|
|
|
|
|
|
|
|
if [ -f "$buildRoot/.config" ]; then
|
|
|
|
echo "Could not link $buildRoot/.config : file exists"
|
|
|
|
exit 1
|
|
|
|
fi
|
2014-01-01 04:09:42 +00:00
|
|
|
ln -sv ${configfile} $buildRoot/.config
|
2018-01-28 18:50:18 +00:00
|
|
|
|
|
|
|
# reads the existing .config file and prompts the user for options in
|
|
|
|
# the current kernel source that are not found in the file.
|
2014-01-01 04:09:42 +00:00
|
|
|
make $makeFlags "''${makeFlagsArray[@]}" oldconfig
|
|
|
|
runHook postConfigure
|
2014-04-14 19:06:04 +00:00
|
|
|
|
2018-07-24 19:38:47 +00:00
|
|
|
make $makeFlags "''${makeFlagsArray[@]}" prepare
|
2017-03-13 16:47:21 +00:00
|
|
|
actualModDirVersion="$(cat $buildRoot/include/config/kernel.release)"
|
|
|
|
if [ "$actualModDirVersion" != "${modDirVersion}" ]; then
|
2017-11-21 15:42:06 +00:00
|
|
|
echo "Error: modDirVersion ${modDirVersion} specified in the Nix expression is wrong, it should be: $actualModDirVersion"
|
2017-03-13 16:47:21 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2016-02-01 14:36:05 +00:00
|
|
|
buildFlagsArray+=("KBUILD_BUILD_TIMESTAMP=$(date -u -d @$SOURCE_DATE_EPOCH)")
|
2018-01-28 18:50:18 +00:00
|
|
|
|
|
|
|
cd $buildRoot
|
2014-01-01 04:09:42 +00:00
|
|
|
'';
|
|
|
|
|
2015-01-02 12:55:04 +00:00
|
|
|
buildFlags = [
|
2023-03-19 23:55:12 +00:00
|
|
|
"DTC_FLAGS=-@"
|
2013-08-13 12:26:35 +00:00
|
|
|
"KBUILD_BUILD_VERSION=1-NixOS"
|
2023-03-17 18:41:07 +00:00
|
|
|
|
|
|
|
# Set by default in the kernel since a73619a845d5,
|
|
|
|
# replicated here to apply to older versions.
|
|
|
|
# Makes __FILE__ relative to the build directory.
|
|
|
|
"KCPPFLAGS=-fmacro-prefix-map=$(sourceRoot)/="
|
2023-03-19 23:55:12 +00:00
|
|
|
] ++ extraMakeFlags;
|
2014-01-01 04:09:42 +00:00
|
|
|
|
|
|
|
installFlags = [
|
|
|
|
"INSTALL_PATH=$(out)"
|
|
|
|
] ++ (optional isModular "INSTALL_MOD_PATH=$(out)")
|
2021-10-14 17:41:32 +00:00
|
|
|
++ optionals buildDTBs ["dtbs_install" "INSTALL_DTBS_PATH=$(out)/dtbs"];
|
2014-01-01 04:09:42 +00:00
|
|
|
|
2022-08-19 20:55:28 +00:00
|
|
|
preInstall = let
|
|
|
|
# All we really need to do here is copy the final image and System.map to $out,
|
|
|
|
# and use the kernel's modules_install, firmware_install, dtbs_install, etc. targets
|
|
|
|
# for the rest. Easy, right?
|
|
|
|
#
|
|
|
|
# Unfortunately for us, the obvious way of getting the built image path,
|
|
|
|
# make -s image_name, does not work correctly, because some architectures
|
|
|
|
# (*cough* aarch64 *cough*) change KBUILD_IMAGE on the fly in their install targets,
|
|
|
|
# so we end up attempting to install the thing we didn't actually build.
|
|
|
|
#
|
|
|
|
# Thankfully, there's a way out that doesn't involve just hardcoding everything.
|
|
|
|
#
|
|
|
|
# The kernel has an install target, which runs a pretty simple shell script
|
|
|
|
# (located at scripts/install.sh or arch/$arch/boot/install.sh, depending on
|
|
|
|
# which kernel version you're looking at) that tries to do something sensible.
|
|
|
|
#
|
|
|
|
# (it would be great to hijack this script immediately, as it has all the
|
|
|
|
# information we need passed to it and we don't need it to try and be smart,
|
|
|
|
# but unfortunately, the exact location of the scripts differs between kernel
|
|
|
|
# versions, and they're seemingly not considered to be public API at all)
|
|
|
|
#
|
|
|
|
# One of the ways it tries to discover what "something sensible" actually is
|
|
|
|
# is by delegating to what's supposed to be a user-provided install script
|
|
|
|
# located at ~/bin/installkernel.
|
|
|
|
#
|
|
|
|
# (the other options are:
|
|
|
|
# - a distribution-specific script at /sbin/installkernel,
|
|
|
|
# which we can't really create in the sandbox easily
|
|
|
|
# - an architecture-specific script at arch/$arch/boot/install.sh,
|
|
|
|
# which attempts to guess _something_ and usually guesses very wrong)
|
|
|
|
#
|
|
|
|
# More specifically, the install script exec's into ~/bin/installkernel, if one
|
|
|
|
# exists, with the following arguments:
|
|
|
|
#
|
|
|
|
# $1: $KERNELRELEASE - full kernel version string
|
|
|
|
# $2: $KBUILD_IMAGE - the final image path
|
|
|
|
# $3: System.map - path to System.map file, seemingly hardcoded everywhere
|
|
|
|
# $4: $INSTALL_PATH - path to the destination directory as specified in installFlags
|
|
|
|
#
|
|
|
|
# $2 is exactly what we want, so hijack the script and use the knowledge given to it
|
|
|
|
# by the makefile overlords for our own nefarious ends.
|
|
|
|
#
|
|
|
|
# Note that the makefiles specifically look in ~/bin/installkernel, and
|
|
|
|
# writeShellScriptBin writes the script to <store path>/bin/installkernel,
|
|
|
|
# so HOME needs to be set to just the store path.
|
|
|
|
#
|
|
|
|
# FIXME: figure out a less roundabout way of doing this.
|
|
|
|
installkernel = buildPackages.writeShellScriptBin "installkernel" ''
|
|
|
|
cp -av $2 $4
|
|
|
|
cp -av $3 $4
|
|
|
|
'';
|
|
|
|
in ''
|
2019-12-15 15:04:53 +00:00
|
|
|
installFlagsArray+=("-j$NIX_BUILD_CORES")
|
2022-08-17 18:08:06 +00:00
|
|
|
export HOME=${installkernel}
|
2019-12-15 15:04:53 +00:00
|
|
|
'';
|
|
|
|
|
2014-01-01 04:09:42 +00:00
|
|
|
# Some image types need special install targets (e.g. uImage is installed with make uinstall)
|
2021-01-23 01:33:55 +00:00
|
|
|
installTargets = [
|
|
|
|
(kernelConf.installTarget or (
|
|
|
|
/**/ if kernelConf.target == "uImage" then "uinstall"
|
|
|
|
else if kernelConf.target == "zImage" || kernelConf.target == "Image.gz" then "zinstall"
|
|
|
|
else "install"))
|
|
|
|
];
|
2014-01-01 04:09:42 +00:00
|
|
|
|
2023-02-21 23:56:19 +00:00
|
|
|
postInstall = optionalString isModular ''
|
2019-10-31 16:50:15 +00:00
|
|
|
if [ -z "''${dontStrip-}" ]; then
|
2015-07-25 23:36:19 +00:00
|
|
|
installFlagsArray+=("INSTALL_MOD_STRIP=1")
|
|
|
|
fi
|
2014-01-01 04:09:42 +00:00
|
|
|
make modules_install $makeFlags "''${makeFlagsArray[@]}" \
|
|
|
|
$installFlags "''${installFlagsArray[@]}"
|
|
|
|
unlink $out/lib/modules/${modDirVersion}/build
|
2014-01-02 04:56:24 +00:00
|
|
|
unlink $out/lib/modules/${modDirVersion}/source
|
|
|
|
|
2023-03-17 18:41:07 +00:00
|
|
|
mkdir $dev/lib/modules/${modDirVersion}/build
|
2018-07-18 10:24:36 +00:00
|
|
|
|
2014-01-02 04:56:24 +00:00
|
|
|
cd $dev/lib/modules/${modDirVersion}/source
|
|
|
|
|
2017-03-20 23:12:12 +00:00
|
|
|
cp $buildRoot/{.config,Module.symvers} $dev/lib/modules/${modDirVersion}/build
|
|
|
|
make modules_prepare $makeFlags "''${makeFlagsArray[@]}" O=$dev/lib/modules/${modDirVersion}/build
|
2014-01-02 04:56:24 +00:00
|
|
|
|
2019-03-09 00:33:28 +00:00
|
|
|
# For reproducibility, removes accidental leftovers from a `cc1` call
|
|
|
|
# from a `try-run` call from the Makefile
|
|
|
|
rm -f $dev/lib/modules/${modDirVersion}/build/.[0-9]*.d
|
|
|
|
|
2023-03-17 18:44:06 +00:00
|
|
|
# Keep some extra files
|
|
|
|
for f in arch/powerpc/lib/crtsavres.o arch/arm64/kernel/ftrace-mod.o \
|
|
|
|
scripts/gdb/linux vmlinux vmlinux-gdb.py
|
|
|
|
do
|
|
|
|
if [ -e "$buildRoot/$f" ]; then
|
|
|
|
mkdir -p "$(dirname "$dev/lib/modules/${modDirVersion}/build/$f")"
|
|
|
|
cp -HR $buildRoot/$f $dev/lib/modules/${modDirVersion}/build/$f
|
2017-10-23 18:28:31 +00:00
|
|
|
fi
|
|
|
|
done
|
2023-03-17 18:44:06 +00:00
|
|
|
ln -s $dev/lib/modules/${modDirVersion}/build/vmlinux $dev
|
2017-10-23 18:28:31 +00:00
|
|
|
|
2014-01-02 04:56:24 +00:00
|
|
|
# !!! No documentation on how much of the source tree must be kept
|
Greatly reduce kernel closure size
Based on access analysis with strace, I determined an essentially
minimal required set of files from the kernel source that was needed to
build all current kernel packages on 3.10, which ultimately resulted in
keeping 30M of source. Generalizing from that minimal set, which
required ad-hoc specifications of which headers outside of include/ and
arch/*/include and which files in the scripts/ directory should be kept,
to a policy of keeping all non-arch-specific headers that aren't part of
the drivers/ directory and the entire scripts/ directory added an
additional 17M, but there was nothing in the analysis that indicated
that that ad-hoc specification was at all complete so I think the extra
hit is worth the likely greater compatibility.
For reference, we now keep:
* All headers that are NOT in arch/${notTargetArch}/include or drivers/
* The scripts/ directory
* Makefile
* arch/${targetArch}/Makefile
IMO the most likely cause of future problems are the headers in
drivers/, but hopefully they won't actually be needed as they add 50M
Ideally kernel packages would only use include and
arch/${targetArch}/include, but alas this is observably not the case.
master:
* $out
* size: 234M
* references-closure: linux-headers, glibc, attr, acl, zlib, gcc,
coreutils, perl, bash
merge-kernel-builds:
* $out
* size: 152M
* references-closure: none
* $dev
* size: 57M
* references-closure: linux-headers, glibc, zlib, gcc
So even with the non-minimal set we still beat out master. Keeping the
drivers headers would make us only slightly bigger.
Signed-off-by: Shea Levy <shea@shealevy.com>
2014-01-05 11:55:47 +00:00
|
|
|
# If/when kernel builds fail due to missing files, you can add
|
|
|
|
# them here. Note that we may see packages requiring headers
|
|
|
|
# from drivers/ in the future; it adds 50M to keep all of its
|
|
|
|
# headers on 3.10 though.
|
|
|
|
|
2018-01-28 18:50:18 +00:00
|
|
|
chmod u+w -R ..
|
2017-10-23 18:28:31 +00:00
|
|
|
arch=$(cd $dev/lib/modules/${modDirVersion}/build/arch; ls)
|
Greatly reduce kernel closure size
Based on access analysis with strace, I determined an essentially
minimal required set of files from the kernel source that was needed to
build all current kernel packages on 3.10, which ultimately resulted in
keeping 30M of source. Generalizing from that minimal set, which
required ad-hoc specifications of which headers outside of include/ and
arch/*/include and which files in the scripts/ directory should be kept,
to a policy of keeping all non-arch-specific headers that aren't part of
the drivers/ directory and the entire scripts/ directory added an
additional 17M, but there was nothing in the analysis that indicated
that that ad-hoc specification was at all complete so I think the extra
hit is worth the likely greater compatibility.
For reference, we now keep:
* All headers that are NOT in arch/${notTargetArch}/include or drivers/
* The scripts/ directory
* Makefile
* arch/${targetArch}/Makefile
IMO the most likely cause of future problems are the headers in
drivers/, but hopefully they won't actually be needed as they add 50M
Ideally kernel packages would only use include and
arch/${targetArch}/include, but alas this is observably not the case.
master:
* $out
* size: 234M
* references-closure: linux-headers, glibc, attr, acl, zlib, gcc,
coreutils, perl, bash
merge-kernel-builds:
* $out
* size: 152M
* references-closure: none
* $dev
* size: 57M
* references-closure: linux-headers, glibc, zlib, gcc
So even with the non-minimal set we still beat out master. Keeping the
drivers headers would make us only slightly bigger.
Signed-off-by: Shea Levy <shea@shealevy.com>
2014-01-05 11:55:47 +00:00
|
|
|
|
2017-10-23 18:28:31 +00:00
|
|
|
# Remove unused arches
|
|
|
|
for d in $(cd arch/; ls); do
|
|
|
|
if [ "$d" = "$arch" ]; then continue; fi
|
|
|
|
if [ "$arch" = arm64 ] && [ "$d" = arm ]; then continue; fi
|
|
|
|
rm -rf arch/$d
|
|
|
|
done
|
Greatly reduce kernel closure size
Based on access analysis with strace, I determined an essentially
minimal required set of files from the kernel source that was needed to
build all current kernel packages on 3.10, which ultimately resulted in
keeping 30M of source. Generalizing from that minimal set, which
required ad-hoc specifications of which headers outside of include/ and
arch/*/include and which files in the scripts/ directory should be kept,
to a policy of keeping all non-arch-specific headers that aren't part of
the drivers/ directory and the entire scripts/ directory added an
additional 17M, but there was nothing in the analysis that indicated
that that ad-hoc specification was at all complete so I think the extra
hit is worth the likely greater compatibility.
For reference, we now keep:
* All headers that are NOT in arch/${notTargetArch}/include or drivers/
* The scripts/ directory
* Makefile
* arch/${targetArch}/Makefile
IMO the most likely cause of future problems are the headers in
drivers/, but hopefully they won't actually be needed as they add 50M
Ideally kernel packages would only use include and
arch/${targetArch}/include, but alas this is observably not the case.
master:
* $out
* size: 234M
* references-closure: linux-headers, glibc, attr, acl, zlib, gcc,
coreutils, perl, bash
merge-kernel-builds:
* $out
* size: 152M
* references-closure: none
* $dev
* size: 57M
* references-closure: linux-headers, glibc, zlib, gcc
So even with the non-minimal set we still beat out master. Keeping the
drivers headers would make us only slightly bigger.
Signed-off-by: Shea Levy <shea@shealevy.com>
2014-01-05 11:55:47 +00:00
|
|
|
|
|
|
|
# Remove all driver-specific code (50M of which is headers)
|
|
|
|
rm -fR drivers
|
|
|
|
|
|
|
|
# Keep all headers
|
2020-10-27 18:29:02 +00:00
|
|
|
find . -type f -name '*.h' -print0 | xargs -0 -r chmod u-w
|
Greatly reduce kernel closure size
Based on access analysis with strace, I determined an essentially
minimal required set of files from the kernel source that was needed to
build all current kernel packages on 3.10, which ultimately resulted in
keeping 30M of source. Generalizing from that minimal set, which
required ad-hoc specifications of which headers outside of include/ and
arch/*/include and which files in the scripts/ directory should be kept,
to a policy of keeping all non-arch-specific headers that aren't part of
the drivers/ directory and the entire scripts/ directory added an
additional 17M, but there was nothing in the analysis that indicated
that that ad-hoc specification was at all complete so I think the extra
hit is worth the likely greater compatibility.
For reference, we now keep:
* All headers that are NOT in arch/${notTargetArch}/include or drivers/
* The scripts/ directory
* Makefile
* arch/${targetArch}/Makefile
IMO the most likely cause of future problems are the headers in
drivers/, but hopefully they won't actually be needed as they add 50M
Ideally kernel packages would only use include and
arch/${targetArch}/include, but alas this is observably not the case.
master:
* $out
* size: 234M
* references-closure: linux-headers, glibc, attr, acl, zlib, gcc,
coreutils, perl, bash
merge-kernel-builds:
* $out
* size: 152M
* references-closure: none
* $dev
* size: 57M
* references-closure: linux-headers, glibc, zlib, gcc
So even with the non-minimal set we still beat out master. Keeping the
drivers headers would make us only slightly bigger.
Signed-off-by: Shea Levy <shea@shealevy.com>
2014-01-05 11:55:47 +00:00
|
|
|
|
2017-10-23 18:28:31 +00:00
|
|
|
# Keep linker scripts (they are required for out-of-tree modules on aarch64)
|
2020-10-27 18:29:02 +00:00
|
|
|
find . -type f -name '*.lds' -print0 | xargs -0 -r chmod u-w
|
2017-10-23 18:28:31 +00:00
|
|
|
|
Greatly reduce kernel closure size
Based on access analysis with strace, I determined an essentially
minimal required set of files from the kernel source that was needed to
build all current kernel packages on 3.10, which ultimately resulted in
keeping 30M of source. Generalizing from that minimal set, which
required ad-hoc specifications of which headers outside of include/ and
arch/*/include and which files in the scripts/ directory should be kept,
to a policy of keeping all non-arch-specific headers that aren't part of
the drivers/ directory and the entire scripts/ directory added an
additional 17M, but there was nothing in the analysis that indicated
that that ad-hoc specification was at all complete so I think the extra
hit is worth the likely greater compatibility.
For reference, we now keep:
* All headers that are NOT in arch/${notTargetArch}/include or drivers/
* The scripts/ directory
* Makefile
* arch/${targetArch}/Makefile
IMO the most likely cause of future problems are the headers in
drivers/, but hopefully they won't actually be needed as they add 50M
Ideally kernel packages would only use include and
arch/${targetArch}/include, but alas this is observably not the case.
master:
* $out
* size: 234M
* references-closure: linux-headers, glibc, attr, acl, zlib, gcc,
coreutils, perl, bash
merge-kernel-builds:
* $out
* size: 152M
* references-closure: none
* $dev
* size: 57M
* references-closure: linux-headers, glibc, zlib, gcc
So even with the non-minimal set we still beat out master. Keeping the
drivers headers would make us only slightly bigger.
Signed-off-by: Shea Levy <shea@shealevy.com>
2014-01-05 11:55:47 +00:00
|
|
|
# Keep root and arch-specific Makefiles
|
2020-12-23 14:52:33 +00:00
|
|
|
chmod u-w Makefile arch/"$arch"/Makefile*
|
Greatly reduce kernel closure size
Based on access analysis with strace, I determined an essentially
minimal required set of files from the kernel source that was needed to
build all current kernel packages on 3.10, which ultimately resulted in
keeping 30M of source. Generalizing from that minimal set, which
required ad-hoc specifications of which headers outside of include/ and
arch/*/include and which files in the scripts/ directory should be kept,
to a policy of keeping all non-arch-specific headers that aren't part of
the drivers/ directory and the entire scripts/ directory added an
additional 17M, but there was nothing in the analysis that indicated
that that ad-hoc specification was at all complete so I think the extra
hit is worth the likely greater compatibility.
For reference, we now keep:
* All headers that are NOT in arch/${notTargetArch}/include or drivers/
* The scripts/ directory
* Makefile
* arch/${targetArch}/Makefile
IMO the most likely cause of future problems are the headers in
drivers/, but hopefully they won't actually be needed as they add 50M
Ideally kernel packages would only use include and
arch/${targetArch}/include, but alas this is observably not the case.
master:
* $out
* size: 234M
* references-closure: linux-headers, glibc, attr, acl, zlib, gcc,
coreutils, perl, bash
merge-kernel-builds:
* $out
* size: 152M
* references-closure: none
* $dev
* size: 57M
* references-closure: linux-headers, glibc, zlib, gcc
So even with the non-minimal set we still beat out master. Keeping the
drivers headers would make us only slightly bigger.
Signed-off-by: Shea Levy <shea@shealevy.com>
2014-01-05 11:55:47 +00:00
|
|
|
|
|
|
|
# Keep whole scripts dir
|
2017-03-20 23:12:12 +00:00
|
|
|
chmod u-w -R scripts
|
Greatly reduce kernel closure size
Based on access analysis with strace, I determined an essentially
minimal required set of files from the kernel source that was needed to
build all current kernel packages on 3.10, which ultimately resulted in
keeping 30M of source. Generalizing from that minimal set, which
required ad-hoc specifications of which headers outside of include/ and
arch/*/include and which files in the scripts/ directory should be kept,
to a policy of keeping all non-arch-specific headers that aren't part of
the drivers/ directory and the entire scripts/ directory added an
additional 17M, but there was nothing in the analysis that indicated
that that ad-hoc specification was at all complete so I think the extra
hit is worth the likely greater compatibility.
For reference, we now keep:
* All headers that are NOT in arch/${notTargetArch}/include or drivers/
* The scripts/ directory
* Makefile
* arch/${targetArch}/Makefile
IMO the most likely cause of future problems are the headers in
drivers/, but hopefully they won't actually be needed as they add 50M
Ideally kernel packages would only use include and
arch/${targetArch}/include, but alas this is observably not the case.
master:
* $out
* size: 234M
* references-closure: linux-headers, glibc, attr, acl, zlib, gcc,
coreutils, perl, bash
merge-kernel-builds:
* $out
* size: 152M
* references-closure: none
* $dev
* size: 57M
* references-closure: linux-headers, glibc, zlib, gcc
So even with the non-minimal set we still beat out master. Keeping the
drivers headers would make us only slightly bigger.
Signed-off-by: Shea Levy <shea@shealevy.com>
2014-01-05 11:55:47 +00:00
|
|
|
|
|
|
|
# Delete everything not kept
|
2020-10-27 18:29:02 +00:00
|
|
|
find . -type f -perm -u=w -print0 | xargs -0 -r rm
|
Greatly reduce kernel closure size
Based on access analysis with strace, I determined an essentially
minimal required set of files from the kernel source that was needed to
build all current kernel packages on 3.10, which ultimately resulted in
keeping 30M of source. Generalizing from that minimal set, which
required ad-hoc specifications of which headers outside of include/ and
arch/*/include and which files in the scripts/ directory should be kept,
to a policy of keeping all non-arch-specific headers that aren't part of
the drivers/ directory and the entire scripts/ directory added an
additional 17M, but there was nothing in the analysis that indicated
that that ad-hoc specification was at all complete so I think the extra
hit is worth the likely greater compatibility.
For reference, we now keep:
* All headers that are NOT in arch/${notTargetArch}/include or drivers/
* The scripts/ directory
* Makefile
* arch/${targetArch}/Makefile
IMO the most likely cause of future problems are the headers in
drivers/, but hopefully they won't actually be needed as they add 50M
Ideally kernel packages would only use include and
arch/${targetArch}/include, but alas this is observably not the case.
master:
* $out
* size: 234M
* references-closure: linux-headers, glibc, attr, acl, zlib, gcc,
coreutils, perl, bash
merge-kernel-builds:
* $out
* size: 152M
* references-closure: none
* $dev
* size: 57M
* references-closure: linux-headers, glibc, zlib, gcc
So even with the non-minimal set we still beat out master. Keeping the
drivers headers would make us only slightly bigger.
Signed-off-by: Shea Levy <shea@shealevy.com>
2014-01-05 11:55:47 +00:00
|
|
|
|
|
|
|
# Delete empty directories
|
2014-01-05 01:57:21 +00:00
|
|
|
find -empty -type d -delete
|
2014-01-05 15:31:16 +00:00
|
|
|
|
|
|
|
# Remove reference to kmod
|
2017-10-29 01:06:18 +00:00
|
|
|
sed -i Makefile -e 's|= ${buildPackages.kmod}/bin/depmod|= depmod|'
|
2023-02-21 23:56:19 +00:00
|
|
|
'';
|
2014-01-01 04:09:42 +00:00
|
|
|
|
2023-03-17 18:44:06 +00:00
|
|
|
preFixup = ''
|
|
|
|
# Don't strip $dev/lib/modules/*/vmlinux
|
|
|
|
stripDebugList="$(cd $dev && echo lib/modules/*/build/*/)"
|
|
|
|
'';
|
|
|
|
|
2016-05-04 16:03:12 +00:00
|
|
|
requiredSystemFeatures = [ "big-parallel" ];
|
|
|
|
|
2014-01-01 14:21:25 +00:00
|
|
|
meta = {
|
|
|
|
description =
|
|
|
|
"The Linux kernel" +
|
|
|
|
(if kernelPatches == [] then "" else
|
|
|
|
" (with patches: "
|
2021-01-15 14:45:37 +00:00
|
|
|
+ lib.concatStringsSep ", " (map (x: x.name) kernelPatches)
|
2014-01-01 14:21:25 +00:00
|
|
|
+ ")");
|
2021-05-02 14:18:43 +00:00
|
|
|
license = lib.licenses.gpl2Only;
|
2020-04-01 01:11:51 +00:00
|
|
|
homepage = "https://www.kernel.org/";
|
2021-10-08 21:17:40 +00:00
|
|
|
maintainers = lib.teams.linux-kernel.members ++ [
|
2014-04-01 07:59:20 +00:00
|
|
|
maintainers.thoughtpolice
|
2014-01-01 14:21:25 +00:00
|
|
|
];
|
|
|
|
platforms = platforms.linux;
|
2018-10-01 15:40:29 +00:00
|
|
|
timeout = 14400; # 4 hours
|
2018-01-15 17:55:24 +00:00
|
|
|
} // extraMeta;
|
|
|
|
};
|
2013-03-02 14:53:56 +00:00
|
|
|
in
|
|
|
|
|
2022-10-23 16:28:32 +00:00
|
|
|
assert lib.versionOlder version "5.8" -> libelf != null;
|
2021-01-15 14:45:37 +00:00
|
|
|
assert lib.versionAtLeast version "5.8" -> elfutils != null;
|
2020-06-26 15:08:51 +00:00
|
|
|
|
2021-01-23 01:33:55 +00:00
|
|
|
stdenv.mkDerivation ((drvAttrs config stdenv.hostPlatform.linux-kernel kernelPatches configfile) // {
|
2019-08-21 13:14:31 +00:00
|
|
|
pname = "linux";
|
|
|
|
inherit version;
|
2013-03-02 14:53:56 +00:00
|
|
|
|
|
|
|
enableParallelBuilding = true;
|
|
|
|
|
2018-01-16 03:28:45 +00:00
|
|
|
depsBuildBuild = [ buildPackages.stdenv.cc ];
|
2022-03-31 18:11:26 +00:00
|
|
|
nativeBuildInputs = [ perl bc nettools openssl rsync gmp libmpc mpfr zstd python3Minimal ]
|
2021-01-23 01:33:55 +00:00
|
|
|
++ optional (stdenv.hostPlatform.linux-kernel.target == "uImage") buildPackages.ubootTools
|
2022-10-23 16:28:32 +00:00
|
|
|
++ optional (lib.versionOlder version "5.8") libelf
|
2021-01-15 14:45:37 +00:00
|
|
|
++ optionals (lib.versionAtLeast version "4.16") [ bison flex ]
|
2021-09-26 18:23:23 +00:00
|
|
|
++ optionals (lib.versionAtLeast version "5.2") [ cpio pahole zlib ]
|
2021-01-15 14:45:37 +00:00
|
|
|
++ optional (lib.versionAtLeast version "5.8") elfutils
|
2017-11-27 23:15:48 +00:00
|
|
|
;
|
2012-07-29 08:59:38 +00:00
|
|
|
|
2018-11-10 19:49:36 +00:00
|
|
|
hardeningDisable = [ "bindnow" "format" "fortify" "stackprotector" "pic" "pie" ];
|
2015-12-23 01:59:47 +00:00
|
|
|
|
2018-02-12 18:45:01 +00:00
|
|
|
# Absolute paths for compilers avoid any PATH-clobbering issues.
|
2022-07-28 17:31:42 +00:00
|
|
|
makeFlags = [
|
|
|
|
"O=$(buildRoot)"
|
2018-02-12 18:45:01 +00:00
|
|
|
"CC=${stdenv.cc}/bin/${stdenv.cc.targetPrefix}cc"
|
|
|
|
"HOSTCC=${buildPackages.stdenv.cc}/bin/${buildPackages.stdenv.cc.targetPrefix}cc"
|
2022-10-25 08:53:28 +00:00
|
|
|
"HOSTLD=${buildPackages.stdenv.cc.bintools}/bin/${buildPackages.stdenv.cc.targetPrefix}ld"
|
2021-01-23 01:33:55 +00:00
|
|
|
"ARCH=${stdenv.hostPlatform.linuxArch}"
|
2022-08-16 16:33:13 +00:00
|
|
|
] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [
|
2017-10-28 19:09:54 +00:00
|
|
|
"CROSS_COMPILE=${stdenv.cc.targetPrefix}"
|
2022-07-28 17:31:42 +00:00
|
|
|
] ++ (stdenv.hostPlatform.linux-kernel.makeFlags or [])
|
|
|
|
++ extraMakeFlags;
|
2012-08-01 18:15:26 +00:00
|
|
|
|
2021-01-23 01:33:55 +00:00
|
|
|
karch = stdenv.hostPlatform.linuxArch;
|
2022-12-20 13:42:38 +00:00
|
|
|
} // (optionalAttrs (pos != null) { inherit pos; })))
|