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 { | ||||
|   name = "zfs-${version}-${kernel.version}"; | ||||
| callPackage ./generic.nix (args // rec { | ||||
|   version = "0.6.3-1.2"; | ||||
| 
 | ||||
|   src = fetchFromGitHub { | ||||
| @ -15,65 +14,4 @@ stdenv.mkDerivation rec { | ||||
|     ./mount_zfs_prefix.patch | ||||
|     ./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 { | ||||
|   name = "zfs-0.6.4-${kernel.version}"; | ||||
| callPackage ./generic.nix (args // rec { | ||||
|   version = "33b4de5"; | ||||
| 
 | ||||
|   src = fetchgit { | ||||
|     url = git://github.com/zfsonlinux/zfs.git; | ||||
| @ -14,65 +14,5 @@ stdenv.mkDerivation { | ||||
|     ./3.19-compat-git.patch # Remove once PR-3084 is mainlined | ||||
|   ]; | ||||
| 
 | ||||
|   buildInputs = [ spl_git 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_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 ]; | ||||
|   }; | ||||
| } | ||||
|   spl = spl_git; | ||||
| }) | ||||
|  | ||||
| @ -8802,8 +8802,14 @@ let | ||||
| 
 | ||||
|     virtualboxGuestAdditions = callPackage ../applications/virtualization/virtualbox/guest-additions { }; | ||||
| 
 | ||||
|     zfs = callPackage ../os-specific/linux/zfs { }; | ||||
|     zfs_git = callPackage ../os-specific/linux/zfs/git.nix { }; | ||||
|     zfs = callPackage ../os-specific/linux/zfs { | ||||
|       configFile = "kernel"; | ||||
|       inherit kernel; | ||||
|     }; | ||||
|     zfs_git = callPackage ../os-specific/linux/zfs/git.nix { | ||||
|       configFile = "kernel"; | ||||
|       inherit kernel; | ||||
|     }; | ||||
|   }; | ||||
| 
 | ||||
|   # The current default kernel / kernel modules. | ||||
| @ -9230,6 +9236,12 @@ let | ||||
| 
 | ||||
|   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 | ||||
| 
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 William A. Kennington III
						William A. Kennington III