zfsUnstable: init at 2017-09-12
This commit is contained in:
parent
f4dfa30d24
commit
1ecf3e862f
@ -192,7 +192,6 @@ 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" ])
|
||||||
|
@ -24,7 +24,11 @@ let
|
|||||||
|
|
||||||
kernel = config.boot.kernelPackages;
|
kernel = config.boot.kernelPackages;
|
||||||
|
|
||||||
packages = {
|
packages = if config.boot.zfs.enableUnstable then {
|
||||||
|
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;
|
||||||
@ -58,6 +62,19 @@ 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 = [];
|
||||||
|
@ -10,18 +10,16 @@ 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
|
common = { version
|
||||||
assert any (n: n == configFile) [ "kernel" "user" "all" ];
|
, sha256
|
||||||
assert buildKernel -> kernel != null;
|
, rev ? "spl-${version}"
|
||||||
stdenv.mkDerivation rec {
|
} @ args : stdenv.mkDerivation rec {
|
||||||
name = "spl-${configFile}-${version}${optionalString buildKernel "-${kernel.version}"}";
|
name = "spl-${configFile}-${version}${optionalString buildKernel "-${kernel.version}"}";
|
||||||
version = "0.7.1";
|
|
||||||
|
|
||||||
src = fetchFromGitHub {
|
src = fetchFromGitHub {
|
||||||
owner = "zfsonlinux";
|
owner = "zfsonlinux";
|
||||||
repo = "spl";
|
repo = "spl";
|
||||||
rev = "spl-${version}";
|
inherit rev sha256;
|
||||||
sha256 = "0m8qhbdd8n40lbd91s30q4lrw8g169sha0410c8rwk2d5qfaxv9n";
|
|
||||||
};
|
};
|
||||||
|
|
||||||
patches = [ ./const.patch ./install_prefix.patch ];
|
patches = [ ./const.patch ./install_prefix.patch ];
|
||||||
@ -59,4 +57,19 @@ stdenv.mkDerivation rec {
|
|||||||
license = licenses.gpl2Plus;
|
license = licenses.gpl2Plus;
|
||||||
maintainers = with maintainers; [ jcumming wizeman wkennington fpletz globin ];
|
maintainers = with maintainers; [ jcumming wizeman wkennington fpletz globin ];
|
||||||
};
|
};
|
||||||
|
};
|
||||||
|
in
|
||||||
|
assert any (n: n == configFile) [ "kernel" "user" "all" ];
|
||||||
|
assert buildKernel -> kernel != null;
|
||||||
|
{
|
||||||
|
splStable = common {
|
||||||
|
version = "0.7.1";
|
||||||
|
sha256 = "0m8qhbdd8n40lbd91s30q4lrw8g169sha0410c8rwk2d5qfaxv9n";
|
||||||
|
};
|
||||||
|
|
||||||
|
splUnstable = common {
|
||||||
|
version = "2017-08-11";
|
||||||
|
rev = "9df9692637aeee416f509c7f39655beb2d35b549";
|
||||||
|
sha256 = "1dggf6xqgk2f7vccv6cgvr8krj7h9f921szp1j2qbxnnq41m37mi";
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
@ -13,23 +13,30 @@ 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 {
|
common = { version
|
||||||
|
, sha256
|
||||||
|
, extraPatches
|
||||||
|
, spl
|
||||||
|
, rev ? "zfs-${version}"
|
||||||
|
, isUnstable ? false
|
||||||
|
, incompatibleKernelVersion ? null } @ args:
|
||||||
|
if buildKernel &&
|
||||||
|
(incompatibleKernelVersion != null) &&
|
||||||
|
versionAtLeast kernel.version incompatibleKernelVersion then
|
||||||
|
throw ''
|
||||||
|
Linux v${kernel.version} is not yet supported by zfsonlinux v${version}.
|
||||||
|
${stdenv.lib.optional (!isUnstable) "Try zfsUnstable or set the NixOS option boot.zfs.enableUnstable."}
|
||||||
|
''
|
||||||
|
else stdenv.mkDerivation rec {
|
||||||
name = "zfs-${configFile}-${version}${optionalString buildKernel "-${kernel.version}"}";
|
name = "zfs-${configFile}-${version}${optionalString buildKernel "-${kernel.version}"}";
|
||||||
version = "0.7.1";
|
|
||||||
|
|
||||||
src = fetchFromGitHub {
|
src = fetchFromGitHub {
|
||||||
owner = "zfsonlinux";
|
owner = "zfsonlinux";
|
||||||
repo = "zfs";
|
repo = "zfs";
|
||||||
rev = "zfs-${version}";
|
inherit rev sha256;
|
||||||
sha256 = "0czal6lpl8igrhwmqh5jcgx07rlcgnrfg6ywzf681vsyh3gaxj9n";
|
|
||||||
};
|
};
|
||||||
|
|
||||||
patches = [
|
patches = extraPatches;
|
||||||
(fetchpatch {
|
|
||||||
url = "https://github.com/Mic92/zfs/compare/zfs-0.7.0-rc3...nixos-zfs-0.7.0-rc3.patch";
|
|
||||||
sha256 = "1vlw98v8xvi8qapzl1jwm69qmfslwnbg3ry1lmacndaxnyckkvhh";
|
|
||||||
})
|
|
||||||
];
|
|
||||||
|
|
||||||
buildInputs = [ autoreconfHook nukeReferences ]
|
buildInputs = [ autoreconfHook nukeReferences ]
|
||||||
++ optionals buildKernel [ spl ]
|
++ optionals buildKernel [ spl ]
|
||||||
@ -116,9 +123,53 @@ in stdenv.mkDerivation rec {
|
|||||||
Copy-On-Write filesystem with data integrity detection and repair,
|
Copy-On-Write filesystem with data integrity detection and repair,
|
||||||
snapshotting, cloning, block devices, deduplication, and more.
|
snapshotting, cloning, block devices, deduplication, and more.
|
||||||
'';
|
'';
|
||||||
homepage = http://zfsonlinux.org/;
|
home = http://zfsonlinux.org/;
|
||||||
license = licenses.cddl;
|
license = licenses.cddl;
|
||||||
platforms = platforms.linux;
|
platforms = platforms.linux;
|
||||||
maintainers = with maintainers; [ jcumming wizeman wkennington fpletz globin ];
|
maintainers = with maintainers; [ jcumming wizeman wkennington fpletz globin ];
|
||||||
};
|
};
|
||||||
|
};
|
||||||
|
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 = null;
|
||||||
|
|
||||||
|
# this package should point to the latest release.
|
||||||
|
version = "0.7.1";
|
||||||
|
|
||||||
|
sha256 = "0czal6lpl8igrhwmqh5jcgx07rlcgnrfg6ywzf681vsyh3gaxj9n";
|
||||||
|
|
||||||
|
extraPatches = [
|
||||||
|
(fetchpatch {
|
||||||
|
url = "https://github.com/Mic92/zfs/compare/zfs-0.7.0-rc3...nixos-zfs-0.7.0-rc3.patch";
|
||||||
|
sha256 = "1vlw98v8xvi8qapzl1jwm69qmfslwnbg3ry1lmacndaxnyckkvhh";
|
||||||
|
})
|
||||||
|
];
|
||||||
|
|
||||||
|
inherit spl;
|
||||||
|
};
|
||||||
|
|
||||||
|
zfsUnstable = common {
|
||||||
|
# comment/uncomment if breaking kernel versions are known
|
||||||
|
incompatibleKernelVersion = null;
|
||||||
|
|
||||||
|
# this package should point to a version / git revision compatible with the latest kernel release
|
||||||
|
version = "2017-09-12";
|
||||||
|
|
||||||
|
rev = "ded8f06a3cfee60b3a8ea5309e9c4d0e567ed3b5";
|
||||||
|
sha256 = "0yn4fg4a00hpflmmr0jbbhfb921nygpw2xbbjy35abl57k6zk375";
|
||||||
|
isUnstable = true;
|
||||||
|
|
||||||
|
extraPatches = [
|
||||||
|
(fetchpatch {
|
||||||
|
url = "https://github.com/Mic92/zfs/compare/ded8f06a3cfee...nixos-zfs-2017-09-12.patch";
|
||||||
|
sha256 = "033wf4jn0h0kp0h47ai98rywnkv5jwvf3xwym30phnaf8xxdx8aj";
|
||||||
|
})
|
||||||
|
];
|
||||||
|
|
||||||
|
spl = splUnstable;
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
@ -12376,10 +12376,12 @@ with pkgs;
|
|||||||
|
|
||||||
sch_cake = callPackage ../os-specific/linux/sch_cake { };
|
sch_cake = callPackage ../os-specific/linux/sch_cake { };
|
||||||
|
|
||||||
spl = callPackage ../os-specific/linux/spl {
|
inherit (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 {};
|
||||||
|
|
||||||
@ -12403,10 +12405,12 @@ 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 { };
|
||||||
|
|
||||||
zfs = callPackage ../os-specific/linux/zfs {
|
inherit (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.
|
||||||
@ -12704,9 +12708,9 @@ with pkgs;
|
|||||||
|
|
||||||
statifier = callPackage ../os-specific/linux/statifier { };
|
statifier = callPackage ../os-specific/linux/statifier { };
|
||||||
|
|
||||||
spl = callPackage ../os-specific/linux/spl {
|
inherit (callPackage ../os-specific/linux/spl {
|
||||||
configFile = "user";
|
configFile = "user";
|
||||||
};
|
}) splStable splUnstable;
|
||||||
|
|
||||||
sysdig = callPackage ../os-specific/linux/sysdig {
|
sysdig = callPackage ../os-specific/linux/sysdig {
|
||||||
kernel = null;
|
kernel = null;
|
||||||
@ -12910,9 +12914,11 @@ with pkgs;
|
|||||||
|
|
||||||
zd1211fw = callPackage ../os-specific/linux/firmware/zd1211 { };
|
zd1211fw = callPackage ../os-specific/linux/firmware/zd1211 { };
|
||||||
|
|
||||||
zfs = callPackage ../os-specific/linux/zfs {
|
inherit (callPackage ../os-specific/linux/zfs {
|
||||||
configFile = "user";
|
configFile = "user";
|
||||||
};
|
}) zfsStable zfsUnstable;
|
||||||
|
|
||||||
|
zfs = zfsStable;
|
||||||
|
|
||||||
### DATA
|
### DATA
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user