mirror of
https://github.com/ilyakooo0/nixpkgs.git
synced 2024-09-23 13:48:21 +03:00
zfs: Modularize and create a userspace only package
This commit is contained in:
parent
91e6126a32
commit
f177036817
@ -1,7 +1,6 @@
|
|||||||
{ stdenv, fetchFromGitHub, kernel, spl, perl, python, autoconf, automake, libtool, zlib, libuuid, coreutils, utillinux }:
|
{ callPackage, fetchFromGitHub, ... } @ args:
|
||||||
|
|
||||||
stdenv.mkDerivation rec {
|
callPackage ./generic.nix (args // rec {
|
||||||
name = "zfs-${version}-${kernel.version}";
|
|
||||||
version = "0.6.3-1.2";
|
version = "0.6.3-1.2";
|
||||||
|
|
||||||
src = fetchFromGitHub {
|
src = fetchFromGitHub {
|
||||||
@ -15,65 +14,4 @@ stdenv.mkDerivation rec {
|
|||||||
./mount_zfs_prefix.patch
|
./mount_zfs_prefix.patch
|
||||||
./nix-build.patch # Remove in >=0.6.4
|
./nix-build.patch # Remove in >=0.6.4
|
||||||
];
|
];
|
||||||
|
})
|
||||||
buildInputs = [ spl perl python autoconf automake libtool zlib libuuid coreutils ];
|
|
||||||
|
|
||||||
# for zdb to get the rpath to libgcc_s, needed for pthread_cancel to work
|
|
||||||
NIX_CFLAGS_LINK = "-lgcc_s";
|
|
||||||
|
|
||||||
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"
|
|
||||||
|
|
||||||
./autogen.sh
|
|
||||||
'';
|
|
||||||
|
|
||||||
configureFlags = [
|
|
||||||
"--enable-systemd"
|
|
||||||
"--with-linux=${kernel.dev}/lib/modules/${kernel.modDirVersion}/source"
|
|
||||||
"--with-linux-obj=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build"
|
|
||||||
"--with-spl=${spl}/libexec/spl"
|
|
||||||
"--with-dracutdir=$(out)/lib/dracut"
|
|
||||||
"--with-udevdir=$(out)/lib/udev"
|
|
||||||
"--with-systemdunitdir=$(out)/etc/systemd/system"
|
|
||||||
"--with-systemdpresetdir=$(out)/etc/systemd/system-preset"
|
|
||||||
"--sysconfdir=/etc"
|
|
||||||
"--localstatedir=/var"
|
|
||||||
];
|
|
||||||
|
|
||||||
enableParallelBuilding = true;
|
|
||||||
|
|
||||||
# Remove provided services as they are buggy
|
|
||||||
postInstall = ''
|
|
||||||
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
|
|
||||||
'';
|
|
||||||
|
|
||||||
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 = http://zfsonlinux.org/;
|
|
||||||
license = stdenv.lib.licenses.cddl;
|
|
||||||
platforms = stdenv.lib.platforms.linux;
|
|
||||||
maintainers = with stdenv.lib.maintainers; [ jcumming wizeman ];
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
94
pkgs/os-specific/linux/zfs/generic.nix
Normal file
94
pkgs/os-specific/linux/zfs/generic.nix
Normal file
@ -0,0 +1,94 @@
|
|||||||
|
{ stdenv, fetchFromGitHub, autoconf, automake, libtool, utillinux
|
||||||
|
, configFile ? "all"
|
||||||
|
|
||||||
|
# Userspace dependencies
|
||||||
|
, zlib, libuuid, python
|
||||||
|
|
||||||
|
# Kernel dependencies
|
||||||
|
, kernel ? null, spl ? null
|
||||||
|
|
||||||
|
# Version specific settings
|
||||||
|
, version, src, patches
|
||||||
|
, ...
|
||||||
|
}:
|
||||||
|
|
||||||
|
with stdenv.lib;
|
||||||
|
let
|
||||||
|
buildKernel = any (n: n == configFile) [ "kernel" "all" ];
|
||||||
|
buildUser = any (n: n == configFile) [ "user" "all" ];
|
||||||
|
in
|
||||||
|
|
||||||
|
assert any (n: n == configFile) [ "kernel" "user" "all" ];
|
||||||
|
assert buildKernel -> kernel != null && spl != null;
|
||||||
|
|
||||||
|
stdenv.mkDerivation rec {
|
||||||
|
name = "zfs-${configFile}-${version}${optionalString buildKernel "-${kernel.version}"}";
|
||||||
|
|
||||||
|
inherit version src patches;
|
||||||
|
|
||||||
|
buildInputs = [ autoconf automake libtool ]
|
||||||
|
++ optionals buildKernel [ spl ]
|
||||||
|
++ optionals buildUser [ zlib libuuid python ];
|
||||||
|
|
||||||
|
# for zdb to get the rpath to libgcc_s, needed for pthread_cancel to work
|
||||||
|
NIX_CFLAGS_LINK = "-lgcc_s";
|
||||||
|
|
||||||
|
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"
|
||||||
|
|
||||||
|
./autogen.sh
|
||||||
|
'';
|
||||||
|
|
||||||
|
configureFlags = [
|
||||||
|
"--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"
|
||||||
|
"--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;
|
||||||
|
|
||||||
|
# Remove provided services as they are buggy
|
||||||
|
postInstall = optionalString buildUser ''
|
||||||
|
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
|
||||||
|
'';
|
||||||
|
|
||||||
|
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 = http://zfsonlinux.org/;
|
||||||
|
license = licenses.cddl;
|
||||||
|
platforms = platforms.linux;
|
||||||
|
maintainers = with maintainers; [ jcumming wizeman wkennington ];
|
||||||
|
};
|
||||||
|
}
|
@ -1,7 +1,7 @@
|
|||||||
{ stdenv, fetchgit, kernel, spl_git, perl, python, autoconf, automake, libtool, zlib, libuuid, coreutils, utillinux }:
|
{ callPackage, fetchgit, spl_git, ... } @ args:
|
||||||
|
|
||||||
stdenv.mkDerivation {
|
callPackage ./generic.nix (args // rec {
|
||||||
name = "zfs-0.6.4-${kernel.version}";
|
version = "33b4de5";
|
||||||
|
|
||||||
src = fetchgit {
|
src = fetchgit {
|
||||||
url = git://github.com/zfsonlinux/zfs.git;
|
url = git://github.com/zfsonlinux/zfs.git;
|
||||||
@ -14,65 +14,5 @@ stdenv.mkDerivation {
|
|||||||
./3.19-compat-git.patch # Remove once PR-3084 is mainlined
|
./3.19-compat-git.patch # Remove once PR-3084 is mainlined
|
||||||
];
|
];
|
||||||
|
|
||||||
buildInputs = [ spl_git perl python autoconf automake libtool zlib libuuid coreutils ];
|
spl = spl_git;
|
||||||
|
})
|
||||||
# for zdb to get the rpath to libgcc_s, needed for pthread_cancel to work
|
|
||||||
NIX_CFLAGS_LINK = "-lgcc_s";
|
|
||||||
|
|
||||||
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"
|
|
||||||
|
|
||||||
./autogen.sh
|
|
||||||
'';
|
|
||||||
|
|
||||||
configureFlags = [
|
|
||||||
"--enable-systemd"
|
|
||||||
"--with-linux=${kernel.dev}/lib/modules/${kernel.modDirVersion}/source"
|
|
||||||
"--with-linux-obj=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build"
|
|
||||||
"--with-spl=${spl_git}/libexec/spl"
|
|
||||||
"--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)/sbin"
|
|
||||||
"--sysconfdir=/etc"
|
|
||||||
"--localstatedir=/var"
|
|
||||||
];
|
|
||||||
|
|
||||||
enableParallelBuilding = true;
|
|
||||||
|
|
||||||
# Remove provided services as they are buggy
|
|
||||||
postInstall = ''
|
|
||||||
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
|
|
||||||
'';
|
|
||||||
|
|
||||||
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 = http://zfsonlinux.org/;
|
|
||||||
license = stdenv.lib.licenses.cddl;
|
|
||||||
platforms = stdenv.lib.platforms.linux;
|
|
||||||
maintainers = with stdenv.lib.maintainers; [ wizeman ];
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
@ -8802,8 +8802,14 @@ let
|
|||||||
|
|
||||||
virtualboxGuestAdditions = callPackage ../applications/virtualization/virtualbox/guest-additions { };
|
virtualboxGuestAdditions = callPackage ../applications/virtualization/virtualbox/guest-additions { };
|
||||||
|
|
||||||
zfs = callPackage ../os-specific/linux/zfs { };
|
zfs = callPackage ../os-specific/linux/zfs {
|
||||||
zfs_git = callPackage ../os-specific/linux/zfs/git.nix { };
|
configFile = "kernel";
|
||||||
|
inherit kernel;
|
||||||
|
};
|
||||||
|
zfs_git = callPackage ../os-specific/linux/zfs/git.nix {
|
||||||
|
configFile = "kernel";
|
||||||
|
inherit kernel;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
# The current default kernel / kernel modules.
|
# The current default kernel / kernel modules.
|
||||||
@ -9230,6 +9236,12 @@ let
|
|||||||
|
|
||||||
zd1211fw = callPackage ../os-specific/linux/firmware/zd1211 { };
|
zd1211fw = callPackage ../os-specific/linux/firmware/zd1211 { };
|
||||||
|
|
||||||
|
zfs = callPackage ../os-specific/linux/zfs {
|
||||||
|
configFile = "user";
|
||||||
|
};
|
||||||
|
zfs_git = callPackage ../os-specific/linux/zfs/git.nix {
|
||||||
|
configFile = "user";
|
||||||
|
};
|
||||||
|
|
||||||
### DATA
|
### DATA
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user