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

54 lines
1.5 KiB
Nix
Raw Normal View History

{ stdenv, fetchurl, fetchpatch, lvm2, json_c
, openssl, libuuid, pkgconfig, popt
2018-06-16 00:20:53 +01:00
, enablePython ? false, python2 ? null }:
2016-11-18 08:45:41 +00:00
assert enablePython -> python2 != null;
stdenv.mkDerivation rec {
2018-08-20 15:42:51 +01:00
name = "cryptsetup-2.0.4";
2012-08-10 21:42:29 +01:00
2018-08-20 15:43:48 +01:00
outputs = [ "out" "dev" "man" ];
src = fetchurl {
2018-04-03 12:25:13 +01:00
url = "mirror://kernel/linux/utils/cryptsetup/v2.0/${name}.tar.xz";
2018-08-20 15:42:51 +01:00
sha256 = "0d2p9g2wqcv6l3671gvw96p16jadbgyh21ddy2bhqgi96dq3qflx";
};
# Disable 4 test cases that fail in a sandbox
patches = [ ./disable-failing-tests.patch ];
2018-08-08 22:18:19 +01:00
postPatch = ''
patchShebangs tests
${stdenv.lib.optionalString enablePython ''
patchShebangs ./python/pycryptsetup-test.py
''}
# O_DIRECT is filesystem dependent and fails in a sandbox (on tmpfs)
# and on several filesystem types (btrfs, zfs) without sandboxing.
# Remove it, see discussion in #46151
substituteInPlace tests/unit-utils-io.c --replace "| O_DIRECT" ""
2018-08-08 22:18:19 +01:00
'';
2018-06-16 00:20:53 +01:00
NIX_LDFLAGS = "-lgcc_s";
configureFlags = [
"--disable-kernel_crypto"
"--enable-cryptsetup-reencrypt"
"--with-crypto_backend=openssl"
] ++ stdenv.lib.optional enablePython "--enable-python";
2012-08-10 21:42:29 +01:00
nativeBuildInputs = [ pkgconfig ];
buildInputs = [ lvm2 json_c openssl libuuid popt ]
2018-06-16 00:20:53 +01:00
++ stdenv.lib.optional enablePython python2;
doCheck = true;
meta = {
homepage = https://gitlab.com/cryptsetup/cryptsetup/;
description = "LUKS for dm-crypt";
license = stdenv.lib.licenses.gpl2;
maintainers = with stdenv.lib.maintainers; [ chaoflow ];
platforms = with stdenv.lib.platforms; linux;
};
}