nixpkgs/pkgs/os-specific/linux/zfs/default.nix

211 lines
8.7 KiB
Nix
Raw Normal View History

2021-02-01 19:26:29 +00:00
{ lib, stdenv, fetchFromGitHub
, autoreconfHook269, util-linux, nukeReferences, coreutils
2021-02-02 21:52:09 +00:00
, perl, buildPackages, nixosTests
, configFile ? "all"
# Userspace dependencies
2018-12-10 17:18:35 +00:00
, zlib, libuuid, python3, attr, openssl
2018-03-24 18:49:05 +00:00
, libtirpc
, nfs-utils
, gawk, gnugrep, gnused, systemd
2019-10-04 10:34:15 +00:00
, smartmontools, sysstat, sudo
, pkg-config
# Kernel dependencies
, kernel ? null
, enablePython ? true
}:
2021-01-15 14:45:37 +00:00
with lib;
let
buildKernel = any (n: n == configFile) [ "kernel" "all" ];
buildUser = any (n: n == configFile) [ "user" "all" ];
2017-09-12 23:28:42 +00:00
common = { version
, sha256
2019-09-25 10:30:31 +00:00
, extraPatches ? []
2017-09-12 23:28:42 +00:00
, rev ? "zfs-${version}"
, isUnstable ? false
, incompatibleKernelVersion ? null }:
stdenv.mkDerivation {
2017-09-12 23:28:42 +00:00
name = "zfs-${configFile}-${version}${optionalString buildKernel "-${kernel.version}"}";
src = fetchFromGitHub {
owner = "zfsonlinux";
repo = "zfs";
inherit rev sha256;
};
2020-08-27 04:49:42 +00:00
patches = extraPatches;
2017-09-12 23:28:42 +00:00
postPatch = optionalString buildKernel ''
patchShebangs scripts
2018-12-21 22:26:34 +00:00
# The arrays must remain the same length, so we repeat a flag that is
# already part of the command and therefore has no effect.
2020-11-30 23:09:54 +00:00
substituteInPlace ./module/os/linux/zfs/zfs_ctldir.c \
2020-11-24 15:29:28 +00:00
--replace '"/usr/bin/env", "umount"' '"${util-linux}/bin/umount", "-n"' \
--replace '"/usr/bin/env", "mount"' '"${util-linux}/bin/mount", "-n"'
2018-12-21 22:26:34 +00:00
'' + optionalString buildUser ''
2020-11-30 23:09:54 +00:00
substituteInPlace ./lib/libshare/os/linux/nfs.c --replace "/usr/sbin/exportfs" "${
# We don't *need* python support, but we set it like this to minimize closure size:
# If it's disabled by default, no need to enable it, even if we have python enabled
# And if it's enabled by default, only change that if we explicitly disable python to remove python from the closure
nfs-utils.override (old: { enablePython = old.enablePython or true && enablePython; })
}/bin/exportfs"
2017-09-12 23:28:42 +00:00
substituteInPlace ./config/user-systemd.m4 --replace "/usr/lib/modules-load.d" "$out/etc/modules-load.d"
2020-08-27 04:49:42 +00:00
substituteInPlace ./config/zfs-build.m4 --replace "\$sysconfdir/init.d" "$out/etc/init.d" \
--replace "/etc/default" "$out/etc/default"
2017-09-12 23:28:42 +00:00
substituteInPlace ./etc/zfs/Makefile.am --replace "\$(sysconfdir)" "$out/etc"
2020-01-24 13:52:44 +00:00
substituteInPlace ./contrib/initramfs/hooks/Makefile.am \
--replace "/usr/share/initramfs-tools/hooks" "$out/usr/share/initramfs-tools/hooks"
substituteInPlace ./contrib/initramfs/Makefile.am \
--replace "/usr/share/initramfs-tools" "$out/usr/share/initramfs-tools"
substituteInPlace ./contrib/initramfs/scripts/Makefile.am \
--replace "/usr/share/initramfs-tools/scripts" "$out/usr/share/initramfs-tools/scripts"
substituteInPlace ./contrib/initramfs/scripts/local-top/Makefile.am \
--replace "/usr/share/initramfs-tools/scripts/local-top" "$out/usr/share/initramfs-tools/scripts/local-top"
substituteInPlace ./contrib/initramfs/scripts/Makefile.am \
--replace "/usr/share/initramfs-tools/scripts" "$out/usr/share/initramfs-tools/scripts"
substituteInPlace ./contrib/initramfs/scripts/local-top/Makefile.am \
--replace "/usr/share/initramfs-tools/scripts/local-top" "$out/usr/share/initramfs-tools/scripts/local-top"
substituteInPlace ./etc/systemd/system/Makefile.am \
--replace '$(DESTDIR)$(systemdunitdir)' "$out"'$(DESTDIR)$(systemdunitdir)'
2020-08-27 04:49:42 +00:00
substituteInPlace ./contrib/initramfs/conf.d/Makefile.am \
--replace "/usr/share/initramfs-tools/conf.d" "$out/usr/share/initramfs-tools/conf.d"
substituteInPlace ./contrib/initramfs/conf-hooks.d/Makefile.am \
--replace "/usr/share/initramfs-tools/conf-hooks.d" "$out/usr/share/initramfs-tools/conf-hooks.d"
2017-09-12 23:28:42 +00:00
substituteInPlace ./cmd/vdev_id/vdev_id \
--replace "PATH=/bin:/sbin:/usr/bin:/usr/sbin" \
"PATH=${makeBinPath [ coreutils gawk gnused gnugrep systemd ]}"
2017-09-12 23:28:42 +00:00
'';
nativeBuildInputs = [ autoreconfHook269 nukeReferences ]
2020-08-15 14:09:09 +00:00
++ optionals buildKernel (kernel.moduleBuildDependencies ++ [ perl ])
++ optional buildUser pkg-config;
2020-08-15 14:09:09 +00:00
buildInputs = optionals buildUser [ zlib libuuid attr libtirpc ]
++ optional buildUser openssl
2020-08-15 14:09:09 +00:00
++ optional (buildUser && enablePython) python3;
2018-12-21 22:26:34 +00:00
# for zdb to get the rpath to libgcc_s, needed for pthread_cancel to work
NIX_CFLAGS_LINK = "-lgcc_s";
hardeningDisable = [ "fortify" "stackprotector" "pic" ];
2017-09-12 23:28:42 +00:00
configureFlags = [
"--with-config=${configFile}"
2020-08-15 14:09:09 +00:00
"--with-tirpc=1"
(withFeatureAs (buildUser && enablePython) "python" python3.interpreter)
] ++ optionals buildUser [
2017-09-12 23:28:42 +00:00
"--with-dracutdir=$(out)/lib/dracut"
"--with-udevdir=$(out)/lib/udev"
"--with-systemdunitdir=$(out)/etc/systemd/system"
"--with-systemdpresetdir=$(out)/etc/systemd/system-preset"
2018-04-12 22:11:13 +00:00
"--with-systemdgeneratordir=$(out)/lib/systemd/system-generator"
2017-09-12 23:28:42 +00:00
"--with-mounthelperdir=$(out)/bin"
2018-12-21 22:26:34 +00:00
"--libexecdir=$(out)/libexec"
2017-09-12 23:28:42 +00:00
"--sysconfdir=/etc"
"--localstatedir=/var"
"--enable-systemd"
2018-12-21 22:26:34 +00:00
] ++ optionals buildKernel ([
2017-09-12 23:28:42 +00:00
"--with-linux=${kernel.dev}/lib/modules/${kernel.modDirVersion}/source"
"--with-linux-obj=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build"
2018-12-21 22:26:34 +00:00
] ++ kernel.makeFlags);
makeFlags = optionals buildKernel kernel.makeFlags;
2017-09-12 23:28:42 +00:00
enableParallelBuilding = true;
installFlags = [
"sysconfdir=\${out}/etc"
"DEFAULT_INITCONF_DIR=\${out}/default"
2019-09-25 10:30:31 +00:00
"INSTALL_MOD_PATH=\${out}"
2017-09-12 23:28:42 +00:00
];
2018-12-21 22:26:34 +00:00
postInstall = optionalString buildKernel ''
# Add reference that cannot be detected due to compressed kernel module
mkdir -p "$out/nix-support"
2020-11-24 15:29:28 +00:00
echo "${util-linux}" >> "$out/nix-support/extra-refs"
2017-09-12 23:28:42 +00:00
'' + optionalString buildUser ''
# Remove provided services as they are buggy
rm $out/etc/systemd/system/zfs-import-*.service
sed -i '/zfs-import-scan.service/d' $out/etc/systemd/system/*
for i in $out/etc/systemd/system/*; do
substituteInPlace $i --replace "zfs-import-cache.service" "zfs-import.target"
done
# Remove tests because they add a runtime dependency on gcc
rm -rf $out/share/zfs/zfs-tests
# Add Bash completions.
2019-06-12 23:00:00 +00:00
install -v -m444 -D -t $out/share/bash-completion/completions contrib/bash_completion.d/zfs
2019-06-13 12:34:35 +00:00
(cd $out/share/bash-completion/completions; ln -s zfs zpool)
2017-09-12 23:28:42 +00:00
'';
postFixup = let
2020-11-24 15:29:28 +00:00
path = "PATH=${makeBinPath [ coreutils gawk gnused gnugrep util-linux smartmontools sysstat ]}:$PATH";
in ''
2019-10-04 10:34:15 +00:00
for i in $out/libexec/zfs/zpool.d/*; do
sed -i '2i${path}' $i
2019-10-04 10:34:15 +00:00
done
'';
2017-09-12 23:28:42 +00:00
outputs = [ "out" ] ++ optionals buildUser [ "lib" "dev" ];
2021-02-02 21:52:09 +00:00
passthru.tests = if isUnstable then
[ nixosTests.zfs.unstable ]
else [
nixosTests.zfs.installer
nixosTests.zfs.stable
];
2017-09-12 23:28:42 +00:00
meta = {
description = "ZFS Filesystem Linux Kernel module";
longDescription = ''
ZFS is a filesystem that combines a logical volume manager with a
Copy-On-Write filesystem with data integrity detection and repair,
snapshotting, cloning, block devices, deduplication, and more.
'';
homepage = "https://github.com/openzfs/zfs";
2017-09-12 23:28:42 +00:00
license = licenses.cddl;
platforms = platforms.linux;
maintainers = with maintainers; [ hmenke jcumming jonringer wizeman fpletz globin mic92 ];
broken = if
buildKernel && (incompatibleKernelVersion != null) && versionAtLeast kernel.version incompatibleKernelVersion
then builtins.trace ''
Linux v${kernel.version} is not yet supported by zfsonlinux v${version}.
${lib.optionalString (!isUnstable) "Try zfsUnstable or set the NixOS option boot.zfs.enableUnstable."}
'' true
else false;
2017-09-12 23:28:42 +00:00
};
};
in {
# also check if kernel version constraints in
# ./nixos/modules/tasks/filesystems/zfs.nix needs
# to be adapted
zfsStable = common {
# comment/uncomment if breaking kernel versions are known
# incompatibleKernelVersion = "4.20";
2017-09-12 23:28:42 +00:00
# this package should point to the latest release.
2021-02-01 19:26:29 +00:00
version = "2.0.2";
2017-09-12 23:28:42 +00:00
2021-02-01 19:26:29 +00:00
sha256 = "sha256-KzrRQwfQRvIQkHG5mj6cGBdcv2VEhC5y7bi09DaKqhY=";
2017-07-27 17:00:54 +00:00
};
2019-08-13 21:52:01 +00:00
zfsUnstable = common {
2017-09-12 23:28:42 +00:00
# comment/uncomment if breaking kernel versions are known
# incompatibleKernelVersion = "4.19";
2017-09-12 23:28:42 +00:00
# this package should point to a version / git revision compatible with the latest kernel release
2021-02-01 19:26:29 +00:00
version = "2.0.2";
2020-12-08 16:38:30 +00:00
2021-02-01 19:26:29 +00:00
sha256 = "sha256-KzrRQwfQRvIQkHG5mj6cGBdcv2VEhC5y7bi09DaKqhY=";
2017-07-27 17:00:54 +00:00
};
}