]> git.ipfire.org Git - thirdparty/grub.git/commitdiff
2007-05-04 Robert Millan <rmh@aybabtu.com>
authorrobertmh <robertmh@localhost>
Fri, 4 May 2007 07:11:44 +0000 (07:11 +0000)
committerrobertmh <robertmh@localhost>
Fri, 4 May 2007 07:11:44 +0000 (07:11 +0000)
* DISTLIST: Add util/update-grub.in, util/grub.d/00_header.in,
util/grub.d/10_hurd.in, util/grub.d/10_linux.in and util/grub.d/README.
* Makefile.in: Build update-grub_SCRIPTS.  Install update-grub_SCRIPTS
and update-grub_DATA.
* conf/common.rmk: Build and install update-grub components.
* conf/common.mk: Regenerate.
* util/update-grub.in: New.  Core of update-grub.
* util/grub.d/00_header.in: New.  Generates grub.cfg header.
* util/grub.d/10_hurd.in: New.  Generates boot entries for the Hurd.
* util/grub.d/10_linux.in: New.  Generates boot entries for Linux.
* util/grub.d/README: New.  Document grub.d directory layout.

ChangeLog
DISTLIST
Makefile.in
conf/common.mk
conf/common.rmk
util/grub.d/00_header.in [new file with mode: 0644]
util/grub.d/10_hurd.in [new file with mode: 0644]
util/grub.d/10_linux.in [new file with mode: 0644]
util/grub.d/README [new file with mode: 0644]
util/update-grub.in [new file with mode: 0644]

index 53e0f8cf1b78ca9ce2fd766798787507bc8f2374..ebe0c47f3ab16101b97256d7d6659750704cf619 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,17 @@
+2007-05-04  Robert Millan  <rmh@aybabtu.com>
+
+       * DISTLIST: Add util/update-grub.in, util/grub.d/00_header.in,
+       util/grub.d/10_hurd.in, util/grub.d/10_linux.in and util/grub.d/README.
+       * Makefile.in: Build update-grub_SCRIPTS.  Install update-grub_SCRIPTS
+       and update-grub_DATA.
+       * conf/common.rmk: Build and install update-grub components.
+       * conf/common.mk: Regenerate.
+       * util/update-grub.in: New.  Core of update-grub.
+       * util/grub.d/00_header.in: New.  Generates grub.cfg header.
+       * util/grub.d/10_hurd.in: New.  Generates boot entries for the Hurd.
+       * util/grub.d/10_linux.in: New.  Generates boot entries for Linux.
+       * util/grub.d/README: New.  Document grub.d directory layout.
+
 2007-05-01  Robert Millan  <rmh@aybabtu.com>
 
        * util/grub-emu.c: Move initialization functions
index 190d4feeaeacf2e062a24a92e2d20bf354e41214..eb287143fcc9e70ae25d5a7ee2e3d62d7c5a98df 100644 (file)
--- a/DISTLIST
+++ b/DISTLIST
@@ -258,6 +258,11 @@ util/misc.c
 util/raid.c
 util/resolve.c
 util/unifont2pff.rb
+util/update-grub.in
+util/grub.d/00_header.in
+util/grub.d/10_hurd.in
+util/grub.d/10_linux.in
+util/grub.d/README
 util/i386/efi/grub-mkimage.c
 util/i386/pc/biosdisk.c
 util/i386/pc/getroot.c
index b6979f1b9048892745d361c46b1ad19ada96c705..642b6cd130d189135c0d04f442bcaf4712dd5c96 100644 (file)
@@ -87,7 +87,7 @@ MKFILES = $(patsubst %.rmk,%.mk,$(RMKFILES))
 DATA = $(pkgdata_IMAGES) $(pkgdata_MODULES) $(pkgdata_PROGRAMS) \
        $(pkgdata_DATA)
 PROGRAMS = $(bin_UTILITIES) $(sbin_UTILITIES)
-SCRIPTS = $(sbin_SCRIPTS)
+SCRIPTS = $(sbin_SCRIPTS) $(update-grub_SCRIPTS)
 
 CLEANFILES =
 MOSTLYCLEANFILES = 
@@ -153,6 +153,17 @@ install-local: all
          dest="`echo $$file | sed 's,.*/,,' | sed '$(transform)'`"; \
          $(INSTALL_SCRIPT) $$dir$$file $(DESTDIR)$(sbindir)/$$dest; \
        done
