rewrite based on reference project from github

This commit is contained in:
2026-01-30 22:58:37 +01:00
parent 1e884eec99
commit 4790e69113
4 changed files with 74 additions and 18 deletions

View File

@@ -199,26 +199,21 @@ umount -l $BUILD_DIR/rootfs/proc
rm $BUILD_DIR/rootfs/setup.sh
# Build initramfs with dracut using the rootfs modules
echo "Building initramfs with dracut using rootfs kernel and modules..."
# Build initramfs with custom netboot hooks/scripts
echo "Building custom netboot initramfs..."
KERNEL_VERSION=$(ls -1 $BUILD_DIR/rootfs/boot/vmlinuz-* | sed 's|.*/vmlinuz-||' | head -1)
# Mount proc/sys temporarily for dracut if needed
mount -t proc proc $BUILD_DIR/rootfs/proc 2>/dev/null || true
dracut -f \
--add "network" \
--hostonly \
--hostonly-cmdline \
--include "/usr/share/initramfs-tools/hooks/rooturl" "/usr/share/initramfs-tools/hooks/" \
--include "/usr/share/initramfs-tools/scripts/local-top/rooturl" "/usr/share/initramfs-tools/scripts/local-top/" \
-k $KERNEL_VERSION \
-r $BUILD_DIR/rootfs \
$BUILD_DIR/rootfs/boot/initrd-netboot.img
umount -l $BUILD_DIR/rootfs/proc 2>/dev/null || true
echo "Initramfs build complete. Size: $(du -h $BUILD_DIR/rootfs/boot/initrd-netboot.img | cut -f1)"
# Use mkinitramfs with custom initramfs directory
INITRAMFS_CONFIG="/srv/netboot/initramfs"
if [ -d "$INITRAMFS_CONFIG" ]; then
mkinitramfs -d "$INITRAMFS_CONFIG" \
-k "$KERNEL_VERSION" \
-o $BUILD_DIR/rootfs/boot/initrd-netboot.img
echo "Initramfs build complete. Size: $(du -h $BUILD_DIR/rootfs/boot/initrd-netboot.img | cut -f1)"
else
echo "ERROR: Custom initramfs config not found at $INITRAMFS_CONFIG"
exit 1
fi
# Copy kernel and netboot initramfs
mkdir -p $IMAGE_DIR/$VERSION

View File

@@ -0,0 +1,16 @@
#!/bin/bash
check() {
return 0
}
depends() {
echo network url-lib
return 0
}
install() {
inst_hook cmdline 90 "$moddir/parse-netboot.sh"
inst_hook pre-mount 90 "$moddir/mount-netboot.sh"
inst_multiple wget curl
}

View File

@@ -0,0 +1,32 @@
#!/bin/sh
# Download and mount squashfs root with overlay
. /tmp/netboot.conf
info "Downloading root filesystem from http://${BOOT_SERVER}/${IMAGE_VERSION}/filesystem.squashfs"
mkdir -p /run/netboot
wget -O /run/netboot/root.squashfs \
"http://${BOOT_SERVER}/${IMAGE_VERSION}/filesystem.squashfs" || \
die "Failed to download root filesystem from $BOOT_SERVER"
info "Download complete, mounting filesystems..."
# Mount squashfs (read-only base)
mkdir -p /run/rootfs/lower
mount -t squashfs /run/netboot/root.squashfs /run/rootfs/lower || \
die "Failed to mount squashfs"
# Create tmpfs for overlay (writable layer)
mkdir -p /run/rootfs/upper /run/rootfs/work
mount -t tmpfs -o size=4G tmpfs /run/rootfs/upper || \
die "Failed to create tmpfs overlay"
mkdir -p /run/rootfs/upper/upper /run/rootfs/upper/work
# Mount overlay (combines read-only base + writable tmpfs)
mount -t overlay overlay \
-o lowerdir=/run/rootfs/lower,upperdir=/run/rootfs/upper/upper,workdir=/run/rootfs/upper/work \
/sysroot || \
die "Failed to mount overlay"
info "Root filesystem mounted successfully"

View File

@@ -0,0 +1,13 @@
#!/bin/sh
# Parse netboot parameters from kernel command line
BOOT_SERVER=$(getarg boot_server=)
IMAGE_VERSION=$(getarg image_version=)
[ -z "$BOOT_SERVER" ] && BOOT_SERVER="192.168.100.1"
[ -z "$IMAGE_VERSION" ] && IMAGE_VERSION="latest"
echo "BOOT_SERVER=$BOOT_SERVER" > /tmp/netboot.conf
echo "IMAGE_VERSION=$IMAGE_VERSION" >> /tmp/netboot.conf
info "Netboot: server=$BOOT_SERVER version=$IMAGE_VERSION"