zfs, spl: 0.6.5.11 -> 0.7.0

This commit is contained in:
Robin Gloster 2017-07-27 19:00:54 +02:00
parent 688dc4e4c3
commit 2799a94963
No known key found for this signature in database
GPG Key ID: 5E4C836C632C2882
6 changed files with 149 additions and 215 deletions

View File

@ -157,6 +157,12 @@ rmdir /var/lib/ipfs/.ipfs
module where user Fontconfig settings are available. module where user Fontconfig settings are available.
</para> </para>
</listitem> </listitem>
<listitem>
<para>
ZFS/SPL have been updated to 0.7.0, <literal>zfsUnstable, splUnstable</literal>
have therefore been removed.
</para>
</listitem>
</itemizedlist> </itemizedlist>

View File

@ -204,6 +204,7 @@ with lib;
"Set the option `services.xserver.displayManager.sddm.package' instead.") "Set the option `services.xserver.displayManager.sddm.package' instead.")
(mkRemovedOptionModule [ "fonts" "fontconfig" "forceAutohint" ] "") (mkRemovedOptionModule [ "fonts" "fontconfig" "forceAutohint" ] "")
(mkRemovedOptionModule [ "fonts" "fontconfig" "renderMonoTTFAsBitmap" ] "") (mkRemovedOptionModule [ "fonts" "fontconfig" "renderMonoTTFAsBitmap" ] "")
(mkRemovedOptionModule [ "boot" "zfs" "enableUnstable" ] "0.7.0 is now the default")
# ZSH # ZSH
(mkRenamedOptionModule [ "programs" "zsh" "enableSyntaxHighlighting" ] [ "programs" "zsh" "syntaxHighlighting" "enable" ]) (mkRenamedOptionModule [ "programs" "zsh" "enableSyntaxHighlighting" ] [ "programs" "zsh" "syntaxHighlighting" "enable" ])

View File

