-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdefault.nix
54 lines (52 loc) · 1.68 KB
/
default.nix
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
let
sources = import ./nix/sources.nix;
pkgs = import sources.nixpkgs { };
sgx = import sources.sgx;
in
pkgs.stdenv.mkDerivation {
name = "sgx-hashmachine";
# FIXME not sure why but the build is non-deterministic if using src = ./.;
# Possibly some untracked file(s) causing the problem ...?
# src = ./.;
# NOTE The commit (rev) cannot include this file, and therefore will at the very
# best one commit behind the commit including this file.
src = pkgs.fetchFromGitHub {
owner = "sbellem";
repo = "sgx-hashmachine";
rev = "70fb483c68aecedf292a15486e16cc5873973fd5";
# Command to get the sha256 hash (note the --fetch-submodules arg):
# nix run -f '<nixpkgs>' nix-prefetch-github -c nix-prefetch-github --rev 70fb483c68aecedf292a15486e16cc5873973fd5 sbellem sgx-hashmachine
sha256 = "073p9q6a72p4wzrq2fiw5l6mdhgz7ng064jn9z7x98myrd60vssc";
};
preConfigure = ''
export SGX_SDK=${sgx.sgx-sdk}/sgxsdk
export PATH=$PATH:$SGX_SDK/bin:$SGX_SDK/bin/x64
export PKG_CONFIG_PATH=$SGX_SDK/pkgconfig
export LD_LIBRARY_PATH=$SGX_SDK/sdk_libs
./bootstrap
'';
configureFlags = ["--with-sgxsdk=$SGX_SDK"];
buildInputs = with pkgs; [
sgx.sgx-sdk
unixtools.xxd
bashInteractive
autoconf
automake
libtool
file
openssl
which
];
installPhase = ''
runHook preInstall
mkdir -p $out/bin
cp Enclave/Enclave.so $out/bin/
cp Enclave/Enclave.signed.so $out/bin/
runHook postInstall
'';
postInstall = ''
${sgx.sgx-sdk}/sgxsdk/bin/x64/sgx_sign dump -cssfile enclave_sigstruct_raw -dumpfile /dev/null -enclave $out/bin/Enclave.signed.so
cp enclave_sigstruct_raw $out/bin/
'';
dontFixup = true;
}