X-Git-Url: http://git.grml.org/?a=blobdiff_plain;f=templates%2Fgrub-pxelinux_config;h=1be9b1807a8b0ca8d0ff27c96f9ec185b227e44d;hb=17edea1f26bf27b35d14ab06f282bdd920e724f7;hp=a538792ba66975ba309c6ce2269974edbf99b58d;hpb=e9048c60067568cd587678243c7ae568c7934d84;p=grml-terminalserver.git diff --git a/templates/grub-pxelinux_config b/templates/grub-pxelinux_config index a538792..1be9b18 100644 --- a/templates/grub-pxelinux_config +++ b/templates/grub-pxelinux_config @@ -18,13 +18,16 @@ # 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)" + live_media_path_="live-media-path=$(awk -F live-media-path= '{print $2}' /proc/cmdline | awk '{print $1}')" +fi +if [ ! -d /live/image/boot ] ; then + live_media_path_="live-media-path=/" 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 \ @@ -32,10 +35,10 @@ apm=power-off nomce" fi # special boot arguments required by grub -grub_def_boot_args_="/linux26 $default_boot_args_" +grub_def_boot_args_="/vmlinuz $default_boot_args_ $live_media_path_" # special boot arguments required by pxelinux -pxe_def_boot_args_="$default_boot_args_ initrd=minirt26.gz" +pxe_def_boot_args_="$default_boot_args_" # default arguments for framebuffer console def_fb_args_="vga=791" @@ -51,7 +54,7 @@ timeout=10 title GRML root (nd) kernel $grub_def_boot_args_ $def_fb_args_ $BOOT_ARGS_ - initrd /minirt26.gz + initrd /initrd.img title GRML no framebuffer root (nd) @@ -60,27 +63,27 @@ title GRML no framebuffer title GRML small root (nd) kernel $grub_def_boot_args_ small $def_fb_args_ $BOOT_ARGS_ - initrd /minirt26.gz + initrd /initrd.img title GRML small nofb root (nd) kernel $grub_def_boot_args_ small $no_fb_args_ $BOOT_ARGS_ - initrd /minirt26.gz + initrd /initrd.img title GRML debuginit root (nd) kernel $grub_def_boot_args_ debuginitrd $def_fb_args_ $BOOT_ARGS_ - initrd /minirt26.gz + initrd /initrd.img title GRML debuginit nofb root (nd) kernel $grub_def_boot_args_ debuginitrd $no_fb_args_ $BOOT_ARGS_ - initrd /minirt26.gz + initrd /initrd.img title GRML rescue root (nd) kernel $grub_def_boot_args_ $no_fb_args_ - initrd /minirt26.gz + initrd /initrd.img title memtest root (nd) @@ -97,23 +100,68 @@ 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" +if [ -d /live/image/boot ] ; then + grml2usb --bootloader-only \ + --bootoptions="$pxe_def_boot_args_ $BOOT_ARGS_" \ + --remove-bootoption=nodhcp \ + /live/image "$DEST_DIR" + + mv "$DEST_DIR"/boot/syslinux/* "$TFTPD_DATA_DIR_/" + rmdir "$DEST_DIR"/boot/syslinux + + mv "$DEST_DIR"/boot/ "$TFTPD_DATA_DIR_" +else # there is no kernel inside /live/image copy it from /boot + if [ ! -d /usr/share/grml-live/templates/boot/isolinux ] ; then + echo "E: Could not find isolinux template directory" >&2 + exit 2 + fi + + array=( $(cat /etc/grml_version) ) + grml_name_=${array[0]} + grml_version_=${array[1]} + + cp /usr/share/grml-live/templates/boot/isolinux/* "$TFTPD_DATA_DIR_/" + + config_files_=$(find "$TFTPD_DATA_DIR_/" -name "*.cfg" -type f) + sed -i "s/%ARCH%/$(uname -m)/" $config_files_ + sed -i "s/%BOOTID%/$RANDOM/" $config_files_ + sed -i "s/%SHORT_NAME%/dummy/" $config_files_ + sed -i "s/%VERSION%/$grml_version_/" $config_files_ + sed -i "s/%GRML_NAME%/$grml_name_/" $config_files_ + sed -i "s/%DISTRI_SPLASH%/grml.png/" $config_files_ + sed -i "s/%DISTRI_INFO%/Grml/" $config_files_ + sed -i "s#\(^.*append.*initrd.*$\)#\1 $pxe_def_boot_args_ $BOOT_ARGS_#" $config_files_ + cat > "$TFTPD_DATA_DIR_/grmlmain.cfg"</dev/null +config_files_=$(find "$TFTPD_DATA_DIR_/" -name "*.cfg" -type f) -# 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 +# cd is multi iso, grml2usb got it right ;0 +if [ -d "$MOUNT_POINT_"/boot/release ] ; then + sed -i -e 's#\(.*\)/boot/\(.*\)#\1\2#' $config_files_ +else + # remove normal kernel path and use our image + sed -i -e 's/.*kernel.*vmlinuz/ kernel vmlinuz/' $config_files_ + sed -i -e 's/\(initrd\)=[[:alnum:]/._-]*/\1=initrd.img/' $config_files_ + # remove live-media-path per default + sed -i -e 's#live-media-path=[[:alnum:]/._-]*##' $config_files_ + + # append live-media-path if needed + if [ ! -z "$live_media_path_" ] ; then + sed -i -e "s#\(^.*append.*initrd.*$\)#\1 $live_media_path_#" $config_files_ + fi +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