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

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

51 lines
1.4 KiB
Nix
Raw Normal View History

2021-02-10 00:37:24 +01:00
{ lib
, stdenv
, fetchFromGitHub
, kernel
, nixosTests
2021-02-10 00:37:24 +01:00
}:
let
tag = "0.3.1";
in
2021-02-10 00:37:24 +01:00
stdenv.mkDerivation {
pname = "apfs";
version = "${tag}-${kernel.version}";
2021-02-10 00:37:24 +01:00
src = fetchFromGitHub {
owner = "linux-apfs";
repo = "linux-apfs-rw";
rev = "v${tag}";
sha256 = "sha256-KYPZsCAEqJl0VjV/TmJWi20Y7yApIJH0YMwQIL80Ep4=";
2021-02-10 00:37:24 +01:00
};
hardeningDisable = [ "pic" ];
nativeBuildInputs = kernel.moduleBuildDependencies;
makeFlags = kernel.makeFlags ++ [
2021-02-10 00:37:24 +01:00
"KERNELRELEASE=${kernel.modDirVersion}"
"KERNEL_DIR=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build"
"INSTALL_MOD_PATH=$(out)"
];
passthru.tests.test = nixosTests.apfs;
2021-02-10 00:37:24 +01:00
meta = with lib; {
description = "APFS module for linux";
longDescription = ''
The Apple File System (APFS) is the copy-on-write filesystem currently
used on all Apple devices. This module provides a degree of experimental
support on Linux.
If you make use of the write support, expect data corruption.
Read-only support is somewhat more complete, with sealed volumes,
snapshots, and all the missing compression algorithms recently added.
Encryption is still not in the works though.
'';
2021-02-10 00:37:24 +01:00
homepage = "https://github.com/linux-apfs/linux-apfs-rw";
license = licenses.gpl2Only;
platforms = platforms.linux;
broken = kernel.kernelOlder "4.9";
2021-02-10 00:37:24 +01:00
maintainers = with maintainers; [ Luflosi ];
};
}