Files
nix-config/packages/arm-trusted-firmware/default.nix
2026-01-21 12:53:13 -06:00

57 lines
1.3 KiB
Nix

{
stdenv,
fetchFromGitHub,
lib,
pkgs,
MODEL ? "5",
DEBUG ? "0",
TFA_FLAGS ? "",
}:
let
inherit (lib.trivial) importJSON;
versionSpec = importJSON ./version.json;
versioning = import ../../lib/versioning.nix { inherit lib pkgs; };
selected = versioning.selectVariant versionSpec null null;
sources = versioning.mkAllSources selected;
fw = selected.sources.fw;
in
stdenv.mkDerivation rec {
pname = "arm-trusted-firmware";
version = if fw ? tag then fw.tag else fw.rev;
src = sources.fw;
# Add required host tools if needed:
nativeBuildInputs = [
# dtc python3 openssl etc.
];
buildPhase = ''
make \
CROSS_COMPILE=${stdenv.cc.targetPrefix} \
CC=${stdenv.cc.targetPrefix}cc \
AS=${stdenv.cc.targetPrefix}cc \
PLAT=rpi${MODEL} \
PRELOADED_BL33_BASE=0x20000 \
RPI3_PRELOADED_DTB_BASE=0x3E0000 \
SUPPORT_VFP=1 \
SMC_PCI_SUPPORT=1 \
ENABLE_FEAT_VHE=1 \
DEBUG=${DEBUG} \
all \
${TFA_FLAGS}
'';
installPhase = ''
mkdir -p $out
cp -r build/* $out/
'';
meta = with lib; {
description = "ARM Trusted Firmware-A for Raspberry Pi";
license = licenses.bsd3;
platforms = [ "aarch64-linux" ];
maintainers = with maintainers; [ kazenyuk ];
};
}