feat(systemd-repart): build image
This commit is contained in:
parent
e7470498e5
commit
af78f1c930
5 changed files with 82 additions and 18 deletions
2
.gitignore
vendored
2
.gitignore
vendored
|
@ -5,8 +5,6 @@
|
|||
/result
|
||||
/target
|
||||
/out
|
||||
/initrd*
|
||||
/patos*
|
||||
.*.swp
|
||||
.*.swo
|
||||
.nixos-test-history
|
||||
|
|
14
flake.nix
14
flake.nix
|
@ -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
27
image/default.nix
Normal 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
52
image/mkimage.sh
Normal 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
|
|
@ -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"
|
||||
'';
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue