feat(systemd-repart): build image

This commit is contained in:
Lars Sjöström 2025-02-24 16:13:43 +01:00
parent e7470498e5
commit af78f1c930
No known key found for this signature in database
5 changed files with 82 additions and 18 deletions

2
.gitignore vendored
View file

@ -5,8 +5,6 @@
/result
/target
/out
/initrd*
/patos*
.*.swp
.*.swo
.nixos-test-history

View file

@ -21,18 +21,7 @@
{
packages = {
default = self.packages.${system}.image;
image = pkgs.writeShellScriptBin "image" ''
set -ex
echo "make UKI..."
mkdir -p patos/efi/boot
${patosPkgs.systemd.out}/usr/bin/ukify build \
--linux ${patosPkgs.kernel.kernel}/bzImage \
--initrd ${patosPkgs.initrd.out}/initrd.xz \
--cmdline "console=ttyS0" \
-o patos/efi/boot/bootx64.efi
'';
image = pkgs.callPackage ./image { inherit patosPkgs; };
kernel = pkgs.callPackage ./kernel { };
glibc = pkgs.callPackage ./glibc { };
systemd = pkgs.callPackage ./systemd { };
@ -60,7 +49,6 @@
nixfmt-rfc-style
squashfs-tools-ng
self.packages.${system}.qemu-uefi-tpm
self.packages.${system}.mkinitrd
];
};

27
image/default.nix Normal file
View file

@ -0,0 +1,27 @@
{
pkgs,
stdenvNoCC,
patosPkgs,
...
}:
let
version = "0.0.1";
pname = "patos-image";
in
stdenvNoCC.mkDerivation (finalAttrs: {
inherit version;
inherit pname;
buildInputs = with pkgs; [
erofs-utils
dosfstools
mtools
];
systemd = patosPkgs.systemd.out;
kernel = patosPkgs.kernel.kernel;
initrd = patosPkgs.initrd.out;
rootfs = patosPkgs.rootfs.out;
builder = ./mkimage.sh;
})

52
image/mkimage.sh Normal file
View file

@ -0,0 +1,52 @@
set -ex -o pipefail
mkdir -p $out/repart.d $out/boot
pushd $out
# Don't seem to work just to create a symlink to rootfs derivation?
# ln -sf $rootfs rootfs
mkdir rootfs
cp -prP $rootfs/* rootfs/
find rootfs/ -type d -exec chmod 755 {} \;
$systemd/usr/bin/ukify build \
--os-release rootfs/etc/os-release \
--linux $kernel/bzImage \
--initrd $initrd/initrd.xz \
--cmdline "console=ttyS0" \
-o boot/patos-x64.efi
cp ${systemd}/usr/lib/systemd/boot/efi/systemd-bootx64.efi boot/
cat <<EOF > repart.d/10-esp.conf
[Partition]
Type=esp
Format=vfat
SizeMinBytes=96M
SizeMaxBytes=96M
SplitName=-
CopyFiles=/boot/patos-x64.efi:/EFI/Linux/patos-x64.efi
CopyFiles=/boot/systemd-bootx64.efi:/EFI/BOOT/BOOTX64.EFI
EOF
cat <<EOF > repart.d/10-root.conf
[Partition]
Type=root
Format=erofs
CopyFiles=/rootfs:/
Minimize=best
SplitName=root
EOF
$systemd/usr/bin/systemd-repart \
--no-pager \
--empty=create \
--size=1G \
--definitions=./repart.d \
--root=$out \
patos-$version.raw
rm -rf rootfs
rm -rf boot
popd

View file

@ -19,7 +19,7 @@ pkgs.writeShellApplication {
state="/tmp/patos-qemu-$USER"
rm -rf "$state"
mkdir -m 700 "$state"
truncate -s 1G "$state/disk.raw"
qemu-img create -f qcow2 -F raw -b "$(readlink -e "$1")" "$state/disk.qcow2" 2G
swtpm socket -d --tpmstate dir="$state" \
--ctrl type=unixio,path="$state/swtpm-sock" \
@ -44,7 +44,6 @@ pkgs.writeShellApplication {
-device tpm-tis,tpmdev=tpm0 \
-netdev id=net00,type=user,hostfwd=tcp::2222-:22 \
-device virtio-net-pci,netdev=net00 \
-drive "file=fat:rw:patos/,format=raw" \
-drive "format=raw,file=$state/disk.raw"
-drive "format=qcow2,file=$state/disk.qcow2"
'';
}