X-Git-Url: https://git.grml.org/?a=blobdiff_plain;f=templates%2Fgrub-pxelinux_config;h=8870d459945fe6bb8d1a96f9095ebca3df3f22cb;hb=8227176e4d324873b6bd892d9771441d2d61ef25;hp=aa6d5ca5138c67eef95a88be5d0150cda7c31aa9;hpb=0696e9c985b9324d559845aa67642c7dcb020d54;p=grml-terminalserver.git diff --git a/templates/grub-pxelinux_config b/templates/grub-pxelinux_config index aa6d5ca..8870d45 100644 --- a/templates/grub-pxelinux_config +++ b/templates/grub-pxelinux_config @@ -1,5 +1,3 @@ -#!/bin/sh i like colors :) -# # the following variables are available in the template: # # $INTERFACE_ (interface for the terminalserver) @@ -19,11 +17,19 @@ # # GLOBAL_README_END +if grep -q live-media-path= /proc/cmdline 2>/dev/null ; then + live_media_path_="live-media-path=$(awk -F live-media-path= '{print $2}' /proc/cmdline)" +fi # default boot arguments used for both grub and pxelinux -default_boot_args_="ramdisk_size=16384 root=/dev/ram0 rw \ +if [ -e '/live/cow' ]; then + default_boot_args_="root=/dev/nfs rw nfsroot=$IP_:$MOUNT_POINT_ \ +nodhcp noprompt noeject" +else + default_boot_args_="ramdisk_size=24000 root=/dev/ram0 rw \ init=/etc/init nfsdir=$IP_:$MOUNT_POINT_ nodhcp noprompt noeject \ apm=power-off nomce" +fi # special boot arguments required by grub grub_def_boot_args_="/linux26 $default_boot_args_" @@ -32,8 +38,8 @@ grub_def_boot_args_="/linux26 $default_boot_args_" pxe_def_boot_args_="$default_boot_args_ initrd=minirt26.gz" # default arguments for framebuffer console -def_fb_args_="video=vesafb:ypan,1024x768-16@60" -no_fb_args_="video=ofonly" +def_fb_args_="vga=791" +no_fb_args_="vga=normal" ### ## create grub config @@ -90,40 +96,32 @@ ret_=$? ### ## create pxelinux config ### +DEST_DIR=$(mktemp -d) +grml2usb --bootloader-only --remove-bootoption='initrd=/boot/[a-z0-9/.]*/initrd.gz' \ + --remove-bootoption='live-media-path=[a-z0-9/.-]+/' \ + --bootoptions="$pxe_def_boot_args_ $BOOT_ARGS_" /live/image "$DEST_DIR" -cat >"$TFTPD_DATA_DIR_/pxelinux.cfg/default" </dev/null + +# only append live-media-path if needed +if [ ! -z "$live_media_path_" ] ; then + sed -i -e 's/\(.*append.*\)/\1 live-media-path='$live_media_path_'/' "$TFTPD_DATA_DIR_/"*.cfg 2>/dev/null +fi + +# adjust ldbsd.com bootline +sed -i -e 's#\(.*kernel .*/ldbsd.com\)#\1 set image /boot/addons/bsd4grml/bsd.rd`echo Type "boot" to load MirOS bsd4grml via keeppxe#' "$TFTPD_DATA_DIR_/"addon_*_bsd.cfg + +# remove grub entries +rm "$TFTPD_DATA_DIR_/"addon_*grub*.cfg + +mv "$TFTPD_DATA_DIR_/syslinux.cfg" "$TFTPD_DATA_DIR_/pxelinux.cfg/default" +rm -rf "$DEST_DIR" let ret_=$ret_+$? return $ret_