@ -24,11 +24,7 @@ let
kernel = config.boot.kernelPackages; kernel = config.boot.kernelPackages;
packages = if config.boot.zfs.enableUnstable then { packages = {
spl = kernel.splUnstable;
zfs = kernel.zfsUnstable;
zfsUser = pkgs.zfsUnstable;
} else {
spl = kernel.spl; spl = kernel.spl;
zfs = kernel.zfs; zfs = kernel.zfs;
zfsUser = pkgs.zfs; zfsUser = pkgs.zfs;
@ -62,19 +58,6 @@ in
options = { options = {
boot.zfs = { boot.zfs = {
enableUnstable = mkOption {
type = types.bool;
default = false;
description = ''
Use the unstable zfs package. This might be an option, if the latest
kernel is not yet supported by a published release of ZFS. Enabling
this option will install a development version of ZFS on Linux. The
version will have already passed an extensive test suite, but it is
more likely to hit an undiscovered bug compared to running a released
version of ZFS on Linux.
'';
};
extraPools = mkOption { extraPools = mkOption {
type = types.listOf types.str; type = types.listOf types.str;
default = []; default = [];

View File

@ -6,67 +6,57 @@
}: }:
with stdenv.lib; with stdenv.lib;
let let
buildKernel = any (n: n == configFile) [ "kernel" "all" ]; buildKernel = any (n: n == configFile) [ "kernel" "all" ];
buildUser = any (n: n == configFile) [ "user" "all" ]; buildUser = any (n: n == configFile) [ "user" "all" ];
common = { version, sha256 } @ args : stdenv.mkDerivation rec {
name = "spl-${configFile}-${version}${optionalString buildKernel "-${kernel.version}"}";
src = fetchFromGitHub {
owner = "zfsonlinux";
repo = "spl";
rev = "spl-${version}";
inherit sha256;
};
patches = [ ./const.patch ./install_prefix.patch ];
nativeBuildInputs = [ autoreconfHook ];
hardeningDisable = [ "pic" ];
preConfigure = ''
substituteInPlace ./module/spl/spl-generic.c --replace /usr/bin/hostid hostid
substituteInPlace ./module/spl/spl-generic.c --replace "PATH=/sbin:/usr/sbin:/bin:/usr/bin" "PATH=${coreutils}:${gawk}:/bin"
substituteInPlace ./module/splat/splat-vnode.c --replace "PATH=/sbin:/usr/sbin:/bin:/usr/bin" "PATH=${coreutils}:/bin"
substituteInPlace ./module/splat/splat-linux.c --replace "PATH=/sbin:/usr/sbin:/bin:/usr/bin" "PATH=${coreutils}:/bin"
'';
configureFlags = [
"--with-config=${configFile}"
] ++ optionals buildKernel [
"--with-linux=${kernel.dev}/lib/modules/${kernel.modDirVersion}/source"
"--with-linux-obj=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build"
];
enableParallelBuilding = true;
meta = {
description = "Kernel module driver for solaris porting layer (needed by in-kernel zfs)";
longDescription = ''
This kernel module is a porting layer for ZFS to work inside the linux
kernel.
'';
homepage = http://zfsonlinux.org/;
platforms = platforms.linux;
license = licenses.gpl2Plus;
maintainers = with maintainers; [ jcumming wizeman wkennington fpletz ];
};
};
in in
assert any (n: n == configFile) [ "kernel" "user" "all" ]; assert any (n: n == configFile) [ "kernel" "user" "all" ];
assert buildKernel -> kernel != null; assert buildKernel -> kernel != null;
{ stdenv.mkDerivation rec {
splStable = common { name = "spl-${configFile}-${version}${optionalString buildKernel "-${kernel.version}"}";
version = "0.6.5.11"; version = "0.7.0";
sha256 = "192val8035pj2rryi3fwb134avzirhv5ifaj5021vh8bbjx75pd5";
}; src = fetchFromGitHub {
splUnstable = common { owner = "zfsonlinux";
version = "0.7.0-rc5"; repo = "spl";
sha256 = "17y25g02c9swi3n90lhjvazcnsr69nh50dz3b8g1c08zlz9n2akp"; rev = "spl-${version}";
}; sha256 = "05qqwhxc9nj94y28c97iwfz8gkjwicrhnkj425yb47gqa8rafazk";
} };
patches = [ ./const.patch ./install_prefix.patch ];
nativeBuildInputs = [ autoreconfHook ];
hardeningDisable = [ "pic" ];
preConfigure = ''
substituteInPlace ./module/spl/spl-generic.c --replace /usr/bin/hostid hostid
substituteInPlace ./module/spl/spl-generic.c --replace "PATH=/sbin:/usr/sbin:/bin:/usr/bin" "PATH=${coreutils}:${gawk}:/bin"
substituteInPlace ./module/splat/splat-vnode.c --replace "PATH=/sbin:/usr/sbin:/bin:/usr/bin" "PATH=${coreutils}:/bin"
substituteInPlace ./module/splat/splat-linux.c --replace "PATH=/sbin:/usr/sbin:/bin:/usr/bin" "PATH=${coreutils}:/bin"
'';
configureFlags = [
"--with-config=${configFile}"
] ++ optionals buildKernel [
"--with-linux=${kernel.dev}/lib/modules/${kernel.modDirVersion}/source"
"--with-linux-obj=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build"
];
enableParallelBuilding = true;
meta = {
description = "Kernel module driver for solaris porting layer (needed by in-kernel zfs)";
longDescription = ''
This kernel module is a porting layer for ZFS to work inside the linux
kernel.
'';
homepage = http://zfsonlinux.org/;
platforms = platforms.linux;
license = licenses.gpl2Plus;
maintainers = with maintainers; [ jcumming wizeman wkennington fpletz globin ];
};
}

View File

@ -12,145 +12,105 @@ with stdenv.lib;
let let
buildKernel = any (n: n == configFile) [ "kernel" "all" ]; buildKernel = any (n: n == configFile) [ "kernel" "all" ];
buildUser = any (n: n == configFile) [ "user" "all" ]; buildUser = any (n: n == configFile) [ "user" "all" ];
in stdenv.mkDerivation rec {
name = "zfs-${configFile}-${version}${optionalString buildKernel "-${kernel.version}"}";
version = "0.7.0";
common = { version, sha256, extraPatches, spl, incompatibleKernelVersion ? null } @ args: src = fetchFromGitHub {
if buildKernel && owner = "zfsonlinux";
(incompatibleKernelVersion != null) && repo = "zfs";
versionAtLeast kernel.version incompatibleKernelVersion then rev = "zfs-${version}";
throw "Linux v${kernel.version} is not yet supported by zfsonlinux v${version}. Try zfsUnstable or set the NixOS option boot.zfs.enableUnstable." sha256 = "16z0fl282rsmvgk608ii7n410swivkrisp112n2fhhjc1fs0zall";
else stdenv.mkDerivation rec { };
name = "zfs-${configFile}-${version}${optionalString buildKernel "-${kernel.version}"}";
src = fetchFromGitHub { patches = [
owner = "zfsonlinux"; (fetchpatch {
repo = "zfs"; url = "https://github.com/Mic92/zfs/compare/zfs-0.7.0-rc3...nixos-zfs-0.7.0-rc3.patch";
rev = "zfs-${version}"; sha256 = "1vlw98v8xvi8qapzl1jwm69qmfslwnbg3ry1lmacndaxnyckkvhh";
inherit sha256; })
}; ];
patches = extraPatches; buildInputs = [ autoreconfHook nukeReferences ]
++ optionals buildKernel [ spl ]
++ optionals buildUser [ zlib libuuid python attr ];
buildInputs = [ autoreconfHook nukeReferences ] # for zdb to get the rpath to libgcc_s, needed for pthread_cancel to work
++ optionals buildKernel [ spl ] NIX_CFLAGS_LINK = "-lgcc_s";
++ optionals buildUser [ zlib libuuid python attr ];
# for zdb to get the rpath to libgcc_s, needed for pthread_cancel to work hardeningDisable = [ "pic" ];
NIX_CFLAGS_LINK = "-lgcc_s";
hardeningDisable = [ "pic" ]; preConfigure = ''
substituteInPlace ./module/zfs/zfs_ctldir.c --replace "umount -t zfs" "${utillinux}/bin/umount -t zfs"
substituteInPlace ./module/zfs/zfs_ctldir.c --replace "mount -t zfs" "${utillinux}/bin/mount -t zfs"
substituteInPlace ./lib/libzfs/libzfs_mount.c --replace "/bin/umount" "${utillinux}/bin/umount"
substituteInPlace ./lib/libzfs/libzfs_mount.c --replace "/bin/mount" "${utillinux}/bin/mount"
substituteInPlace ./udev/rules.d/* --replace "/lib/udev/vdev_id" "$out/lib/udev/vdev_id"
substituteInPlace ./cmd/ztest/ztest.c --replace "/usr/sbin/ztest" "$out/sbin/ztest"
substituteInPlace ./cmd/ztest/ztest.c --replace "/usr/sbin/zdb" "$out/sbin/zdb"
substituteInPlace ./config/user-systemd.m4 --replace "/usr/lib/modules-load.d" "$out/etc/modules-load.d"
substituteInPlace ./config/zfs-build.m4 --replace "\$sysconfdir/init.d" "$out/etc/init.d"
substituteInPlace ./etc/zfs/Makefile.am --replace "\$(sysconfdir)" "$out/etc"
substituteInPlace ./cmd/zed/Makefile.am --replace "\$(sysconfdir)" "$out/etc"
substituteInPlace ./module/Makefile.in --replace "/bin/cp" "cp"
substituteInPlace ./etc/systemd/system/zfs-share.service.in \
--replace "@bindir@/rm " "${coreutils}/bin/rm "
./autogen.sh
'';
preConfigure = '' configureFlags = [
substituteInPlace ./module/zfs/zfs_ctldir.c --replace "umount -t zfs" "${utillinux}/bin/umount -t zfs" "--with-config=${configFile}"
substituteInPlace ./module/zfs/zfs_ctldir.c --replace "mount -t zfs" "${utillinux}/bin/mount -t zfs" ] ++ optionals buildUser [
substituteInPlace ./lib/libzfs/libzfs_mount.c --replace "/bin/umount" "${utillinux}/bin/umount" "--with-dracutdir=$(out)/lib/dracut"
substituteInPlace ./lib/libzfs/libzfs_mount.c --replace "/bin/mount" "${utillinux}/bin/mount" "--with-udevdir=$(out)/lib/udev"
substituteInPlace ./udev/rules.d/* --replace "/lib/udev/vdev_id" "$out/lib/udev/vdev_id" "--with-systemdunitdir=$(out)/etc/systemd/system"
substituteInPlace ./cmd/ztest/ztest.c --replace "/usr/sbin/ztest" "$out/sbin/ztest" "--with-systemdpresetdir=$(out)/etc/systemd/system-preset"
substituteInPlace ./cmd/ztest/ztest.c --replace "/usr/sbin/zdb" "$out/sbin/zdb" "--with-mounthelperdir=$(out)/bin"
substituteInPlace ./config/user-systemd.m4 --replace "/usr/lib/modules-load.d" "$out/etc/modules-load.d" "--sysconfdir=/etc"
substituteInPlace ./config/zfs-build.m4 --replace "\$sysconfdir/init.d" "$out/etc/init.d" "--localstatedir=/var"
substituteInPlace ./etc/zfs/Makefile.am --replace "\$(sysconfdir)" "$out/etc" "--enable-systemd"
substituteInPlace ./cmd/zed/Makefile.am --replace "\$(sysconfdir)" "$out/etc" ] ++ optionals buildKernel [
substituteInPlace ./module/Makefile.in --replace "/bin/cp" "cp" "--with-spl=${spl}/libexec/spl"
substituteInPlace ./etc/systemd/system/zfs-share.service.in \ "--with-linux=${kernel.dev}/lib/modules/${kernel.modDirVersion}/source"
--replace "@bindir@/rm " "${coreutils}/bin/rm " "--with-linux-obj=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build"
./autogen.sh ];
'';
configureFlags = [ enableParallelBuilding = true;
"--with-config=${configFile}"
] ++ optionals buildUser [
"--with-dracutdir=$(out)/lib/dracut"
"--with-udevdir=$(out)/lib/udev"
"--with-systemdunitdir=$(out)/etc/systemd/system"
"--with-systemdpresetdir=$(out)/etc/systemd/system-preset"
"--with-mounthelperdir=$(out)/bin"
"--sysconfdir=/etc"
"--localstatedir=/var"
"--enable-systemd"
] ++ optionals buildKernel [
"--with-spl=${spl}/libexec/spl"
"--with-linux=${kernel.dev}/lib/modules/${kernel.modDirVersion}/source"
"--with-linux-obj=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build"
];
enableParallelBuilding = true; installFlags = [
"sysconfdir=\${out}/etc"
"DEFAULT_INITCONF_DIR=\${out}/default"
];
installFlags = [ postInstall = ''
"sysconfdir=\${out}/etc" # Prevent kernel modules from depending on the Linux -dev output.
"DEFAULT_INITCONF_DIR=\${out}/default" nuke-refs $(find $out -name "*.ko")
]; '' + optionalString buildUser ''
# Remove provided services as they are buggy
rm $out/etc/systemd/system/zfs-import-*.service
postInstall = '' sed -i '/zfs-import-scan.service/d' $out/etc/systemd/system/*
# Prevent kernel modules from depending on the Linux -dev output.
nuke-refs $(find $out -name "*.ko")
'' + 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
for i in $out/etc/systemd/system/*; do # Fix pkgconfig.
substituteInPlace $i --replace "zfs-import-cache.service" "zfs-import.target" ln -s ../share/pkgconfig $out/lib/pkgconfig
done
# Fix pkgconfig. # Remove tests because they add a runtime dependency on gcc
ln -s ../share/pkgconfig $out/lib/pkgconfig rm -rf $out/share/zfs/zfs-tests
'';
# Remove tests because they add a runtime dependency on gcc meta = {
rm -rf $out/share/zfs/zfs-tests description = "ZFS Filesystem Linux Kernel module";
''; longDescription = ''
ZFS is a filesystem that combines a logical volume manager with a
meta = { Copy-On-Write filesystem with data integrity detection and repair,
description = "ZFS Filesystem Linux Kernel module"; snapshotting, cloning, block devices, deduplication, and more.
longDescription = '' '';
ZFS is a filesystem that combines a logical volume manager with a homepage = http://zfsonlinux.org/;
Copy-On-Write filesystem with data integrity detection and repair, license = licenses.cddl;
snapshotting, cloning, block devices, deduplication, and more. platforms = platforms.linux;
''; maintainers = with maintainers; [ jcumming wizeman wkennington fpletz globin ];
homepage = http://zfsonlinux.org/; };
license = licenses.cddl; }
platforms = platforms.linux;
maintainers = with maintainers; [ jcumming wizeman wkennington fpletz ];
};
};
in
assert any (n: n == configFile) [ "kernel" "user" "all" ];
assert buildKernel -> kernel != null && spl != null;
{
# 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.12";
version = "0.6.5.11";
# this package should point to the latest release.
sha256 = "1wqz43cjr21m3f52ahcikl2798pbzj5sfy16zqxwiqpv7iy09kr3";
extraPatches = [
(fetchpatch {
url = "https://github.com/Mic92/zfs/compare/zfs-0.6.5.8...nixos-zfs-0.6.5.8.patch";
sha256 = "14kqqphzg02m9a7qncdhff8958cfzdrvsid3vsrm9k75lqv1w08z";
})
];
inherit spl;
};
zfsUnstable = common {
# comment/uncomment if breaking kernel versions are known
incompatibleKernelVersion = null;
version = "0.7.0-rc5";
# this package should point to a version / git revision compatible with the latest kernel release
sha256 = "1k0fl6lbi5winri58v26k7gngd560hbj0247rnwcbc6j01ixsr5n";
extraPatches = [
(fetchpatch {
url = "https://github.com/Mic92/zfs/compare/zfs-0.7.0-rc3...nixos-zfs-0.7.0-rc3.patch";
sha256 = "1vlw98v8xvi8qapzl1jwm69qmfslwnbg3ry1lmacndaxnyckkvhh";
})
];
spl = splUnstable;
};
}

View File

@ -12250,12 +12250,10 @@ with pkgs;
sch_cake = callPackage ../os-specific/linux/sch_cake { }; sch_cake = callPackage ../os-specific/linux/sch_cake { };
inherit (callPackage ../os-specific/linux/spl { spl = callPackage ../os-specific/linux/spl {
configFile = "kernel"; configFile = "kernel";
inherit kernel; inherit kernel;
}) splStable splUnstable; };
spl = splStable;
sysdig = callPackage ../os-specific/linux/sysdig {}; sysdig = callPackage ../os-specific/linux/sysdig {};
@ -12279,12 +12277,10 @@ with pkgs;
x86_energy_perf_policy = callPackage ../os-specific/linux/x86_energy_perf_policy { }; x86_energy_perf_policy = callPackage ../os-specific/linux/x86_energy_perf_policy { };
inherit (callPackage ../os-specific/linux/zfs { zfs = callPackage ../os-specific/linux/zfs {
configFile = "kernel"; configFile = "kernel";
inherit kernel spl; inherit kernel spl;
}) zfsStable zfsUnstable; };
zfs = zfsStable;
}); });
# The current default kernel / kernel modules. # The current default kernel / kernel modules.
@ -12593,11 +12589,9 @@ with pkgs;
statifier = callPackage ../os-specific/linux/statifier { }; statifier = callPackage ../os-specific/linux/statifier { };
inherit (callPackage ../os-specific/linux/spl { spl = callPackage ../os-specific/linux/spl {
configFile = "user"; configFile = "user";
}) splStable splUnstable; };
spl = splStable;
sysdig = callPackage ../os-specific/linux/sysdig { sysdig = callPackage ../os-specific/linux/sysdig {
kernel = null; kernel = null;