pi4 edk2 builds
This commit is contained in:
@@ -1,11 +1,7 @@
|
||||
{ stdenv
|
||||
, fetchFromGitHub
|
||||
, lib
|
||||
, applyPatches
|
||||
, fetchpatch
|
||||
, MODEL ? "5"
|
||||
, RELEASE_TYPE ? "RELEASE"
|
||||
, EDK2_FLAGS ? ""
|
||||
, src
|
||||
, version ? "stable202511"
|
||||
, python3
|
||||
, git
|
||||
, libuuid
|
||||
@@ -15,20 +11,9 @@
|
||||
let
|
||||
pythonEnv = python3.withPackages (ps: [ ps.tkinter ]);
|
||||
pname = "edk2-basetools";
|
||||
version = "stable202511";
|
||||
in
|
||||
stdenv.mkDerivation rec {
|
||||
inherit pname version;
|
||||
|
||||
edk2Src = fetchFromGitHub rec {
|
||||
owner = "mjallen18";
|
||||
repo = "edk2";
|
||||
name = repo;
|
||||
#tag = "edk2-${version}";
|
||||
rev = "9765be56f1f816ef737153f5588b3294fcc69a63";
|
||||
hash = "sha256-oqfJbNeOj2BVJqWE+snD6ri3lUO1aNcmPg+eJpjyr5E=";
|
||||
fetchSubmodules = true;
|
||||
};
|
||||
inherit src pname version;
|
||||
|
||||
env = {
|
||||
NIX_CFLAGS_COMPILE =
|
||||
@@ -54,7 +39,7 @@ stdenv.mkDerivation rec {
|
||||
unpackPhase = ''
|
||||
runHook preUnpack
|
||||
|
||||
unpackFile "$edk2Src"
|
||||
unpackFile "$src"
|
||||
|
||||
chmod -R u+w .
|
||||
|
||||
@@ -69,10 +54,12 @@ stdenv.mkDerivation rec {
|
||||
postPatch = ''
|
||||
# enable compilation using Clang
|
||||
# https://bugzilla.tianocore.org/show_bug.cgi?id=4620
|
||||
ls -alh
|
||||
substituteInPlace edk2/BaseTools/Conf/tools_def.template --replace-fail \
|
||||
'DEFINE CLANGPDB_WARNING_OVERRIDES = ' \
|
||||
'DEFINE CLANGPDB_WARNING_OVERRIDES = -Wno-unneeded-internal-declaration '
|
||||
|
||||
substituteInPlace edk2/BaseTools/Conf/tools_def.template \
|
||||
--replace "-Werror" "-Werror -Wno-error=format-security"
|
||||
'';
|
||||
|
||||
buildPhase = ''
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
{ stdenv
|
||||
, fetchFromGitHub
|
||||
, lib
|
||||
, MODEL ? "4"
|
||||
, MODEL ? "5"
|
||||
, RELEASE_TYPE ? "RELEASE"
|
||||
, EDK2_FLAGS ? ""
|
||||
, nasm
|
||||
@@ -11,6 +11,7 @@
|
||||
, openssl
|
||||
, git
|
||||
, libuuid
|
||||
, acpica-tools
|
||||
, pkgs
|
||||
, namespace
|
||||
}:
|
||||
@@ -18,33 +19,64 @@ let
|
||||
pname = "edk2";
|
||||
version = "stable202511";
|
||||
|
||||
edk2Src = fetchFromGitHub rec {
|
||||
owner = "mjallen18";
|
||||
repo = "edk2";
|
||||
name = repo;
|
||||
#tag = "edk2-${version}";
|
||||
rev = "9765be56f1f816ef737153f5588b3294fcc69a63";
|
||||
hash = "sha256-oqfJbNeOj2BVJqWE+snD6ri3lUO1aNcmPg+eJpjyr5E=";
|
||||
fetchSubmodules = true;
|
||||
};
|
||||
edk2Src = (if MODEL == "5" then
|
||||
fetchFromGitHub rec {
|
||||
owner = "mjallen18";
|
||||
repo = "edk2";
|
||||
name = repo;
|
||||
rev = "9765be56f1f816ef737153f5588b3294fcc69a63";
|
||||
hash = "sha256-oqfJbNeOj2BVJqWE+snD6ri3lUO1aNcmPg+eJpjyr5E=";
|
||||
fetchSubmodules = true;
|
||||
}
|
||||
else
|
||||
fetchFromGitHub rec {
|
||||
owner = "tianocore";
|
||||
repo = "edk2";
|
||||
name = repo;
|
||||
tag = "edk2-${version}";
|
||||
hash = "sha256-R/rgz8dWcDYVoiM67K2UGuq0xXbjjJYBPtJ1FmfGIaU=";
|
||||
fetchSubmodules = true;
|
||||
}
|
||||
);
|
||||
|
||||
edk2NonOsiSrc = fetchFromGitHub rec {
|
||||
owner = "mjallen18";
|
||||
repo = "edk2-non-osi";
|
||||
name = repo;
|
||||
rev = "09ee44f07ded544d976be8a03dec3715719homeassistant-apif638e";
|
||||
hash = "sha256-k7nUb3WaRUIr9IlXdam2WGKPOzKjLNVFLfuD5h4veMc=";
|
||||
};
|
||||
edk2NonOsiSrc = (if MODEL == "5" then
|
||||
fetchFromGitHub rec {
|
||||
owner = "mjallen18";
|
||||
repo = "edk2-non-osi";
|
||||
name = repo;
|
||||
rev = "09ee44f07ded544d976be8a03dec3715719f638e";
|
||||
hash = "sha256-k7nUb3WaRUIr9IlXdam2WGKPOzKjLNVFLfuD5h4veMc=";
|
||||
}
|
||||
else
|
||||
fetchFromGitHub rec {
|
||||
owner = "tianocore";
|
||||
repo = "edk2-non-osi";
|
||||
name = repo;
|
||||
rev = "94d048981116e2e3eda52dad1a89958ee404098d";
|
||||
hash = "sha256-6yuvVvmGn4yaEksbbvGDX1ZcKpdWBKnwaNjLGvgAWyk=";
|
||||
}
|
||||
);
|
||||
|
||||
edk2PlatformsSrc = fetchFromGitHub rec {
|
||||
owner = "mjallen18";
|
||||
repo = "edk2-platforms";
|
||||
name = repo;
|
||||
rev = "933314d94a3d05f2f62b0f2148151d4a0f1e1183";
|
||||
hash = "sha256-Tnvrwk4g191LzfTkdoFw1BBN51EWhEQ7DRe9u5Mzc0w=";
|
||||
};
|
||||
edk2PlatformsSrc = (if MODEL == "5" then
|
||||
fetchFromGitHub rec {
|
||||
owner = "mjallen18";
|
||||
repo = "edk2-platforms";
|
||||
name = repo;
|
||||
rev = "8dfa12ddd9e1d695f13a7e35e3646396a09ccb67";
|
||||
hash = "sha256-8KaXpUWJtAbT35dX/fF94Y9HLzYHLOkX+Xzbn9l7idU=";
|
||||
}
|
||||
else
|
||||
fetchFromGitHub rec {
|
||||
owner = "tianocore";
|
||||
repo = "edk2-platforms";
|
||||
name = repo;
|
||||
rev = "0991a0b643509d900e5d023a0116789827a696e5";
|
||||
hash = "sha256-IdACr0NStqEpC0TFoKKgDwKT2mqyJwVXW/B7hlRXccI=";
|
||||
}
|
||||
);
|
||||
|
||||
baseTools = pkgs.${namespace}.edk2-basetools;
|
||||
baseTools = pkgs.${namespace}.edk2-basetools.override { version = "stable202511"; src = edk2Src; };
|
||||
armTrustedFirmware = pkgs.${namespace}.arm-trusted-firmware.override { inherit MODEL; };
|
||||
|
||||
pythonEnv = python3.withPackages (
|
||||
_ps: with python3Packages; [
|
||||
@@ -70,6 +102,7 @@ stdenv.mkDerivation rec {
|
||||
git
|
||||
libuuid
|
||||
baseTools
|
||||
acpica-tools
|
||||
];
|
||||
|
||||
env = {
|
||||
@@ -105,27 +138,12 @@ stdenv.mkDerivation rec {
|
||||
ln -sv ${baseTools}/BaseTools ./edk2/BaseTools
|
||||
'';
|
||||
|
||||
postPatch = ''
|
||||
f=edk2/CryptoPkg/Library/OpensslLib/OpensslLib.inf
|
||||
if grep -q '^\[BuildOptions\]' "$f"; then
|
||||
# Add flag inside existing BuildOptions
|
||||
sed -i '/^\[BuildOptions\]/a\ GCC:*_*_*_CC_FLAGS = -Wno-error' "$f"
|
||||
else
|
||||
# Append a new BuildOptions block
|
||||
cat >> "$f" <<'EOF'
|
||||
|
||||
[BuildOptions]
|
||||
GCC:*_*_*_CC_FLAGS = -Wno-error
|
||||
EOF
|
||||
fi
|
||||
'';
|
||||
|
||||
configurePhase = ''
|
||||
runHook preConfigure
|
||||
export WORKSPACE=$PWD
|
||||
export PACKAGES_PATH=$WORKSPACE/edk2:$WORKSPACE/edk2-non-osi:$WORKSPACE/edk2-platforms
|
||||
export EDK_TOOLS_PATH=${baseTools}/BaseTools
|
||||
export ATF_BUILD_DIR="${pkgs.${namespace}.arm-trusted-firmware}/rpi${MODEL}/${RELEASE_TYPE}"
|
||||
export ATF_BUILD_DIR="${armTrustedFirmware}/rpi${MODEL}/${lib.toLower RELEASE_TYPE}"
|
||||
|
||||
. ${baseTools}/edksetup.sh BaseTools
|
||||
runHook postConfigure
|
||||
@@ -144,7 +162,7 @@ stdenv.mkDerivation rec {
|
||||
|
||||
installPhase = ''
|
||||
mkdir -p $out
|
||||
cp -r /Build/RPi${MODEL}/${RELEASE_TYPE}_GCC/FV/RPI_EFI.fd $out/RPI_EFI.fd
|
||||
cp -r /build/Build/RPi${MODEL}/${RELEASE_TYPE}_GCC/FV/RPI_EFI.fd $out/RPI_EFI.fd
|
||||
'';
|
||||
|
||||
meta = with lib; {
|
||||
|
||||
Reference in New Issue
Block a user