+       $(mkinstalldirs) $(DESTDIR)$(sysconfdir)/grub.d
+       @list='$(update-grub_SCRIPTS)'; for file in $$list; do \
+         if test -f "$$file"; then dir=; else dir="$(srcdir)"; fi; \
+         dest="`echo $$file | sed 's,.*/,,' | sed '$(transform)'`"; \
+         $(INSTALL_SCRIPT) $$dir$$file $(DESTDIR)$(sysconfdir)/grub.d/$$dest; \
+       done
+       @list='$(update-grub_DATA)'; for file in $$list; do \
+         if test -f "$$file"; then dir=; else dir="$(srcdir)"; fi; \
+         dest="`echo $$file | sed 's,.*/,,' | sed '$(transform)'`"; \
+         $(INSTALL_DATA) $$dir$$file $(DESTDIR)$(sysconfdir)/grub.d/$$dest; \
+       done
 
 install-strip:
        $(MAKE) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" install
index e0e13d6a3256d79e0a637ae9041acf3e70f469a1..64334964021e78766da740163704a22e709f29a4 100644 (file)
@@ -18,6 +18,33 @@ grub_emu_init.c: $(filter-out grub_emu_init.c,$(grub_emu_SOURCES)) geninit.sh gr
        rm -f $@; sh $(srcdir)/geninit.sh $(filter %.c,$^) > $@
 DISTCLEANFILES += grub_emu_init.c
 
+# For update-grub
+update-grub: util/update-grub.in config.status
+       ./config.status --file=$@:$<
+       chmod +x $@
+sbin_SCRIPTS += update-grub
+CLEANFILES += update-grub
+
+00_header: util/grub.d/00_header.in config.status
+       ./config.status --file=$@:$<
+       chmod +x $@
+update-grub_SCRIPTS += 00_header
+CLEANFILES += 00_header
+
+10_linux: util/grub.d/10_linux.in config.status
+       ./config.status --file=$@:$<
+       chmod +x $@
+update-grub_SCRIPTS += 10_linux
+CLEANFILES += 10_linux
+
+10_hurd: util/grub.d/10_hurd.in config.status
+       ./config.status --file=$@:$<
+       chmod +x $@
+update-grub_SCRIPTS += 10_hurd
+CLEANFILES += 10_hurd
+
+update-grub_DATA += util/grub.d/README
+
 
 # Filing systems.
 pkgdata_MODULES += fshelp.mod fat.mod ufs.mod ext2.mod         \
index 816246948be5892492b868c1fe3679a9d84bd604..2a7d64018b0daefa22d2df72592b11b52e58a898 100644 (file)
@@ -18,6 +18,33 @@ grub_emu_init.c: $(filter-out grub_emu_init.c,$(grub_emu_SOURCES)) geninit.sh gr
        rm -f $@; sh $(srcdir)/geninit.sh $(filter %.c,$^) > $@
 DISTCLEANFILES += grub_emu_init.c
 
+# For update-grub
+update-grub: util/update-grub.in config.status
+       ./config.status --file=$@:$<
+       chmod +x $@
+sbin_SCRIPTS += update-grub
+CLEANFILES += update-grub
+
+00_header: util/grub.d/00_header.in config.status
+       ./config.status --file=$@:$<
+       chmod +x $@
+update-grub_SCRIPTS += 00_header
+CLEANFILES += 00_header
+
+10_linux: util/grub.d/10_linux.in config.status
+       ./config.status --file=$@:$<
+       chmod +x $@
+update-grub_SCRIPTS += 10_linux
+CLEANFILES += 10_linux
+
+10_hurd: util/grub.d/10_hurd.in config.status
+       ./config.status --file=$@:$<
+       chmod +x $@
+update-grub_SCRIPTS += 10_hurd
+CLEANFILES += 10_hurd
+
+update-grub_DATA += util/grub.d/README
+
 
 # Filing systems.
 pkgdata_MODULES += fshelp.mod fat.mod ufs.mod ext2.mod         \
