diff --git a/ChangeLog b/ChangeLog index 75a7f21..6ab9d74 100644 --- a/ChangeLog +++ b/ChangeLog @@ -2,6 +2,10 @@ # Copyright 1999-2008 Gentoo Foundation; 2008 Chris Gianelloni # Distributed under the GPL v2 + 21 Aug 2008; Andrew Gaffney -gen_bootloader.sh, + -gen_bootloader_grub.awk: + Remove unneeded files for broken grub code + 21 Aug 2008; Andrew Gaffney gen_cmdline.sh, gen_determineargs.sh, genkernel, genkernel.conf: Remove broken grub code diff --git a/gen_bootloader.sh b/gen_bootloader.sh deleted file mode 100644 index 5e3291c..0000000 --- a/gen_bootloader.sh +++ /dev/null @@ -1,94 +0,0 @@ -#!/bin/bash - -set_bootloader() { - if [ "x${BOOTLOADER}" == 'xgrub' ] - then - set_grub_bootloader - else - return 0 - fi -} - -set_grub_bootloader() { - local GRUB_CONF="${BOOTDIR}/grub/grub.conf" - - print_info 1 '' - print_info 1 "Adding kernel to ${GRUB_CONF}..." - if [ "${BOOTFS}" != '' ] - then - GRUB_BOOTFS=${BOOTFS} - else - # Extract block device information from /etc/fstab - GRUB_ROOTFS=$(awk 'BEGIN{RS="((#[^\n]*)?\n)"}( $2 == "/" ) { print $1; exit }' /etc/fstab) - GRUB_BOOTFS=$(awk 'BEGIN{RS="((#[^\n]*)?\n)"}( $2 == "'${BOOTDIR}'") { print $1; exit }' /etc/fstab) - - # If ${BOOTDIR} is not defined in /etc/fstab, it must be the same as / - [ "x${GRUB_BOOTFS}" == 'x' ] && GRUB_BOOTFS=${GRUB_ROOTFS} - fi - - # Read GRUB device map - [ ! -d ${TEMP} ] && mkdir ${TEMP} - grub --batch --device-map=${TEMP}/grub.map </dev/null 2>&1 -quit -EOF - # Get the GRUB mapping for our device - local GRUB_BOOT_DISK1=$(echo ${GRUB_BOOTFS} | sed -e 's#\(/dev/.\+\)[[:digit:]]\+#\1#') - local GRUB_BOOT_DISK=$(awk '{if ($2 == "'${GRUB_BOOT_DISK1}'") {gsub(/(\(|\))/, "", $1); print $1;}}' ${TEMP}/grub.map) - - local GRUB_BOOT_PARTITION=$(echo ${GRUB_BOOTFS} | sed -e 's#/dev/.\+\([[:digit:]]?*\)#\1#') - [ ! -d ${TEMP} ] && rm -r ${TEMP} - - # Create grub configuration directory and file if it doesn't exist. - [ ! -e `dirname ${GRUB_CONF}` ] && mkdir -p `dirname ${GRUB_CONF}` - - if [ ! -e ${GRUB_CONF} ] - then - if [ "${GRUB_BOOT_DISK}" != '' -a "${GRUB_BOOT_PARTITION}" != '' ] - then - GRUB_BOOT_PARTITION=`expr ${GRUB_BOOT_PARTITION} - 1` - # grub.conf doesn't exist - create it with standard defaults - touch ${GRUB_CONF} - echo 'default 0' >> ${GRUB_CONF} - echo 'timeout 5' >> ${GRUB_CONF} - echo >> ${GRUB_CONF} - - # Add grub configuration to grub.conf - echo "# Genkernel generated entry, see GRUB documentation for details" >> ${GRUB_CONF} - echo "title=Gentoo Linux ($KV)" >> ${GRUB_CONF} - echo -e "\troot (${GRUB_BOOT_DISK},${GRUB_BOOT_PARTITION})" >> ${GRUB_CONF} - if [ "${BUILD_RAMDISK}" -eq '0' ] - then - echo -e "\tkernel /kernel-${KNAME}-${ARCH}-${KV} root=${GRUB_ROOTFS}" >> ${GRUB_CONF} - else - echo -e "\tkernel /kernel-${KNAME}-${ARCH}-${KV} root=/dev/ram0 init=/linuxrc real_root=${GRUB_ROOTFS}" >> ${GRUB_CONF} - echo -e "\tinitrd /initramfs-${KNAME}-${ARCH}-${KV}" >> ${GRUB_CONF} - fi - echo >> ${GRUB_CONF} - else - print_error 1 "Error! ${BOOTDIR}/grub/grub.conf does not exist and the correct settings can not be automatically detected." - print_error 1 "Please manually create your ${BOOTDIR}/grub/grub.conf file." - fi - else - # grub.conf already exists; so... - # ... Clone the first boot definition and change the version. - local TYPE='ramfs' - - cp -f ${GRUB_CONF} ${GRUB_CONF}.bak - awk 'BEGIN { RS="\n"; } - { - if(match($0, "kernel-" KNAME "-" ARCH "-" KV)) - { have_k="1" } - if(match($0, "init" TYPE "-" KNAME "-" ARCH "-" KV)) - { have_i="1" } - if(have_k == "1" && have_i == "1") - { exit 1; } - }' KNAME=${KNAME} ARCH=${ARCH} KV=${KV} TYPE=${TYPE} ${GRUB_CONF}.bak - if [ "$?" -eq '0' ] - then - local LIMIT=$(wc -l ${GRUB_CONF}.bak) - awk -f ${GK_SHARE}/gen_bootloader_grub.awk LIMIT=${LIMIT/ */} KNAME=${KNAME} ARCH=${ARCH} KV=${KV} TYPE=${TYPE} ${GRUB_CONF}.bak > ${GRUB_CONF} - else - print_info 1 "GRUB: Definition found, not duplicating." - fi - fi -} diff --git a/gen_bootloader_grub.awk b/gen_bootloader_grub.awk deleted file mode 100644 index 435e936..0000000 --- a/gen_bootloader_grub.awk +++ /dev/null @@ -1,84 +0,0 @@ -BEGIN { RS="\n"; FS=""; OFS=""; ORS=""; state="0"; } -{ -if(state == "0") -{ - if (match($0, /^title=/) || match($0, /^title */)) - { - state = "1"; - ORIG = ORIG $0 "\n"; - next; - } else { - if(match($0, /^[[:space:]]*#/)) - ORIG = ORIG $0 "\n"; - extraA = extraA $0 "\n"; - } -} - -if(state == "1") -{ - if(match($0, /^[[:space:]]*kernel /)) - { - ORIG = ORIG $0 "\n"; - i = 0; - have_k = "1"; - my_kernel = $0; - sub(/kernel-[[:alnum:][:punct:]]+/, "kernel-" KNAME "-" ARCH "-" KV, my_kernel); - } else { - if(match($0, /^[[:space:]]*initrd /)) - { - ORIG = ORIG $0 "\n"; - i = 0; - extraC = extraC commentLookahead; - - have_i = "1"; - my_initrd = "\n" $0; - sub(/initr(d|amfs)-[[:alnum:][:punct:]]+/, "init" TYPE "-" KNAME "-" ARCH "-" KV, my_initrd); - } else { - if($0 == "\n") - next; - ORIG = ORIG $0 "\n"; - if(match($0, /^[[:space:]]*#/)) - { - i = 1; - if(commentLookahead) - commentLookahead = commentLookahead "\n" $0; - else - commentLookahead = $0; - next; - } - - if(!(match($0, /^title=/) || match($0, /^title */) )) - { - i = 0; - commentLookahead = ""; - - if(have_k != "1") - extraB = extraB commentLookahead $0 "\n"; - else - { - if(have_i != "1") - extraC = extraC commentLookahead $0 "\n"; - else - extraD = extraD commentLookahead $0 "\n"; - } - } - } - } - if(have_k == "1" && ((match($0, /^title=/) || match($0, /^title */)) || NR == LIMIT)) - { - state = "2"; - print extraA "title=Gentoo Linux (" KV ")\n"; - print extraB my_kernel; - if(extraC) - print "\n" extraC; - print my_initrd extraD "\n"; - if(i == 0) - print commentLookahead; - print ORIG; - next; - } -} - -if(state == "2") - print $0 "\n"; -}