8ee92f5194
- Implement NV index mode for TPM 2.0 key protector 0001-protectors-Implement-NV-index.patch - Fall back to passphrase mode when the key protector fails to unlock the disk 0002-cryptodisk-Fallback-to-passphrase.patch - Wipe out the cached key cleanly 0003-cryptodisk-wipe-out-the-cached-keys-from-protectors.patch - Make diskfiler to look up cryptodisk devices first 0004-diskfilter-look-up-cryptodisk-devices-first.patch - Version bump to 2.12~rc1 * Added: - grub-2.12~rc1.tar.xz * Removed: - grub-2.06.tar.xz * Patch dropped merged by new version: - grub2-GRUB_CMDLINE_LINUX_RECOVERY-for-recovery-mode.patch - grub2-s390x-02-kexec-module-added-to-emu.patch - grub2-efi-chainloader-root.patch - grub2-Fix-incorrect-netmask-on-ppc64.patch - 0001-osdep-Introduce-include-grub-osdep-major.h-and-use-i.patch - 0002-osdep-linux-hostdisk-Use-stat-instead-of-udevadm-for.patch - 0002-net-read-bracketed-ipv6-addrs-and-port-numbers.patch - grub2-s390x-10-keep-network-at-kexec.patch - 0001-Fix-build-error-in-binutils-2.36.patch - 0001-emu-fix-executable-stack-marking.patch - 0046-squash-verifiers-Move-verifiers-API-to-kernel-image.patch - 0001-30_uefi-firmware-fix-printf-format-with-null-byte.patch - 0001-tpm-Pass-unknown-error-as-non-fatal-but-debug-print-.patch - 0001-Filter-out-POSIX-locale-for-translation.patch OBS-URL: https://build.opensuse.org/request/show/1105405 OBS-URL: https://build.opensuse.org/package/show/Base:System/grub2?expand=0&rev=458
164 lines
4.2 KiB
Diff
164 lines
4.2 KiB
Diff
From 58dcf7985b20de876a6fc44a591aa377d0a0302c Mon Sep 17 00:00:00 2001
|
|
From: Michael Chang <mchang@suse.com>
|
|
Date: Thu, 10 Feb 2022 22:16:58 +0800
|
|
Subject: [PATCH] grub-install: bailout root device probing
|
|
|
|
The root device is probed to test if the filesystem is btrfs in order to setup
|
|
boot configs for snapshot booting. However when the root device is a lvm thin
|
|
volume, due to lack in grub support, the probing will be errored out and entire
|
|
installation process aborts.
|
|
|
|
Here we call out stat to bailout the situation whenever grub fails to probe
|
|
filesystem in it's own right.
|
|
|
|
stat -f -c %T /
|
|
|
|
The command is also used by grub-mkconfig for the same purpose.
|
|
|
|
Signed-off-by: Michael Chang <mchang@suse.com>
|
|
---
|
|
grub-core/osdep/basic/no_platform.c | 5 +++++
|
|
grub-core/osdep/unix/platform.c | 34 +++++++++++++++++++++++++++++
|
|
grub-core/osdep/windows/platform.c | 6 +++++
|
|
include/grub/util/install.h | 3 +++
|
|
util/grub-install.c | 31 ++++++++++++++++++--------
|
|
5 files changed, 70 insertions(+), 9 deletions(-)
|
|
|
|
--- a/grub-core/osdep/basic/no_platform.c
|
|
+++ b/grub-core/osdep/basic/no_platform.c
|
|
@@ -51,3 +51,8 @@
|
|
grub_util_error ("%s", _("no zIPL routines are available for your platform"));
|
|
}
|
|
|
|
+char *
|
|
+grub_install_get_filesystem (const char *path)
|
|
+{
|
|
+ return NULL;
|
|
+}
|
|
--- a/grub-core/osdep/unix/platform.c
|
|
+++ b/grub-core/osdep/unix/platform.c
|
|
@@ -250,3 +250,37 @@
|
|
"-z", dest, NULL }))
|
|
grub_util_error (_("`%s' failed.\n"), PACKAGE"-zipl-setup");
|
|
}
|
|
+
|
|
+char *
|
|
+grub_install_get_filesystem (const char *path)
|
|
+{
|
|
+ int fd;
|
|
+ pid_t pid;
|
|
+ FILE *fp;
|
|
+ ssize_t len;
|
|
+ char *buf = NULL;
|
|
+ size_t bufsz = 0;
|
|
+
|
|
+ pid = grub_util_exec_pipe ((const char * []){ "stat", "-f", "-c", "%T", path, NULL }, &fd);
|
|
+ if (!pid)
|
|
+ return NULL;
|
|
+
|
|
+ fp = fdopen (fd, "r");
|
|
+ if (!fp)
|
|
+ return NULL;
|
|
+
|
|
+ len = getline (&buf, &bufsz, fp);
|
|
+ if (len == -1)
|
|
+ {
|
|
+ free (buf);
|
|
+ fclose (fp);
|
|
+ return NULL;
|
|
+ }
|
|
+
|
|
+ fclose (fp);
|
|
+
|
|
+ if (len > 0 && buf[len - 1] == '\n')
|
|
+ buf[len - 1] = '\0';
|
|
+
|
|
+ return buf;
|
|
+}
|
|
--- a/grub-core/osdep/windows/platform.c
|
|
+++ b/grub-core/osdep/windows/platform.c
|
|
@@ -440,3 +440,9 @@
|
|
{
|
|
grub_util_error ("%s", _("no zIPL routines are available for your platform"));
|
|
}
|
|
+
|
|
+char *
|
|
+grub_install_get_filesystem (const char *path)
|
|
+{
|
|
+ return NULL;
|
|
+}
|
|
--- a/include/grub/util/install.h
|
|
+++ b/include/grub/util/install.h
|
|
@@ -251,6 +251,9 @@
|
|
void
|
|
grub_install_zipl (const char *d, int i, int f);
|
|
|
|
+char *
|
|
+grub_install_get_filesystem (const char *path);
|
|
+
|
|
int
|
|
grub_install_compress_gzip (const char *src, const char *dest);
|
|
int
|
|
--- a/util/grub-install.c
|
|
+++ b/util/grub-install.c
|
|
@@ -887,7 +887,6 @@
|
|
const char *efi_file = NULL;
|
|
char **grub_devices;
|
|
grub_fs_t grub_fs;
|
|
- grub_fs_t root_fs;
|
|
grub_device_t grub_dev = NULL;
|
|
enum grub_install_plat platform;
|
|
char *grubdir, *device_map;
|
|
@@ -1067,8 +1066,10 @@
|
|
grub_host_init ();
|
|
|
|
{
|
|
- char *rootdir_grub_devname;
|
|
- grub_device_t rootdir_grub_dev;
|
|
+ grub_device_t rootdir_grub_dev = NULL;
|
|
+ char *rootdir_grub_devname = NULL;
|
|
+ char *root_fs_name = NULL;
|
|
+
|
|
char *t = grub_util_path_concat (2, "/", rootdir);
|
|
|
|
rootdir_path = grub_canonicalize_file_name (t);
|
|
@@ -1089,20 +1090,32 @@
|
|
rootdir_devices[0]);
|
|
|
|
rootdir_grub_dev = grub_device_open (rootdir_grub_devname);
|
|
- if (! rootdir_grub_dev)
|
|
- grub_util_error ("%s", grub_errmsg);
|
|
+ if (!rootdir_grub_dev)
|
|
+ {
|
|
+ root_fs_name = grub_install_get_filesystem (t);
|
|
+ if (root_fs_name)
|
|
+ grub_errno = 0;
|
|
+ }
|
|
+ else
|
|
+ {
|
|
+ grub_fs_t root_fs = grub_fs_probe (rootdir_grub_dev);
|
|
+ if (root_fs)
|
|
+ root_fs_name = grub_strdup (root_fs->name);
|
|
+ }
|
|
|
|
- root_fs = grub_fs_probe (rootdir_grub_dev);
|
|
- if (!root_fs)
|
|
+ if (!root_fs_name)
|
|
grub_util_error ("%s", grub_errmsg);
|
|
|
|
if (config.is_suse_btrfs_snapshot_enabled
|
|
- && grub_strncmp(root_fs->name, "btrfs", sizeof ("btrfs") - 1) == 0)
|
|
+ && root_fs_name
|
|
+ && grub_strncmp(root_fs_name, "btrfs", sizeof ("btrfs") - 1) == 0)
|
|
use_relative_path_on_btrfs = 1;
|
|
|
|
+ free (root_fs_name);
|
|
free (t);
|
|
free (rootdir_grub_devname);
|
|
- grub_device_close (rootdir_grub_dev);
|
|
+ if (rootdir_grub_dev)
|
|
+ grub_device_close (rootdir_grub_dev);
|
|
}
|
|
|
|
switch (platform)
|