summaryrefslogtreecommitdiff
path: root/config
diff options
context:
space:
mode:
Diffstat (limited to 'config')
-rw-r--r--config/binary_grub/grub-efi.cfg (renamed from config/binary_local-includes/boot/grub/x86_64-efi/grub.cfg)0
-rw-r--r--config/binary_grub/grub.cfg2
-rwxr-xr-xconfig/binary_local-hooks/grub2-efi67
-rwxr-xr-xconfig/binary_local-hooks/grub2-theme6
4 files changed, 74 insertions, 1 deletions
diff --git a/config/binary_local-includes/boot/grub/x86_64-efi/grub.cfg b/config/binary_grub/grub-efi.cfg
index bff7cab..bff7cab 100644
--- a/config/binary_local-includes/boot/grub/x86_64-efi/grub.cfg
+++ b/config/binary_grub/grub-efi.cfg
diff --git a/config/binary_grub/grub.cfg b/config/binary_grub/grub.cfg
index be60ad3..3cd4f20 100644
--- a/config/binary_grub/grub.cfg
+++ b/config/binary_grub/grub.cfg
@@ -81,7 +81,7 @@ if [ $efi != 1 ] ; then
}
else
menuentry 'EFI Shell' {
- chainloader /efi/shellx64.efi
+ chainloader /efi/boot/shellx64.efi
}
if search -nf /EFI/Microsoft/Boot/BOOTMGR.EFI ; then
menuentry 'Microsoft Bootmgr' {
diff --git a/config/binary_local-hooks/grub2-efi b/config/binary_local-hooks/grub2-efi
new file mode 100755
index 0000000..4984370
--- /dev/null
+++ b/config/binary_local-hooks/grub2-efi
@@ -0,0 +1,67 @@
+#!/bin/bash
+
+platform=x86_64
+efi_name=x64
+modules="search iso9660 configfile normal memdisk tar part_msdos fat"
+
+memdisk_img=
+workdir=
+
+cleanup () {
+ [ -z "$memdisk_img" ] || rm -f "$memdisk_img"
+ [ -z "$workdir" ] || rm -rf "$workdir"
+}
+trap cleanup EXIT HUP INT QUIT TERM
+
+memdisk_img="$(mktemp efi-image.XXXXXX)"
+workdir="$(mktemp -d efi-image.XXXXXX)"
+
+# Skeleton configuration file which finds the real boot disk.
+mkdir -p "$workdir/boot/grub"
+cat >"$workdir/boot/grub/grub.cfg" <<EOF
+search --file --set=root /.disk/info
+set prefix=(\$root)/boot/grub/$platform
+source \$prefix/grub.cfg
+EOF
+
+mkdir -p "binary/boot/grub/$platform"
+mkdir -p "binary/efi/boot"
+
+(for i in $(cat chroot/usr/lib/grub/$platform/partmap.lst); do
+ echo "insmod $i"
+ done; \
+ echo "source /boot/grub/grub-efi.cfg") >"binary/boot/grub/$platform/grub.cfg"
+
+# fix module order ("gzio" should be loaded before "normal", otherwise a "prefix not set" error message will pop up on boot)
+sed -i.orig -e '/^normal:/{/gzio/!{s/$/ gzio/}}' chroot/usr/lib/grub/x86_64-efi/moddep.lst
+
+# Build the core image.
+(cd "$workdir"; tar -cf - boot) >"$memdisk_img"
+grub-mkimage -v -O "$platform" -m "$memdisk_img" \
+ -o "binary/efi/boot/boot$efi_name.efi" -p '(memdisk)/boot/grub' $modules
+
+# restore original module order
+mv chroot/usr/lib/grub/x86_64-efi/moddep.lst{.orig,}
+
+# Copy over GRUB modules, except for those already built in.
+cp -a "chroot/usr/lib/grub/$platform"/*.lst "binary/boot/grub/$platform/"
+builtin_modules="$(m="$modules"; while [ "$m" ] && echo $m
+ do m=$(sed -ne "s/^\($(echo -n $m | sed 's/ /\\|/g')\):\(.*\)$/\2/p" "chroot/usr/lib/grub/$platform"/moddep.lst)
+ done | fmt -w1 | sort -u)"
+for x in "chroot/usr/lib/grub/$platform"/*.mod; do
+ case $(basename "$x" .mod) in
+ affs|afs|afs_be|befs|befs_be|minix|nilfs2|sfs|zfs|zfsinfo)
+ # unnecessary filesystem modules
+ ;;
+ example_functional_test|functional_test|hello)
+ # other cruft
+ ;;
+ *)
+ grep -wq $(basename "$x" .mod) <<<"$builtin_modules" || cp -a "$x" "binary/boot/grub/$platform/"
+ ;;
+ esac
+done
+
+# include EFI shell
+wget -O efi/boot/shellx64.efi 'http://tianocore.git.sourceforge.net/git/gitweb.cgi?p=tianocore/edk2;a=blob_plain;f=EdkShellBinPkg/FullShell/X64/Shell_Full.efi;hb=HEAD'
+
diff --git a/config/binary_local-hooks/grub2-theme b/config/binary_local-hooks/grub2-theme
new file mode 100755
index 0000000..8fd752a
--- /dev/null
+++ b/config/binary_local-hooks/grub2-theme
@@ -0,0 +1,6 @@
+#!/bin/bash
+# copy theme related files to binary
+mkdir -p binary/boot/grub
+cp chroot/usr/share/grub/unicode.pf2 binary/boot/grub/
+cp chroot/usr/share/images/grub/kanotix-logo.png binary/boot/grub/
+