summaryrefslogtreecommitdiffstats
path: root/pkgs/development/compilers/edk2
diff options
context:
space:
mode:
authorGuillaume Girol <symphorien+git@xlumurb.eu>2022-05-14 12:00:00 +0000
committerGuillaume Girol <symphorien+git@xlumurb.eu>2022-05-14 12:00:00 +0000
commit9ccccc3e255948be13079138d09b3b21da1a5e23 (patch)
treecbc2967bfa57e8986cdf32d9e82a1f9990429351 /pkgs/development/compilers/edk2
parent6766fb6503ae1ebebc2a9704c162b2aef351f921 (diff)
edk2: fix cross compilation
Diffstat (limited to 'pkgs/development/compilers/edk2')
-rw-r--r--pkgs/development/compilers/edk2/default.nix30
1 files changed, 26 insertions, 4 deletions
diff --git a/pkgs/development/compilers/edk2/default.nix b/pkgs/development/compilers/edk2/default.nix
index 47ea90482b6d..e0bcc4476849 100644
--- a/pkgs/development/compilers/edk2/default.nix
+++ b/pkgs/development/compilers/edk2/default.nix
@@ -7,10 +7,11 @@
, bc
, llvmPackages_9
, lib
+, buildPackages
}:
let
- pythonEnv = python3.withPackages (ps: [ps.tkinter]);
+ pythonEnv = buildPackages.python3.withPackages (ps: [ps.tkinter]);
targetArch = if stdenv.isi686 then
"IA32"
@@ -35,6 +36,14 @@ edk2 = buildStdenv.mkDerivation {
pname = "edk2";
version = "202202";
+ patches = [
+ # pass targetPrefix as an env var
+ (fetchpatch {
+ url = "https://src.fedoraproject.org/rpms/edk2/raw/08f2354cd280b4ce5a7888aa85cf520e042955c3/f/0021-Tweak-the-tools_def-to-support-cross-compiling.patch";
+ sha256 = "sha256-E1/fiFNVx0aB1kOej2DJ2DlBIs9tAAcxoedym2Zhjxw=";
+ })
+ ];
+
# submodules
src = fetchFromGitHub {
owner = "tianocore";
@@ -44,7 +53,12 @@ edk2 = buildStdenv.mkDerivation {
sha256 = "0srmhi6c27n5vyl01nhh0fq8k4vngbwn79siyjvcacjbj2ivhh8d";
};
- buildInputs = [ libuuid pythonEnv ];
+ nativeBuildInputs = [ pythonEnv ];
+ depsBuildBuild = [ buildPackages.stdenv.cc buildPackages.util-linux buildPackages.bash ];
+ strictDeps = true;
+
+ # trick taken from https://src.fedoraproject.org/rpms/edk2/blob/08f2354cd280b4ce5a7888aa85cf520e042955c3/f/edk2.spec#_319
+ ${"GCC5_${targetArch}_PREFIX"}=stdenv.cc.targetPrefix;
makeFlags = [ "-C BaseTools" ]
++ lib.optional (stdenv.cc.isClang) [ "BUILD_CC=clang BUILD_CXX=clang++ BUILD_AS=clang" ];
@@ -57,6 +71,10 @@ edk2 = buildStdenv.mkDerivation {
mkdir -vp $out
mv -v BaseTools $out
mv -v edksetup.sh $out
+ # patchShebangs fails to see these when cross compiling
+ for i in $out/BaseTools/BinWrappers/PosixLike/*; do
+ substituteInPlace $i --replace '/usr/bin/env bash' ${buildPackages.bash}/bin/bash
+ done
'';
enableParallelBuilding = true;
@@ -72,7 +90,11 @@ edk2 = buildStdenv.mkDerivation {
mkDerivation = projectDscPath: attrs: buildStdenv.mkDerivation ({
inherit (edk2) src;
- buildInputs = [ bc pythonEnv ] ++ attrs.buildInputs or [];
+ depsBuildBuild = [ buildPackages.stdenv.cc ] ++ attrs.depsBuildBuild or [];
+ nativeBuildInputs = [ bc pythonEnv ] ++ attrs.nativeBuildInputs or [];
+ strictDeps = true;
+
+ ${"GCC5_${targetArch}_PREFIX"}=stdenv.cc.targetPrefix;
prePatch = ''
rm -rf BaseTools
@@ -97,7 +119,7 @@ edk2 = buildStdenv.mkDerivation {
mv -v Build/*/* $out
runHook postInstall
'';
- } // removeAttrs attrs [ "buildInputs" ]);
+ } // removeAttrs attrs [ "nativeBuildInputs" "depsBuildBuild" ]);
};
};