1
0
Fork 0
grub2/debian/patches/mkconfig-ubuntu-recovery.patch
Daniel Baumann 4cf387939d
Adding debian version 2.12-8.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
2025-06-22 15:25:08 +02:00

105 lines
3.2 KiB
Diff

From: Colin Watson <cjwatson@ubuntu.com>
Date: Mon, 13 Jan 2014 12:13:06 +0000
Subject: "single" -> "recovery" when friendly-recovery is installed
MIME-Version: 1.0
Content-Type: text/plain; charset="utf-8"
Content-Transfer-Encoding: 8bit
If configured with --enable-ubuntu-recovery, also set nomodeset for
recovery mode, and disable 'set gfxpayload=keep' even if the system
normally supports it. See
https://launchpad.net/ubuntu/+spec/desktop-o-xorg-tools-and-processes.
Author: Stéphane Graber <stgraber@ubuntu.com>
Forwarded: no
Last-Update: 2013-12-25
Patch-Name: mkconfig-ubuntu-recovery.patch
---
configure.ac | 11 +++++++++++
util/grub.d/10_linux.in | 15 +++++++++++++--
util/grub.d/30_os-prober.in | 2 +-
3 files changed, 25 insertions(+), 3 deletions(-)
diff --git a/configure.ac b/configure.ac
index cd667a2..f19356e 100644
--- a/configure.ac
+++ b/configure.ac
@@ -2057,6 +2057,17 @@ fi
AC_SUBST([LIBZFS])
AC_SUBST([LIBNVPAIR])
+AC_ARG_ENABLE([ubuntu-recovery],
+ [AS_HELP_STRING([--enable-ubuntu-recovery],
+ [adjust boot options for the Ubuntu recovery mode (default=no)])],
+ [], [enable_ubuntu_recovery=no])
+if test x"$enable_ubuntu_recovery" = xyes ; then
+ UBUNTU_RECOVERY=1
+else
+ UBUNTU_RECOVERY=0
+fi
+AC_SUBST([UBUNTU_RECOVERY])
+
LIBS=""
AC_SUBST([FONT_SOURCE])
diff --git a/util/grub.d/10_linux.in b/util/grub.d/10_linux.in
index cc6ae58..858052c 100644
--- a/util/grub.d/10_linux.in
+++ b/util/grub.d/10_linux.in
@@ -20,6 +20,7 @@ set -e
prefix="@prefix@"
exec_prefix="@exec_prefix@"
datarootdir="@datarootdir@"
+ubuntu_recovery="@UBUNTU_RECOVERY@"
. "$pkgdatadir/grub-mkconfig_lib"
@@ -48,7 +49,11 @@ case ${GRUB_DEVICE} in
;;
esac
-: ${GRUB_CMDLINE_LINUX_RECOVERY:=single}
+if [ -x /lib/recovery-mode/recovery-menu ]; then
+ : ${GRUB_CMDLINE_LINUX_RECOVERY:=recovery}
+else
+ : ${GRUB_CMDLINE_LINUX_RECOVERY:=single}
+fi
# Default to disabling partition uuid support to maintian compatibility with
# older kernels.
@@ -86,6 +91,10 @@ esac
title_correction_code=
+if [ "$ubuntu_recovery" = 1 ]; then
+ GRUB_CMDLINE_LINUX_RECOVERY="$GRUB_CMDLINE_LINUX_RECOVERY nomodeset"
+fi
+
linux_entry ()
{
os="$1"
@@ -125,7 +134,9 @@ linux_entry ()
if [ "x$GRUB_GFXPAYLOAD_LINUX" != xtext ]; then
echo " load_video" | sed "s/^/$submenu_indentation/"
fi
- echo " set gfxpayload=$GRUB_GFXPAYLOAD_LINUX" | sed "s/^/$submenu_indentation/"
+ if [ "$ubuntu_recovery" = 0 ] || [ x$type != xrecovery ]; then
+ echo " set gfxpayload=$GRUB_GFXPAYLOAD_LINUX" | sed "s/^/$submenu_indentation/"
+ fi
fi
echo " insmod gzio" | sed "s/^/$submenu_indentation/"
diff --git a/util/grub.d/30_os-prober.in b/util/grub.d/30_os-prober.in
index 656301e..b74606b 100644
--- a/util/grub.d/30_os-prober.in
+++ b/util/grub.d/30_os-prober.in
@@ -227,7 +227,7 @@ EOF
fi
onstr="$(gettext_printf "(on %s)" "${DEVICE}")"
- recovery_params="$(echo "${LPARAMS}" | grep single)" || true
+ recovery_params="$(echo "${LPARAMS}" | grep 'single\|recovery')" || true
counter=1
while echo "$used_osprober_linux_ids" | grep 'osprober-gnulinux-$LKERNEL-${recovery_params}-$counter-$boot_device_id' > /dev/null; do
counter=$((counter+1));