pi4 edk2 builds

This commit is contained in:
mjallen18
2026-01-13 14:54:55 -06:00
parent 1dc075f405
commit a7c25fe70d
4 changed files with 70 additions and 63 deletions

View File

@@ -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; {