57 lines
1.8 KiB
Nix
57 lines
1.8 KiB
Nix
{ stdenv, lib, fetchFromGitHub, fetchpatch, kernel, kernelAtLeast }:
|
|
|
|
stdenv.mkDerivation rec {
|
|
name = "isgx-${version}-${kernel.version}";
|
|
version = "2.11";
|
|
|
|
src = fetchFromGitHub {
|
|
owner = "intel";
|
|
repo = "linux-sgx-driver";
|
|
rev = "sgx_driver_${version}";
|
|
hash = "sha256-zZ0FgCx63LCNmvQ909O27v/o4+93gefhgEE/oDr/bHw=";
|
|
};
|
|
|
|
patches = [
|
|
# Fixes build with kernel >= 5.8
|
|
(fetchpatch {
|
|
url = "https://github.com/intel/linux-sgx-driver/commit/276c5c6a064d22358542f5e0aa96b1c0ace5d695.patch";
|
|
sha256 = "sha256-PmchqYENIbnJ51G/tkdap/g20LUrJEoQ4rDtqy6hj24=";
|
|
})
|
|
# Fixes detection with kernel >= 5.11
|
|
(fetchpatch {
|
|
url = "https://github.com/intel/linux-sgx-driver/commit/ed2c256929962db1a8805db53bed09bb8f2f4de3.patch";
|
|
sha256 = "sha256-MRbgS4U8FTCP1J1n+rhsvbXxKDytfl6B7YlT9Izq05U=";
|
|
})
|
|
];
|
|
|
|
hardeningDisable = [ "pic" ];
|
|
|
|
nativeBuildInputs = kernel.moduleBuildDependencies;
|
|
|
|
makeFlags = [
|
|
"KDIR=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build"
|
|
];
|
|
|
|
installPhase = ''
|
|
runHook preInstall
|
|
install -D isgx.ko -t $out/lib/modules/${kernel.modDirVersion}/kernel/drivers/intel/sgx
|
|
runHook postInstall
|
|
'';
|
|
|
|
meta = with lib; {
|
|
description = "Intel SGX Linux Driver";
|
|
longDescription = ''
|
|
The linux-sgx-driver project (isgx) hosts an out-of-tree driver
|
|
for the Linux* Intel(R) SGX software stack, which would be used
|
|
until the driver upstreaming process is complete (before 5.11.0).
|
|
|
|
It is used to support Enhanced Privacy Identification (EPID)
|
|
based attestation on the platforms without Flexible Launch Control.
|
|
'';
|
|
homepage = "https://github.com/intel/linux-sgx-driver";
|
|
license = with licenses; [ bsd3 /* OR */ gpl2Only ];
|
|
maintainers = with maintainers; [ oxalica ];
|
|
platforms = [ "x86_64-linux" ];
|
|
};
|
|
}
|