e04c0b0d99
This re-introduces the old stable ZFS version we had in the past following the many predicted issues of ZFS 2.2.x series, that is much more stable than any further ZFS version at the moment. I am also removing myself from maintenance of any further ZFS versions as I am planning to quit ZFS maintenance at some point. In the meantime, for users like me who depend on ZFS for critical operations, here is a ZFS version that is known to work for LTS kernels.
693 lines
26 KiB
Nix
693 lines
26 KiB
Nix
{ pkgs
|
|
, linuxKernel
|
|
, config
|
|
, buildPackages
|
|
, callPackage
|
|
, makeOverridable
|
|
, recurseIntoAttrs
|
|
, dontRecurseIntoAttrs
|
|
, stdenv
|
|
, stdenvNoCC
|
|
, newScope
|
|
, lib
|
|
, fetchurl
|
|
, gcc10Stdenv
|
|
}:
|
|
|
|
# When adding a kernel:
|
|
# - Update packageAliases.linux_latest to the latest version
|
|
# - Update the rev in ../os-specific/linux/kernel/linux-libre.nix to the latest one.
|
|
# - Update linux_latest_hardened when the patches become available
|
|
|
|
with linuxKernel;
|
|
|
|
let
|
|
deblobKernel = kernel: callPackage ../os-specific/linux/kernel/linux-libre.nix {
|
|
linux = kernel;
|
|
};
|
|
|
|
# Hardened Linux
|
|
hardenedKernelFor = kernel': overrides:
|
|
let
|
|
kernel = kernel'.override overrides;
|
|
version = kernelPatches.hardened.${kernel.meta.branch}.version;
|
|
major = lib.versions.major version;
|
|
sha256 = kernelPatches.hardened.${kernel.meta.branch}.sha256;
|
|
modDirVersion' = builtins.replaceStrings [ kernel.version ] [ version ] kernel.modDirVersion;
|
|
in kernel.override {
|
|
structuredExtraConfig = import ../os-specific/linux/kernel/hardened/config.nix {
|
|
inherit stdenv lib version;
|
|
};
|
|
argsOverride = {
|
|
inherit version;
|
|
modDirVersion = modDirVersion' + kernelPatches.hardened.${kernel.meta.branch}.extra;
|
|
src = fetchurl {
|
|
url = "mirror://kernel/linux/kernel/v${major}.x/linux-${version}.tar.xz";
|
|
inherit sha256;
|
|
};
|
|
extraMeta = {
|
|
broken = kernel.meta.broken;
|
|
};
|
|
};
|
|
kernelPatches = kernel.kernelPatches ++ [
|
|
kernelPatches.hardened.${kernel.meta.branch}
|
|
];
|
|
isHardened = true;
|
|
};
|
|
in {
|
|
kernelPatches = callPackage ../os-specific/linux/kernel/patches.nix { };
|
|
|
|
kernels = recurseIntoAttrs (lib.makeExtensible (self: with self;
|
|
let callPackage = newScope self; in {
|
|
|
|
# NOTE: PLEASE DO NOT ADD NEW VENDOR KERNELS TO NIXPKGS.
|
|
# New vendor kernels should go to nixos-hardware instead.
|
|
# e.g. https://github.com/NixOS/nixos-hardware/tree/master/microsoft/surface/kernel
|
|
|
|
linux_rpi1 = callPackage ../os-specific/linux/kernel/linux-rpi.nix {
|
|
kernelPatches = with kernelPatches; [
|
|
bridge_stp_helper
|
|
request_key_helper
|
|
];
|
|
rpiVersion = 1;
|
|
};
|
|
|
|
linux_rpi2 = callPackage ../os-specific/linux/kernel/linux-rpi.nix {
|
|
kernelPatches = with kernelPatches; [
|
|
bridge_stp_helper
|
|
request_key_helper
|
|
];
|
|
rpiVersion = 2;
|
|
};
|
|
|
|
linux_rpi3 = callPackage ../os-specific/linux/kernel/linux-rpi.nix {
|
|
kernelPatches = with kernelPatches; [
|
|
bridge_stp_helper
|
|
request_key_helper
|
|
];
|
|
rpiVersion = 3;
|
|
};
|
|
|
|
linux_rpi4 = callPackage ../os-specific/linux/kernel/linux-rpi.nix {
|
|
kernelPatches = with kernelPatches; [
|
|
bridge_stp_helper
|
|
request_key_helper
|
|
];
|
|
rpiVersion = 4;
|
|
};
|
|
|
|
linux_4_19 = callPackage ../os-specific/linux/kernel/mainline.nix {
|
|
branch = "4.19";
|
|
kernelPatches =
|
|
[ kernelPatches.bridge_stp_helper
|
|
kernelPatches.request_key_helper
|
|
kernelPatches.modinst_arg_list_too_long
|
|
];
|
|
};
|
|
|
|
linux_5_4 = callPackage ../os-specific/linux/kernel/mainline.nix {
|
|
branch = "5.4";
|
|
kernelPatches = [
|
|
kernelPatches.bridge_stp_helper
|
|
kernelPatches.request_key_helper
|
|
kernelPatches.rtl8761b_support
|
|
];
|
|
};
|
|
|
|
linux_rt_5_4 = callPackage ../os-specific/linux/kernel/linux-rt-5.4.nix {
|
|
kernelPatches = [
|
|
kernelPatches.bridge_stp_helper
|
|
kernelPatches.request_key_helper
|
|
];
|
|
};
|
|
|
|
linux_5_10 = callPackage ../os-specific/linux/kernel/mainline.nix {
|
|
branch = "5.10";
|
|
kernelPatches = [
|
|
kernelPatches.bridge_stp_helper
|
|
kernelPatches.request_key_helper
|
|
];
|
|
};
|
|
|
|
linux_rt_5_10 = callPackage ../os-specific/linux/kernel/linux-rt-5.10.nix {
|
|
kernelPatches = [
|
|
kernelPatches.bridge_stp_helper
|
|
kernelPatches.request_key_helper
|
|
kernelPatches.export-rt-sched-migrate
|
|
];
|
|
};
|
|
|
|
linux_5_15 = callPackage ../os-specific/linux/kernel/mainline.nix {
|
|
branch = "5.15";
|
|
kernelPatches = [
|
|
kernelPatches.bridge_stp_helper
|
|
kernelPatches.request_key_helper
|
|
];
|
|
};
|
|
|
|
linux_rt_5_15 = callPackage ../os-specific/linux/kernel/linux-rt-5.15.nix {
|
|
kernelPatches = [
|
|
kernelPatches.bridge_stp_helper
|
|
kernelPatches.request_key_helper
|
|
kernelPatches.export-rt-sched-migrate
|
|
];
|
|
};
|
|
|
|
linux_6_1 = callPackage ../os-specific/linux/kernel/mainline.nix {
|
|
branch = "6.1";
|
|
kernelPatches = [
|
|
kernelPatches.bridge_stp_helper
|
|
kernelPatches.request_key_helper
|
|
];
|
|
};
|
|
|
|
linux_rt_6_1 = callPackage ../os-specific/linux/kernel/linux-rt-6.1.nix {
|
|
kernelPatches = [
|
|
kernelPatches.bridge_stp_helper
|
|
kernelPatches.request_key_helper
|
|
kernelPatches.export-rt-sched-migrate
|
|
kernelPatches.dell_xps_regression
|
|
];
|
|
};
|
|
|
|
linux_6_5 = callPackage ../os-specific/linux/kernel/mainline.nix {
|
|
branch = "6.5";
|
|
kernelPatches = [
|
|
kernelPatches.bridge_stp_helper
|
|
kernelPatches.request_key_helper
|
|
];
|
|
};
|
|
|
|
linux_6_6 = callPackage ../os-specific/linux/kernel/mainline.nix {
|
|
branch = "6.6";
|
|
kernelPatches = [
|
|
kernelPatches.bridge_stp_helper
|
|
kernelPatches.request_key_helper
|
|
];
|
|
};
|
|
|
|
linux_testing = let
|
|
testing = callPackage ../os-specific/linux/kernel/mainline.nix {
|
|
# A special branch that tracks the kernel under the release process
|
|
# i.e. which has at least a public rc1 and is not released yet.
|
|
branch = "testing";
|
|
kernelPatches = [
|
|
kernelPatches.bridge_stp_helper
|
|
kernelPatches.request_key_helper
|
|
];
|
|
};
|
|
latest = packageAliases.linux_latest.kernel;
|
|
in if latest.kernelAtLeast testing.baseVersion
|
|
then latest
|
|
else testing;
|
|
|
|
# FIXME: Remove after 23.11 is released
|
|
linux_testing_bcachefs = callPackage ../os-specific/linux/kernel/linux-testing-bcachefs.nix {
|
|
# Pinned on the last version which Kent's commits can be cleany rebased up.
|
|
kernel = linux_6_5;
|
|
kernelPatches = linux_6_5.kernelPatches;
|
|
};
|
|
|
|
# Using zenKernels like this due lqx&zen came from one source, but may have different base kernel version
|
|
# https://github.com/NixOS/nixpkgs/pull/161773#discussion_r820134708
|
|
zenKernels = callPackage ../os-specific/linux/kernel/zen-kernels.nix;
|
|
|
|
linux_zen = (zenKernels {
|
|
kernelPatches = [
|
|
kernelPatches.bridge_stp_helper
|
|
kernelPatches.request_key_helper
|
|
];
|
|
}).zen;
|
|
|
|
linux_lqx = (zenKernels {
|
|
kernelPatches = [
|
|
kernelPatches.bridge_stp_helper
|
|
kernelPatches.request_key_helper
|
|
];
|
|
}).lqx;
|
|
|
|
# This contains the variants of the XanMod kernel
|
|
xanmodKernels = callPackage ../os-specific/linux/kernel/xanmod-kernels.nix {
|
|
kernelPatches = [
|
|
kernelPatches.bridge_stp_helper
|
|
kernelPatches.request_key_helper
|
|
];
|
|
};
|
|
|
|
linux_xanmod = xanmodKernels.lts;
|
|
linux_xanmod_stable = xanmodKernels.main;
|
|
linux_xanmod_latest = xanmodKernels.main;
|
|
|
|
linux_libre = deblobKernel packageAliases.linux_default.kernel;
|
|
|
|
linux_latest_libre = deblobKernel packageAliases.linux_latest.kernel;
|
|
|
|
linux_hardened = hardenedKernelFor packageAliases.linux_default.kernel { };
|
|
|
|
linux_4_19_hardened = hardenedKernelFor kernels.linux_4_19 {
|
|
stdenv = gcc10Stdenv;
|
|
buildPackages = buildPackages // { stdenv = buildPackages.gcc10Stdenv; };
|
|
};
|
|
linux_5_4_hardened = hardenedKernelFor kernels.linux_5_4 {
|
|
stdenv = gcc10Stdenv;
|
|
buildPackages = buildPackages // { stdenv = buildPackages.gcc10Stdenv; };
|
|
};
|
|
linux_5_10_hardened = hardenedKernelFor kernels.linux_5_10 { };
|
|
linux_5_15_hardened = hardenedKernelFor kernels.linux_5_15 { };
|
|
linux_6_1_hardened = hardenedKernelFor kernels.linux_6_1 { };
|
|
linux_6_5_hardened = hardenedKernelFor kernels.linux_6_5 { };
|
|
|
|
} // lib.optionalAttrs config.allowAliases {
|
|
linux_4_9 = throw "linux 4.9 was removed because it will reach its end of life within 22.11";
|
|
linux_4_14 = throw "linux 4.14 was removed because it will reach its end of life within 23.11";
|
|
linux_5_18 = throw "linux 5.18 was removed because it has reached its end of life upstream";
|
|
linux_5_19 = throw "linux 5.19 was removed because it has reached its end of life upstream";
|
|
linux_6_0 = throw "linux 6.0 was removed because it has reached its end of life upstream";
|
|
linux_6_2 = throw "linux 6.2 was removed because it has reached its end of life upstream";
|
|
linux_6_3 = throw "linux 6.3 was removed because it has reached its end of life upstream";
|
|
linux_6_4 = throw "linux 6.4 was removed because it has reached its end of life upstream";
|
|
|
|
linux_xanmod_tt = throw "linux_xanmod_tt was removed because upstream no longer offers this option";
|
|
|
|
linux_5_18_hardened = throw "linux 5.18 was removed because it has reached its end of life upstream";
|
|
linux_5_19_hardened = throw "linux 5.19 was removed because it has reached its end of life upstream";
|
|
linux_6_0_hardened = throw "linux 6.0 was removed because it has reached its end of life upstream";
|
|
}));
|
|
/* Linux kernel modules are inherently tied to a specific kernel. So
|
|
rather than provide specific instances of those packages for a
|
|
specific kernel, we have a function that builds those packages
|
|
for a specific kernel. This function can then be called for
|
|
whatever kernel you're using. */
|
|
|
|
packagesFor = kernel_: lib.makeExtensible (self: with self;
|
|
let callPackage = newScope self; in {
|
|
inherit callPackage;
|
|
kernel = kernel_;
|
|
inherit (kernel) stdenv; # in particular, use the same compiler by default
|
|
|
|
# to help determine module compatibility
|
|
inherit (kernel) isZen isHardened isLibre;
|
|
inherit (kernel) kernelOlder kernelAtLeast;
|
|
# Obsolete aliases (these packages do not depend on the kernel).
|
|
inherit (pkgs) odp-dpdk pktgen; # added 2018-05
|
|
inherit (pkgs) bcc bpftrace; # added 2021-12
|
|
inherit (pkgs) oci-seccomp-bpf-hook; # added 2022-11
|
|
|
|
acpi_call = callPackage ../os-specific/linux/acpi-call {};
|
|
|
|
akvcam = callPackage ../os-specific/linux/akvcam { };
|
|
|
|
amdgpu-pro = callPackage ../os-specific/linux/amdgpu-pro {
|
|
libffi = pkgs.libffi.overrideAttrs (orig: rec {
|
|
version = "3.3";
|
|
src = fetchurl {
|
|
url = "https://github.com/libffi/libffi/releases/download/v${version}/${orig.pname}-${version}.tar.gz";
|
|
sha256 = "0mi0cpf8aa40ljjmzxb7im6dbj45bb0kllcd09xgmp834y9agyvj";
|
|
};
|
|
});
|
|
};
|
|
|
|
apfs = callPackage ../os-specific/linux/apfs { };
|
|
|
|
ax99100 = callPackage ../os-specific/linux/ax99100 {};
|
|
|
|
batman_adv = callPackage ../os-specific/linux/batman-adv {};
|
|
|
|
bbswitch = callPackage ../os-specific/linux/bbswitch {};
|
|
|
|
ch9344 = callPackage ../os-specific/linux/ch9344 { };
|
|
|
|
chipsec = callPackage ../tools/security/chipsec {
|
|
inherit kernel;
|
|
withDriver = true;
|
|
};
|
|
|
|
cryptodev = callPackage ../os-specific/linux/cryptodev { };
|
|
|
|
cpupower = callPackage ../os-specific/linux/cpupower { };
|
|
|
|
ddcci-driver = callPackage ../os-specific/linux/ddcci { };
|
|
|
|
dddvb = callPackage ../os-specific/linux/dddvb { };
|
|
|
|
decklink = callPackage ../os-specific/linux/decklink { };
|
|
|
|
digimend = callPackage ../os-specific/linux/digimend { };
|
|
|
|
dpdk-kmods = callPackage ../os-specific/linux/dpdk-kmods { };
|
|
|
|
dpdk = pkgs.dpdk.override { inherit kernel; };
|
|
|
|
exfat-nofuse = if lib.versionOlder kernel.version "5.8" then callPackage ../os-specific/linux/exfat { } else null;
|
|
|
|
evdi = callPackage ../os-specific/linux/evdi { };
|
|
|
|
fanout = callPackage ../os-specific/linux/fanout { };
|
|
|
|
fwts-efi-runtime = callPackage ../os-specific/linux/fwts/module.nix { };
|
|
|
|
gcadapter-oc-kmod = callPackage ../os-specific/linux/gcadapter-oc-kmod { };
|
|
|
|
hyperv-daemons = callPackage ../os-specific/linux/hyperv-daemons { };
|
|
|
|
e1000e = if lib.versionOlder kernel.version "4.10" then callPackage ../os-specific/linux/e1000e {} else null;
|
|
|
|
intel-speed-select = if lib.versionAtLeast kernel.version "5.3" then callPackage ../os-specific/linux/intel-speed-select { } else null;
|
|
|
|
ipu6-drivers = callPackage ../os-specific/linux/ipu6-drivers {};
|
|
|
|
ivsc-driver = callPackage ../os-specific/linux/ivsc-driver {};
|
|
|
|
ixgbevf = callPackage ../os-specific/linux/ixgbevf {};
|
|
|
|
it87 = callPackage ../os-specific/linux/it87 {};
|
|
|
|
asus-ec-sensors = callPackage ../os-specific/linux/asus-ec-sensors {};
|
|
|
|
asus-wmi-sensors = callPackage ../os-specific/linux/asus-wmi-sensors {};
|
|
|
|
ena = callPackage ../os-specific/linux/ena {};
|
|
|
|
kvdo = callPackage ../os-specific/linux/kvdo {};
|
|
|
|
lenovo-legion-module = callPackage ../os-specific/linux/lenovo-legion { };
|
|
|
|
linux-gpib = callPackage ../applications/science/electronics/linux-gpib/kernel.nix { };
|
|
|
|
liquidtux = callPackage ../os-specific/linux/liquidtux {};
|
|
|
|
lkrg = callPackage ../os-specific/linux/lkrg {};
|
|
|
|
v4l2loopback = callPackage ../os-specific/linux/v4l2loopback { };
|
|
|
|
lttng-modules = callPackage ../os-specific/linux/lttng-modules { };
|
|
|
|
mstflint_access = callPackage ../os-specific/linux/mstflint_access { };
|
|
|
|
broadcom_sta = callPackage ../os-specific/linux/broadcom-sta { };
|
|
|
|
tbs = callPackage ../os-specific/linux/tbs { };
|
|
|
|
mbp2018-bridge-drv = callPackage ../os-specific/linux/mbp-modules/mbp2018-bridge-drv { };
|
|
|
|
nct6687d = callPackage ../os-specific/linux/nct6687d { };
|
|
|
|
new-lg4ff = callPackage ../os-specific/linux/new-lg4ff { };
|
|
|
|
nvidiabl = callPackage ../os-specific/linux/nvidiabl { };
|
|
|
|
nvidiaPackages = dontRecurseIntoAttrs (lib.makeExtensible (_: callPackage ../os-specific/linux/nvidia-x11 { }));
|
|
|
|
nvidia_x11 = nvidiaPackages.stable;
|
|
nvidia_x11_beta = nvidiaPackages.beta;
|
|
nvidia_x11_legacy340 = nvidiaPackages.legacy_340;
|
|
nvidia_x11_legacy390 = nvidiaPackages.legacy_390;
|
|
nvidia_x11_legacy470 = nvidiaPackages.legacy_470;
|
|
nvidia_x11_production = nvidiaPackages.production;
|
|
nvidia_x11_vulkan_beta = nvidiaPackages.vulkan_beta;
|
|
nvidia_dc = nvidiaPackages.dc;
|
|
nvidia_dc_520 = nvidiaPackages.dc_520;
|
|
|
|
# this is not a replacement for nvidia_x11*
|
|
# only the opensource kernel driver exposed for hydra to build
|
|
nvidia_x11_beta_open = nvidiaPackages.beta.open;
|
|
nvidia_x11_production_open = nvidiaPackages.production.open;
|
|
nvidia_x11_stable_open = nvidiaPackages.stable.open;
|
|
nvidia_x11_vulkan_beta_open = nvidiaPackages.vulkan_beta.open;
|
|
|
|
openrazer = callPackage ../os-specific/linux/openrazer/driver.nix { };
|
|
|
|
ply = callPackage ../os-specific/linux/ply { };
|
|
|
|
r8125 = callPackage ../os-specific/linux/r8125 { };
|
|
|
|
r8168 = callPackage ../os-specific/linux/r8168 { };
|
|
|
|
rtl8188eus-aircrack = callPackage ../os-specific/linux/rtl8188eus-aircrack { };
|
|
|
|
rtl8192eu = callPackage ../os-specific/linux/rtl8192eu { };
|
|
|
|
rtl8189es = callPackage ../os-specific/linux/rtl8189es { };
|
|
|
|
rtl8189fs = callPackage ../os-specific/linux/rtl8189fs { };
|
|
|
|
rtl8723ds = callPackage ../os-specific/linux/rtl8723ds { };
|
|
|
|
rtl8812au = callPackage ../os-specific/linux/rtl8812au { };
|
|
|
|
rtl8814au = callPackage ../os-specific/linux/rtl8814au { };
|
|
|
|
rtl88xxau-aircrack = callPackage ../os-specific/linux/rtl88xxau-aircrack {};
|
|
|
|
rtl8821au = callPackage ../os-specific/linux/rtl8821au { };
|
|
|
|
rtl8821ce = callPackage ../os-specific/linux/rtl8821ce { };
|
|
|
|
rtl88x2bu = callPackage ../os-specific/linux/rtl88x2bu { };
|
|
|
|
rtl8821cu = callPackage ../os-specific/linux/rtl8821cu { };
|
|
|
|
rtw88 = callPackage ../os-specific/linux/rtw88 { };
|
|
|
|
rtw89 = if lib.versionOlder kernel.version "5.16" then callPackage ../os-specific/linux/rtw89 { } else null;
|
|
|
|
openafs_1_8 = callPackage ../servers/openafs/1.8/module.nix { };
|
|
# Current stable release; don't backport release updates!
|
|
openafs = openafs_1_8;
|
|
|
|
opensnitch-ebpf = if lib.versionAtLeast kernel.version "5.10" then callPackage ../os-specific/linux/opensnitch-ebpf { } else null;
|
|
|
|
facetimehd = callPackage ../os-specific/linux/facetimehd { };
|
|
|
|
tuxedo-keyboard = if lib.versionAtLeast kernel.version "4.14" then callPackage ../os-specific/linux/tuxedo-keyboard { } else null;
|
|
|
|
jool = callPackage ../os-specific/linux/jool { };
|
|
|
|
kvmfr = callPackage ../os-specific/linux/kvmfr { };
|
|
|
|
mba6x_bl = callPackage ../os-specific/linux/mba6x_bl { };
|
|
|
|
mwprocapture = callPackage ../os-specific/linux/mwprocapture { };
|
|
|
|
mxu11x0 = callPackage ../os-specific/linux/mxu11x0 { };
|
|
|
|
# compiles but has to be integrated into the kernel somehow
|
|
# Let's have it uncommented and finish it..
|
|
ndiswrapper = callPackage ../os-specific/linux/ndiswrapper { };
|
|
|
|
netatop = callPackage ../os-specific/linux/netatop { };
|
|
|
|
perf = callPackage ../os-specific/linux/kernel/perf { };
|
|
|
|
phc-intel = if lib.versionAtLeast kernel.version "4.10" then callPackage ../os-specific/linux/phc-intel { } else null;
|
|
|
|
prl-tools = callPackage ../os-specific/linux/prl-tools { };
|
|
|
|
isgx = callPackage ../os-specific/linux/isgx { };
|
|
|
|
rr-zen_workaround = callPackage ../development/tools/analysis/rr/zen_workaround.nix { };
|
|
|
|
sysdig = callPackage ../os-specific/linux/sysdig {};
|
|
|
|
systemtap = callPackage ../development/tools/profiling/systemtap { };
|
|
|
|
system76 = callPackage ../os-specific/linux/system76 { };
|
|
|
|
system76-acpi = callPackage ../os-specific/linux/system76-acpi { };
|
|
|
|
system76-power = callPackage ../os-specific/linux/system76-power { };
|
|
|
|
system76-io = callPackage ../os-specific/linux/system76-io { };
|
|
|
|
system76-scheduler = callPackage ../os-specific/linux/system76-scheduler { };
|
|
|
|
tmon = callPackage ../os-specific/linux/tmon { };
|
|
|
|
tp_smapi = callPackage ../os-specific/linux/tp_smapi { };
|
|
|
|
turbostat = callPackage ../os-specific/linux/turbostat { };
|
|
|
|
trelay = callPackage ../os-specific/linux/trelay { };
|
|
|
|
usbip = callPackage ../os-specific/linux/usbip { };
|
|
|
|
v86d = callPackage ../os-specific/linux/v86d { };
|
|
|
|
veikk-linux-driver = callPackage ../os-specific/linux/veikk-linux-driver { };
|
|
vendor-reset = callPackage ../os-specific/linux/vendor-reset { };
|
|
|
|
vhba = callPackage ../applications/emulators/cdemu/vhba.nix { };
|
|
|
|
virtio_vmmci = callPackage ../os-specific/linux/virtio_vmmci { };
|
|
|
|
virtualbox = callPackage ../os-specific/linux/virtualbox {
|
|
virtualbox = pkgs.virtualboxHardened;
|
|
};
|
|
|
|
virtualboxGuestAdditions = callPackage ../applications/virtualization/virtualbox/guest-additions {
|
|
virtualbox = pkgs.virtualboxHardened;
|
|
};
|
|
|
|
vm-tools = callPackage ../os-specific/linux/vm-tools { };
|
|
|
|
vmm_clock = callPackage ../os-specific/linux/vmm_clock { };
|
|
|
|
vmware = callPackage ../os-specific/linux/vmware { };
|
|
|
|
wireguard = if lib.versionOlder kernel.version "5.6" then callPackage ../os-specific/linux/wireguard { } else null;
|
|
|
|
x86_energy_perf_policy = callPackage ../os-specific/linux/x86_energy_perf_policy { };
|
|
|
|
xone = if lib.versionAtLeast kernel.version "5.4" then callPackage ../os-specific/linux/xone { } else null;
|
|
|
|
xpadneo = callPackage ../os-specific/linux/xpadneo { };
|
|
|
|
ithc = callPackage ../os-specific/linux/ithc { };
|
|
|
|
zenpower = callPackage ../os-specific/linux/zenpower { };
|
|
|
|
zfs_2_1 = callPackage ../os-specific/linux/zfs/2_1.nix {
|
|
configFile = "kernel";
|
|
inherit pkgs kernel;
|
|
};
|
|
zfsStable = callPackage ../os-specific/linux/zfs/stable.nix {
|
|
configFile = "kernel";
|
|
inherit pkgs kernel;
|
|
};
|
|
zfsUnstable = callPackage ../os-specific/linux/zfs/unstable.nix {
|
|
configFile = "kernel";
|
|
inherit pkgs kernel;
|
|
};
|
|
zfs = zfsStable;
|
|
|
|
can-isotp = callPackage ../os-specific/linux/can-isotp { };
|
|
|
|
qc71_laptop = callPackage ../os-specific/linux/qc71_laptop { };
|
|
|
|
hid-ite8291r3 = callPackage ../os-specific/linux/hid-ite8291r3 { };
|
|
|
|
hid-tmff2 = callPackage ../os-specific/linux/hid-tmff2 { };
|
|
|
|
} // lib.optionalAttrs config.allowAliases {
|
|
ati_drivers_x11 = throw "ati drivers are no longer supported by any kernel >=4.1"; # added 2021-05-18;
|
|
hid-nintendo = throw "hid-nintendo was added in mainline kernel version 5.16"; # Added 2023-07-30
|
|
sch_cake = throw "sch_cake was added in mainline kernel version 4.19"; # Added 2023-06-14
|
|
rtl8723bs = throw "rtl8723bs was added in mainline kernel version 4.12"; # Added 2023-06-14
|
|
xmm7360-pci = throw "Support for the XMM7360 WWAN card was added to the iosm kmod in mainline kernel version 5.18";
|
|
});
|
|
|
|
hardenedPackagesFor = kernel: overrides: packagesFor (hardenedKernelFor kernel overrides);
|
|
|
|
vanillaPackages = {
|
|
# recurse to build modules for the kernels
|
|
linux_4_19 = recurseIntoAttrs (packagesFor kernels.linux_4_19);
|
|
linux_5_4 = recurseIntoAttrs (packagesFor kernels.linux_5_4);
|
|
linux_5_10 = recurseIntoAttrs (packagesFor kernels.linux_5_10);
|
|
linux_5_15 = recurseIntoAttrs (packagesFor kernels.linux_5_15);
|
|
linux_6_1 = recurseIntoAttrs (packagesFor kernels.linux_6_1);
|
|
linux_6_5 = recurseIntoAttrs (packagesFor kernels.linux_6_5);
|
|
linux_6_6 = recurseIntoAttrs (packagesFor kernels.linux_6_6);
|
|
} // lib.optionalAttrs config.allowAliases {
|
|
linux_4_9 = throw "linux 4.9 was removed because it will reach its end of life within 22.11"; # Added 2022-11-08
|
|
linux_4_14 = throw "linux 4.14 was removed because it will reach its end of life within 23.11"; # Added 2023-10-11
|
|
linux_5_18 = throw "linux 5.18 was removed because it reached its end of life upstream"; # Added 2022-09-17
|
|
linux_5_19 = throw "linux 5.19 was removed because it reached its end of life upstream"; # Added 2022-11-01
|
|
linux_6_0 = throw "linux 6.0 was removed because it reached its end of life upstream"; # Added 2023-01-20
|
|
linux_6_2 = throw "linux 6.2 was removed because it reached its end of life upstream"; # Added 2023-05-26
|
|
linux_6_3 = throw "linux 6.3 was removed because it reached its end of life upstream"; # Added 2023-07-22
|
|
linux_6_4 = throw "linux 6.4 was removed because it reached its end of life upstream"; # Added 2023-10-02
|
|
};
|
|
|
|
rtPackages = {
|
|
# realtime kernel packages
|
|
linux_rt_5_4 = packagesFor kernels.linux_rt_5_4;
|
|
linux_rt_5_10 = packagesFor kernels.linux_rt_5_10;
|
|
linux_rt_5_15 = packagesFor kernels.linux_rt_5_15;
|
|
linux_rt_6_1 = packagesFor kernels.linux_rt_6_1;
|
|
};
|
|
|
|
rpiPackages = {
|
|
linux_rpi1 = packagesFor kernels.linux_rpi1;
|
|
linux_rpi2 = packagesFor kernels.linux_rpi2;
|
|
linux_rpi3 = packagesFor kernels.linux_rpi3;
|
|
linux_rpi4 = packagesFor kernels.linux_rpi4;
|
|
};
|
|
|
|
packages = recurseIntoAttrs (vanillaPackages // rtPackages // rpiPackages // {
|
|
|
|
# Intentionally lacks recurseIntoAttrs, as -rc kernels will quite likely break out-of-tree modules and cause failed Hydra builds.
|
|
linux_testing = packagesFor kernels.linux_testing;
|
|
# FIXME: Remove after 23.11 is released
|
|
linux_testing_bcachefs = recurseIntoAttrs (packagesFor kernels.linux_testing_bcachefs);
|
|
|
|
linux_hardened = recurseIntoAttrs (packagesFor kernels.linux_hardened);
|
|
|
|
linux_4_19_hardened = recurseIntoAttrs (packagesFor kernels.linux_4_19_hardened);
|
|
linux_5_4_hardened = recurseIntoAttrs (packagesFor kernels.linux_5_4_hardened);
|
|
linux_5_10_hardened = recurseIntoAttrs (packagesFor kernels.linux_5_10_hardened);
|
|
linux_5_15_hardened = recurseIntoAttrs (packagesFor kernels.linux_5_15_hardened);
|
|
linux_6_1_hardened = recurseIntoAttrs (packagesFor kernels.linux_6_1_hardened);
|
|
linux_6_5_hardened = recurseIntoAttrs (packagesFor kernels.linux_6_5_hardened);
|
|
|
|
linux_zen = recurseIntoAttrs (packagesFor kernels.linux_zen);
|
|
linux_lqx = recurseIntoAttrs (packagesFor kernels.linux_lqx);
|
|
linux_xanmod = recurseIntoAttrs (packagesFor kernels.linux_xanmod);
|
|
linux_xanmod_stable = recurseIntoAttrs (packagesFor kernels.linux_xanmod_stable);
|
|
linux_xanmod_latest = recurseIntoAttrs (packagesFor kernels.linux_xanmod_latest);
|
|
|
|
linux_libre = recurseIntoAttrs (packagesFor kernels.linux_libre);
|
|
|
|
linux_latest_libre = recurseIntoAttrs (packagesFor kernels.linux_latest_libre);
|
|
} // lib.optionalAttrs config.allowAliases {
|
|
linux_5_18_hardened = throw "linux 5.18 was removed because it has reached its end of life upstream";
|
|
linux_5_19_hardened = throw "linux 5.19 was removed because it has reached its end of life upstream";
|
|
linux_6_0_hardened = throw "linux 6.0 was removed because it has reached its end of life upstream";
|
|
linux_xanmod_tt = throw "linux_xanmod_tt was removed because upstream no longer offers this option";
|
|
});
|
|
|
|
packageAliases = {
|
|
linux_default = packages.linux_6_1;
|
|
# Update this when adding the newest kernel major version!
|
|
linux_latest = packages.linux_6_6;
|
|
linux_mptcp = throw "'linux_mptcp' has been moved to https://github.com/teto/mptcp-flake";
|
|
linux_rt_default = packages.linux_rt_5_4;
|
|
linux_rt_latest = packages.linux_rt_6_1;
|
|
};
|
|
|
|
manualConfig = callPackage ../os-specific/linux/kernel/manual-config.nix {};
|
|
|
|
customPackage = { version, src, modDirVersion ? lib.versions.pad 3 version, configfile, allowImportFromDerivation ? true }:
|
|
recurseIntoAttrs (packagesFor (manualConfig {
|
|
inherit version src modDirVersion configfile allowImportFromDerivation;
|
|
}));
|
|
|
|
# Derive one of the default .config files
|
|
linuxConfig = {
|
|
src,
|
|
kernelPatches ? [],
|
|
version ? (builtins.parseDrvName src.name).version,
|
|
makeTarget ? "defconfig",
|
|
name ? "kernel.config",
|
|
}: stdenvNoCC.mkDerivation {
|
|
inherit name src;
|
|
depsBuildBuild = [ buildPackages.stdenv.cc ]
|
|
++ lib.optionals (lib.versionAtLeast version "4.16") [ buildPackages.bison buildPackages.flex ];
|
|
patches = map (p: p.patch) kernelPatches; # Patches may include new configs.
|
|
postPatch = ''
|
|
patchShebangs scripts/
|
|
'';
|
|
buildPhase = ''
|
|
set -x
|
|
make \
|
|
ARCH=${stdenv.hostPlatform.linuxArch} \
|
|
HOSTCC=${buildPackages.stdenv.cc.targetPrefix}gcc \
|
|
${makeTarget}
|
|
'';
|
|
installPhase = ''
|
|
cp .config $out
|
|
'';
|
|
};
|
|
|
|
buildLinux = attrs: callPackage ../os-specific/linux/kernel/generic.nix attrs;
|
|
|
|
}
|