diff --git a/util/grub.d/00_header.in b/util/grub.d/00_header.in
new file mode 100644 (file)
index 0000000..2d1cc8b
--- /dev/null
@@ -0,0 +1,38 @@
+#! /bin/sh -e
+
+# update-grub helper script.
+# Copyright (C) 2006, 2007 Free Software Foundation, Inc.
+#
+# This file is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St - Suite 330, Boston, MA 02110, USA.
+
+
+if [ "x${GRUB_DEFAULT}" = "x" ] ; then GRUB_DEFAULT=0 ; fi
+if [ "x${GRUB_TIMEOUT}" = "x" ] ; then GRUB_TIMEOUT=5 ; fi
+
+cat << EOF
+set default=${GRUB_DEFAULT}
+set timeout=${GRUB_TIMEOUT}
+set root=${GRUB_DRIVE}
+EOF
+
+if test -e /boot/grub/unifont.pff ; then
+  cat << EOF
+font /boot/grub/unifont.pff
+set gfxmode=640x480x32
+insmod gfxterm
+insmod vbe
+terminal gfxterm
+EOF
+fi
diff --git a/util/grub.d/10_hurd.in b/util/grub.d/10_hurd.in
new file mode 100644 (file)
index 0000000..08aadf3
--- /dev/null
@@ -0,0 +1,72 @@
+#! /bin/sh -e
+
+# update-grub helper script.
+# Copyright (C) 2006, 2007 Free Software Foundation, Inc.
+#
+# This file is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St - Suite 330, Boston, MA 02110, USA.
+
+if [ "x${GRUB_DISTRIBUTOR}" = "" ] ; then
+  OS=GNU
+else
+  OS="${GRUB_DISTRIBUTOR} GNU/Hurd"
+fi
+
+# FIXME: add l4 here?
+kernel=
+for i in /boot/gnumach.gz /boot/gnumach ; do
+  if test -e $i ; then
+    kernel=$i
+  fi
+done
+
+# FIXME: This works for ext2.  For other filesystems we might need special-casing
+case "${GRUB_FS}" in
+  *fs) hurd_fs="${GRUB_FS}" ;;
+  *)   hurd_fs="${GRUB_FS}fs" ;;
+esac
+
+at_least_one=false
+all_of_them=true
+for i in "${kernel}" /hurd/${hurd_fs}.static /hurd/exec ; do
+  if test -e "$i" ; then
+    echo "Found Hurd module: $i" >&2
+    at_least_one=true
+  else
+    all_of_them=false
+  fi
+done
+
+if ${at_least_one} ; then : ; else
+  # no hurd here, aborting silently
+  exit 0
+fi
+
+if ${all_of_them} && test -e /lib/ld.so.1 ; then : ; else
+  echo "Some Hurd stuff found, but not enough to boot." >&2
+  exit 1
+fi
+
+cat << EOF
+menuentry "${OS}" {
+       multiboot ${kernel} root=device:${GRUB_DEVICE}
+       module /hurd/${hurd_fs}.static --readonly \\
+                       --multiboot-command-line='\${kernel-command-line}' \\
+                       --host-priv-port='\${host-port}' \\
+                       --device-master-port='\${device-port}' \\
+                       --exec-server-task='\${exec-task}' -T typed '\${root}' \\
+                       '\$(task-create)' '\$(task-resume)'
+       module /lib/ld.so.1 /hurd/exec '\$(exec-task=task-create)'
+}
+EOF
diff --git a/util/grub.d/10_linux.in b/util/grub.d/10_linux.in
new file mode 100644 (file)
index 0000000..97c70d1
--- /dev/null
@@ -0,0 +1,59 @@
+#! /bin/sh -e
+
+# update-grub helper script.
+# Copyright (C) 2006, 2007 Free Software Foundation, Inc.
+#
+# This file is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St - Suite 330, Boston, MA 02110, USA.
+
+if [ "x${GRUB_DISTRIBUTOR}" = "" ] ; then
+  OS=GNU/Linux
+else
+  OS="${GRUB_DISTRIBUTOR} GNU/Linux"
+fi
+
+
+for linux in /boot/vmlinu[xz]-* /vmlinu[xz]-* ; do
+  if test -e ${linux} ; then : ; else
+    continue
+  fi
+  echo "Found linux image:  $linux" >&2
+  version=`echo $linux | sed -e "s,.*/[^0-9]*-,,g"`
+  basedir=`echo $linux | sed -e "s,/[^/]*$,,g"`
+  cat << EOF
+menuentry "${OS}, linux ${version}" {
+       linux   ${linux} root=${GRUB_DEVICE} ro
+EOF
+  if test -e ${basedir}/initrd.img-${version} ; then
+    echo "Found initrd image: ${basedir}/initrd.img-${version}" >&2
+    cat << EOF
+       initrd  ${basedir}/initrd.img-${version}
+EOF
+  fi
+  cat << EOF
+}
+EOF
+  cat << EOF
+menuentry "${OS}, linux ${version} (single-user mode)" {
+       linux   ${linux} root=${GRUB_DEVICE} ro single
+EOF
+  if test -e ${basedir}/initrd.img-${version} ; then
+    cat << EOF
+       initrd  ${basedir}/initrd.img-${version}
+EOF
+  fi
+  cat << EOF
+}
+EOF
+done
diff --git a/util/grub.d/README b/util/grub.d/README
new file mode 100644 (file)
index 0000000..3ea109d
--- /dev/null
@@ -0,0 +1,11 @@
+
+All executable files in this directory are processed in shell expansion order.
+
+  00_*: Reserved for 00_header.
+  10_*: Native boot entries.
+  20_*: Third party apps (e.g. memtest86+).
+
+The number namespace in-between is configurable by system installer and/or
+administrator.  For example, you can add an entry to boot another OS as
+01_otheros, 11_otheros, etc, depending on the position you want it to occupy in
+the menu; and then adjust the default setting via /etc/default/grub.
diff --git a/util/update-grub.in b/util/update-grub.in
new file mode 100644 (file)
index 0000000..a4d1af7
--- /dev/null
@@ -0,0 +1,106 @@
+#! /bin/sh -e
+
+# Generate grub.cfg by inspecting /boot contents.
+# Copyright (C) 2006, 2007 Free Software Foundation, Inc.
+#
+# This file is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin St - Suite 330, Boston, MA 02110, USA.
+
+transform="@program_transform_name@"
+
+sysconfdir=@sysconfdir@
+grub_prefix=`echo /boot/grub | sed ${transform}`
+grub_cfg=${grub_prefix}/grub.cfg
+update_grub_dir=${sysconfdir}/grub.d
+test_mode=false
+
+if [ "x$UID" = "x" ] ; then
+  UID=`id -u`
+fi
+
+if [ "$UID" != 0 ] ; then
+  echo "$0: You must run this as root" >&2
+  exit 1
+fi
+
+if [ "$1" = "-y" ] ; then
+  echo "$0: warning: Ignoring -y option (no longer needed)." >&2
+fi
+
+if test -d ${update_grub_dir} ; then : ; else
+  if test -d ./grub.d ; then
+    update_grub_dir=./grub.d
+    test_mode=true
+  fi
+fi
+
+found=false
+old_IFS="$IFS"
+IFS=:
+for i in $PATH ; do
+  if test -x "$i/grub-probe" ; then
+    found=true
+    break
+  fi
+done
+IFS="$old_IFS"
+if ${found} ; then : ; else
+  echo "$0: grub-probe not found in PATH." >&2
+  exit 1
+fi
+
+if ${test_mode} ; then : ; else
+  exec > ${grub_cfg}.new
+  chmod 444 ${grub_cfg}.new
+fi
+
+if test -f ${sysconfdir}/default/grub ; then
+  . ${sysconfdir}/default/grub
+fi
+
+echo "Updating ${grub_cfg} ..." >&2
+
+cat << EOF
+#
+# DO NOT EDIT THIS FILE
+#
+# It is automaticaly generated by $0 using templates from ${update_grub_dir}
+#
+EOF
+
+export GRUB_DEVICE="`grub-probe --target=device ${grub_prefix}`"
+export GRUB_DRIVE="`grub-probe --target=drive ${grub_prefix}`"
+export GRUB_FS="`grub-probe --target=fs ${grub_prefix}`"
+
+for i in ${update_grub_dir}/* ; do
+  case $i in
+    # emacsen backup files. FIXME: support other editors
+    *~) ;;
+    *)
+      if test -x $i ; then
+        echo
+        echo "### BEGIN $i ###"
+        $i
+        echo "### END $i ###"
+      fi
+    ;;
+  esac
+done
+
+# none of the children aborted with error, install the new grub.cfg
+if ${test_mode} ; then : ; else
+  mv ${grub_cfg}.new ${grub_cfg}
+fi
+
+echo "done" >&2