refactor build script for better board management

This commit is contained in:
Florian Agbuya 2024-02-16 13:13:05 +08:00
parent 073f1c9bbd
commit 25ef8fa486

View File

@ -169,7 +169,17 @@
hardeningDisable = [ "fortify" ]; hardeningDisable = [ "fortify" ];
}; };
fsbl = { board ? "zc706" }: pkgs.stdenv.mkDerivation { # Pinned qemu version due to networking errors in recent version 8.2.0
qemu = pkgs.qemu.overrideAttrs (oldAttrs: rec {
version = "8.1.3";
src = pkgs.fetchurl {
url = "https://download.qemu.org/qemu-${version}.tar.xz";
hash = "sha256-Q8wXaAQQVYb3T5A5jzTp+FeH3/QA07ZA2B93efviZbs=";
};
});
board-package-set = { board }: let
fsbl = pkgs.stdenv.mkDerivation {
name = "${board}-fsbl"; name = "${board}-fsbl";
src = pkgs.fetchFromGitHub { src = pkgs.fetchFromGitHub {
owner = "Xilinx"; owner = "Xilinx";
@ -204,7 +214,7 @@
dontFixup = true; dontFixup = true;
}; };
u-boot = { board ? "zc706" }: (pkgs.pkgsCross.armv7l-hf-multiplatform.buildUBoot { u-boot = (pkgs.pkgsCross.armv7l-hf-multiplatform.buildUBoot {
defconfig = "xilinx_zynq_virt_defconfig"; defconfig = "xilinx_zynq_virt_defconfig";
patches = [] ++ pkgs.lib.optional (board == "fast-servo") ./fast-servo/u-boot.patch; patches = [] ++ pkgs.lib.optional (board == "fast-servo") ./fast-servo/u-boot.patch;
preConfigure = '' preConfigure = ''
@ -237,15 +247,15 @@
''; '';
}); });
bootimage = { board ? "zc706" }: pkgs.runCommand "${board}-bootimage" bootimage = pkgs.runCommand "${board}-bootimage"
{ {
buildInputs = [ mkbootimage ]; buildInputs = [ mkbootimage ];
} }
'' ''
bifdir=`mktemp -d` bifdir=`mktemp -d`
cd $bifdir cd $bifdir
ln -s ${fsbl { inherit board; }}/fsbl.elf fsbl.elf ln -s ${fsbl}/fsbl.elf fsbl.elf
ln -s ${u-boot { inherit board; }}/u-boot.elf u-boot.elf ln -s ${u-boot}/u-boot.elf u-boot.elf
cat > boot.bif << EOF cat > boot.bif << EOF
the_ROM_image: the_ROM_image:
{ {
@ -258,7 +268,7 @@
echo file binary-dist $out/boot.bin >> $out/nix-support/hydra-build-products echo file binary-dist $out/boot.bin >> $out/nix-support/hydra-build-products
''; '';
dtb = { board ? "zc706" }: pkgs.runCommand "dtb" dtb = pkgs.runCommand "dtb"
{ {
buildInputs = [ pkgs.gcc pkgs.dtc ]; buildInputs = [ pkgs.gcc pkgs.dtc ];
} }
@ -266,11 +276,11 @@
mkdir -p $out mkdir -p $out
DTSDIR=$(mktemp -d /tmp/dts-XXXXXX) DTSDIR=$(mktemp -d /tmp/dts-XXXXXX)
cd $DTSDIR cd $DTSDIR
cp ${u-boot { inherit board; }}/dts/zynq-${board}.dts . cp ${u-boot}/dts/zynq-${board}.dts .
if [ ${board} == "zc706" ]; then if [ ${board} == "zc706" ]; then
mv zynq-${board}.dts zynq-${board}-top.dts mv zynq-${board}.dts zynq-${board}-top.dts
cp ${u-boot { inherit board; }}/dts/zynq-7000.dtsi . cp ${u-boot}/dts/zynq-7000.dtsi .
gcc -E -nostdinc -undef -D__DTS__ -x assembler-with-cpp -o zynq-${board}.dts zynq-${board}-top.dts gcc -E -nostdinc -undef -D__DTS__ -x assembler-with-cpp -o zynq-${board}.dts zynq-${board}-top.dts
fi fi
@ -279,7 +289,7 @@
rm -rf $DTSDIR rm -rf $DTSDIR
''; '';
sd-image = { board ? "zc706" }: let sd-image = let
rootfsImage = pkgs.callPackage (pkgs.path + "/nixos/lib/make-ext4-fs.nix") { rootfsImage = pkgs.callPackage (pkgs.path + "/nixos/lib/make-ext4-fs.nix") {
storePaths = [ not-os-cfg.build.toplevel ]; storePaths = [ not-os-cfg.build.toplevel ];
volumeLabel = "ROOT"; volumeLabel = "ROOT";
@ -320,8 +330,8 @@
faketime "1970-01-01 00:00:00" mkfs.vfat -n BOOT firmware_part.img faketime "1970-01-01 00:00:00" mkfs.vfat -n BOOT firmware_part.img
mkdir firmware mkdir firmware
cp ${bootimage { inherit board; }}/boot.bin firmware/ cp ${bootimage}/boot.bin firmware/
cp ${dtb { inherit board; }}/${board}.dtb firmware/ cp ${dtb}/${board}.dtb firmware/
cp ${not-os-cfg.build.kernel}/uImage firmware/ cp ${not-os-cfg.build.kernel}/uImage firmware/
cp ${not-os-cfg.build.uRamdisk}/initrd firmware/uRamdisk.image.gz cp ${not-os-cfg.build.uRamdisk}/initrd firmware/uRamdisk.image.gz
@ -330,16 +340,7 @@
''; '';
}; };
# Pinned qemu version due to networking errors in recent version 8.2.0 not-os-qemu = let
qemu = pkgs.qemu.overrideAttrs (oldAttrs: rec {
version = "8.1.3";
src = pkgs.fetchurl {
url = "https://download.qemu.org/qemu-${version}.tar.xz";
hash = "sha256-Q8wXaAQQVYb3T5A5jzTp+FeH3/QA07ZA2B93efviZbs=";
};
});
not-os-qemu = { board ? "zc706" }: let
qemuScript = '' qemuScript = ''
#!/bin/bash #!/bin/bash
export PATH=${qemu}/bin:$PATH export PATH=${qemu}/bin:$PATH
@ -368,31 +369,28 @@
'' ''
mkdir $out mkdir $out
cd $out cd $out
cp -s ${u-boot { inherit board; }}/u-boot.elf . cp -s ${u-boot}/u-boot.elf .
cp -s ${sd-image { inherit board; }}/sd-image/sd-image.img . cp -s ${sd-image}/sd-image/sd-image.img .
cp $qemuScriptPath qemu-script cp $qemuScriptPath qemu-script
chmod +x qemu-script chmod +x qemu-script
patchShebangs qemu-script patchShebangs qemu-script
''; '';
in {
"${board}-fsbl" = fsbl;
"${board}-u-boot" = u-boot;
"${board}-bootimage" = bootimage;
"${board}-dtb" = dtb;
"${board}-sd-image" = sd-image;
"${board}-qemu" = not-os-qemu;
};
in rec { in rec {
packages.x86_64-linux = { packages.x86_64-linux = {
inherit mkbootimage; inherit mkbootimage;
}; };
packages.armv7l-linux = { packages.armv7l-linux =
not-os = not-os-cfg.build.zynq_image; (board-package-set { board = "zc706"; }) //
zc706-fsbl = fsbl { board = "zc706"; }; (board-package-set { board = "fast-servo"; });
zc706-u-boot = u-boot { board = "zc706"; };
zc706-bootimage = bootimage { board = "zc706"; };
zc706-dtb = dtb { board = "zc706"; };
zc706-sd-image = sd-image { board = "zc706"; };
zc706-qemu = not-os-qemu { board = "zc706"; };
fast-servo-fsbl = fsbl { board = "fast-servo"; };
fast-servo-u-boot = u-boot { board = "fast-servo"; };
fast-servo-bootimage = bootimage { board = "fast-servo"; };
fast-servo-dtb = dtb { board = "fast-servo"; };
fast-servo-sd-image = sd-image { board = "fast-servo"; };
fast-servo-qemu = not-os-qemu { board = "fast-servo"; };
};
hydraJobs = packages.x86_64-linux // packages.armv7l-linux; hydraJobs = packages.x86_64-linux // packages.armv7l-linux;
}; };