X-Git-Url: http://git.grml.org/?a=blobdiff_plain;f=templates%2Fgrub-pxelinux_config;h=8360ac33910b16a316f8f9f17d2fcf17e01ef069;hb=d661dac3445254e4367ff7aa7ed87ca58ef74833;hp=20be1b614a381c822a734cf07952226304cafe24;hpb=fdea9e5736375443ad3818136cab0bc41f9d9414;p=grml-terminalserver.git diff --git a/templates/grub-pxelinux_config b/templates/grub-pxelinux_config index 20be1b6..8360ac3 100644 --- a/templates/grub-pxelinux_config +++ b/templates/grub-pxelinux_config @@ -17,97 +17,50 @@ # # 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 -if [ -e '/live/cow' ]; then +if [ -e "$MOUNT_POINT_" ]; then default_boot_args_="root=/dev/nfs rw nfsroot=$IP_:$MOUNT_POINT_ \ -nodhcp noprompt noeject" +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_" - # special boot arguments required by pxelinux pxe_def_boot_args_="$default_boot_args_" -# default arguments for framebuffer console -def_fb_args_="vga=791" -no_fb_args_="vga=normal" - -### -## create grub config -### - -cat >"$TFTPD_DATA_DIR_/menu.lst" <&2 + echo "E: Could not find isolinux directory, can not operate without. + +Did you boot the system with the toram=... boot option? If so please +either do not use the toram boot option at all or use boot option toram +without any arguments (just \"toram\" instead of \"toram=...\")." >&2 exit 2 fi @@ -138,26 +91,25 @@ EOT fi +# Copy initrd.img and vmlinuz from all directories which name begins +# with grml, e.g. grml32full and grml64full +# This way we can boot multiple ISOs +for filename in "${MULTIBOOT_PATH_}"/grml* ; do + [ -d "$filename" ] || continue + cp -r "${filename}" "${TFTPD_DATA_DIR_}/boot/" +done +config_files_=$(find "$TFTPD_DATA_DIR_/" -name "*.cfg" -type f) # cd is multi iso, grml2usb got it right ;0 if [ -d "$MOUNT_POINT_"/boot/release ] ; then - sed -i -e 's#\(.*\)/boot/\(.*\)#\1\2#' "$TFTPD_DATA_DIR_/"*.cfg 2>/dev/null -else - # remove normal kernel path and use our image - sed -i -e 's/.*kernel.*linux26/kernel linux26/' "$TFTPD_DATA_DIR_/"*.cfg 2>/dev/null - sed -i -e 's/\(initrd\)=[[:alnum:]/._-]*/\1=minirt26.gz/' "$TFTPD_DATA_DIR_/"*.cfg 2>/dev/null - - # only append live-media-path if needed - if [ ! -z "$live_media_path_" ] ; then - sed -i -e 's/\(live-media-path\)=[[:alnum:]/._-]*/\1='$live_media_path_'/' "$TFTPD_DATA_DIR_/"*.cfg 2>/dev/null - else - sed -i -e 's/live-media-path=[[:alnum:]/._-]*//' "$TFTPD_DATA_DIR_/"*.cfg 2>/dev/nul - fi - + sed -i -e 's#\(.*\)/boot/\(.*\)#\1\2#' $config_files_ 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 +if ls "$TFTPD_DATA_DIR_/"addon_*_bsd.cfg >/dev/null 2>&1; then + 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 +fi # remove grub entries rm -f "$TFTPD_DATA_DIR_/"addon_*grub*.cfg