2021-06-13 05:54:55 +01:00
|
|
|
{ lib
|
|
|
|
, stdenv
|
|
|
|
, fetchFromGitHub
|
|
|
|
, callPackage
|
|
|
|
, autoconf
|
|
|
|
, automake
|
|
|
|
, binutils
|
|
|
|
, cmake
|
|
|
|
, file
|
|
|
|
, git
|
|
|
|
, libtool
|
|
|
|
, nasm
|
|
|
|
, ncurses
|
|
|
|
, ocaml
|
|
|
|
, ocamlPackages
|
|
|
|
, openssl
|
|
|
|
, perl
|
|
|
|
, python3
|
|
|
|
, texinfo
|
|
|
|
, which
|
|
|
|
, writeShellScript
|
|
|
|
}:
|
|
|
|
|
|
|
|
stdenv.mkDerivation rec {
|
|
|
|
pname = "sgx-sdk";
|
|
|
|
version = "2.14";
|
|
|
|
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "intel";
|
|
|
|
repo = "linux-sgx";
|
2021-11-14 23:39:09 +00:00
|
|
|
rev = "sgx_${version}";
|
2021-06-13 05:54:55 +01:00
|
|
|
sha256 = "1cr2mkk459s270ng0yddgcryi0zc3dfmg9rmdrdh9mhy2mc1kx0g";
|
|
|
|
fetchSubmodules = true;
|
|
|
|
};
|
|
|
|
|
|
|
|
postPatch = ''
|
2021-11-14 23:32:36 +00:00
|
|
|
# https://github.com/intel/linux-sgx/pull/730
|
|
|
|
substituteInPlace buildenv.mk --replace '/bin/cp' 'cp'
|
|
|
|
|
|
|
|
# https://github.com/intel/linux-sgx/pull/752
|
|
|
|
ln -s "$src/external/epid-sdk/ext/ipp/include/sgx_ippcp.h" \
|
|
|
|
'external/ippcp_internal/inc/sgx_ippcp.h'
|
|
|
|
|
2021-06-13 05:54:55 +01:00
|
|
|
patchShebangs ./linux/installer/bin/build-installpkg.sh \
|
|
|
|
./linux/installer/common/sdk/createTarball.sh \
|
|
|
|
./linux/installer/common/sdk/install.sh
|
|
|
|
'';
|
|
|
|
|
|
|
|
dontConfigure = true;
|
|
|
|
|
|
|
|
# SDK built with stackprotector produces broken enclaves which crash at runtime.
|
|
|
|
# Disable all to be safe, SDK build configures compiler mitigations manually.
|
|
|
|
hardeningDisable = [ "all" ];
|
|
|
|
|
|
|
|
nativeBuildInputs = [
|
|
|
|
cmake
|
|
|
|
git
|
|
|
|
ocaml
|
|
|
|
ocamlPackages.ocamlbuild
|
|
|
|
perl
|
|
|
|
python3
|
|
|
|
texinfo
|
|
|
|
nasm
|
|
|
|
file
|
|
|
|
ncurses
|
|
|
|
autoconf
|
|
|
|
automake
|
|
|
|
];
|
|
|
|
|
|
|
|
buildInputs = [
|
|
|
|
libtool
|
|
|
|
openssl
|
|
|
|
];
|
|
|
|
|
|
|
|
BINUTILS_DIR = "${binutils}/bin";
|
|
|
|
|
|
|
|
# Build external/ippcp_internal first. The Makefile is rewritten to make the
|
|
|
|
# build faster by splitting different versions of ipp-crypto builds and to
|
|
|
|
# avoid patching the Makefile for reproducibility issues.
|
2021-11-14 23:10:36 +00:00
|
|
|
buildPhase =
|
|
|
|
let
|
|
|
|
ipp-crypto-no_mitigation = callPackage (import ./ipp-crypto.nix) { };
|
2021-06-13 05:54:55 +01:00
|
|
|
|
2021-11-14 23:10:36 +00:00
|
|
|
sgx-asm-pp = "python ${src}/build-scripts/sgx-asm-pp.py --assembler=nasm";
|
2021-06-13 05:54:55 +01:00
|
|
|
|
2021-11-14 23:10:36 +00:00
|
|
|
nasm-load = writeShellScript "nasm-load" "${sgx-asm-pp} --MITIGATION-CVE-2020-0551=LOAD $@";
|
|
|
|
ipp-crypto-cve_2020_0551_load = callPackage (import ./ipp-crypto.nix) {
|
|
|
|
extraCmakeFlags = [ "-DCMAKE_ASM_NASM_COMPILER=${nasm-load}" ];
|
|
|
|
};
|
2021-06-13 05:54:55 +01:00
|
|
|
|
2021-11-14 23:10:36 +00:00
|
|
|
nasm-cf = writeShellScript "nasm-cf" "${sgx-asm-pp} --MITIGATION-CVE-2020-0551=CF $@";
|
|
|
|
ipp-crypto-cve_2020_0551_cf = callPackage (import ./ipp-crypto.nix) {
|
|
|
|
extraCmakeFlags = [ "-DCMAKE_ASM_NASM_COMPILER=${nasm-cf}" ];
|
|
|
|
};
|
|
|
|
in
|
|
|
|
''
|
|
|
|
cd external/ippcp_internal
|
2021-06-13 05:54:55 +01:00
|
|
|
|
2021-11-14 23:10:36 +00:00
|
|
|
mkdir -p lib/linux/intel64/no_mitigation
|
|
|
|
cp ${ipp-crypto-no_mitigation}/lib/intel64/libippcp.a lib/linux/intel64/no_mitigation
|
|
|
|
chmod a+w lib/linux/intel64/no_mitigation/libippcp.a
|
|
|
|
cp ${ipp-crypto-no_mitigation}/include/* ./inc
|
2021-06-13 05:54:55 +01:00
|
|
|
|
2021-11-14 23:10:36 +00:00
|
|
|
mkdir -p lib/linux/intel64/cve_2020_0551_load
|
|
|
|
cp ${ipp-crypto-cve_2020_0551_load}/lib/intel64/libippcp.a lib/linux/intel64/cve_2020_0551_load
|
|
|
|
chmod a+w lib/linux/intel64/cve_2020_0551_load/libippcp.a
|
2021-06-13 05:54:55 +01:00
|
|
|
|
2021-11-14 23:10:36 +00:00
|
|
|
mkdir -p lib/linux/intel64/cve_2020_0551_cf
|
|
|
|
cp ${ipp-crypto-cve_2020_0551_cf}/lib/intel64/libippcp.a lib/linux/intel64/cve_2020_0551_cf
|
|
|
|
chmod a+w lib/linux/intel64/cve_2020_0551_cf/libippcp.a
|
2021-06-13 05:54:55 +01:00
|
|
|
|
2021-11-14 23:10:36 +00:00
|
|
|
rm -f ./inc/ippcp.h
|
|
|
|
patch ${ipp-crypto-no_mitigation}/include/ippcp.h -i ./inc/ippcp20u3.patch -o ./inc/ippcp.h
|
2021-06-13 05:54:55 +01:00
|
|
|
|
2021-11-14 23:10:36 +00:00
|
|
|
mkdir -p license
|
|
|
|
cp ${ipp-crypto-no_mitigation.src}/LICENSE ./license
|
2021-06-13 05:54:55 +01:00
|
|
|
|
2021-11-14 23:10:36 +00:00
|
|
|
# Build the SDK installation package.
|
|
|
|
cd ../..
|
2021-06-13 05:54:55 +01:00
|
|
|
|
2021-11-14 23:10:36 +00:00
|
|
|
# Nix patches make so that $(SHELL) defaults to "sh" instead of "/bin/sh".
|
|
|
|
# The build uses $(SHELL) as an argument to file -L which requires a path.
|
|
|
|
make SHELL=$SHELL sdk_install_pkg
|
2021-06-13 05:54:55 +01:00
|
|
|
|
2021-11-14 23:10:36 +00:00
|
|
|
runHook postBuild
|
|
|
|
'';
|
2021-06-13 05:54:55 +01:00
|
|
|
|
|
|
|
postBuild = ''
|
|
|
|
patchShebangs ./linux/installer/bin/sgx_linux_x64_sdk_*.bin
|
|
|
|
'';
|
|
|
|
|
|
|
|
installPhase = ''
|
|
|
|
echo -e 'no\n'$out | ./linux/installer/bin/sgx_linux_x64_sdk_*.bin
|
|
|
|
'';
|
|
|
|
|
|
|
|
dontFixup = true;
|
|
|
|
|
|
|
|
doInstallCheck = true;
|
|
|
|
installCheckInputs = [ which ];
|
|
|
|
installCheckPhase = ''
|
|
|
|
source $out/sgxsdk/environment
|
|
|
|
cd SampleCode/SampleEnclave
|
|
|
|
make SGX_MODE=SGX_SIM
|
|
|
|
./app
|
|
|
|
'';
|
|
|
|
|
|
|
|
meta = with lib; {
|
|
|
|
description = "Intel SGX SDK for Linux built with IPP Crypto Library";
|
|
|
|
homepage = "https://github.com/intel/linux-sgx";
|
|
|
|
maintainers = with maintainers; [ sbellem arturcygan ];
|
|
|
|
platforms = [ "x86_64-linux" ];
|
|
|
|
license = with licenses; [ bsd3 ];
|
|
|
|
};
|
|
|
|
}
|