Files
nix-config/packages/arm-trusted-firmware/default.nix
mjallen18 94c3d6d6ff packages
2026-01-21 21:41:01 -06:00

57 lines
1.2 KiB
Nix

{
stdenv,
lib,
namespace,
MODEL ? "5",
DEBUG ? "0",
TFA_FLAGS ? "",
}:
let
inherit (lib.trivial) importJSON;
inherit (lib.${namespace}) versioning;
versionSpec = importJSON ./version.json;
selected = versioning.selectVariant versionSpec null null;
sources = versioning.mkAllSources selected;
fw = selected.sources.fw;
in
stdenv.mkDerivation {
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 ];
};
}