Compare commits
No commits in common. "c8" and "a10s" have entirely different histories.
15
.git.diff.order
Normal file
15
.git.diff.order
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
*.dec
|
||||||
|
*.dsc.inc
|
||||||
|
*.dsc
|
||||||
|
*.fdf
|
||||||
|
*.inf
|
||||||
|
*.vfr
|
||||||
|
*.ac
|
||||||
|
*.def
|
||||||
|
*.c
|
||||||
|
*.h
|
||||||
|
*.S
|
||||||
|
*.mk
|
||||||
|
Makefile.*
|
||||||
|
Make.*
|
||||||
|
Makefile
|
1
.gitattributes
vendored
Normal file
1
.gitattributes
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
po/exclude.pot binary
|
22
.gitignore
vendored
22
.gitignore
vendored
@ -1,9 +1,13 @@
|
|||||||
SOURCES/grub-2.02.tar.xz
|
grub-*.tar.?z
|
||||||
SOURCES/redhatsecureboot301.cer
|
*.rpm
|
||||||
SOURCES/redhatsecureboot502.cer
|
clog
|
||||||
SOURCES/redhatsecureboot601.cer
|
/unifont-*.pcf.?z
|
||||||
SOURCES/redhatsecureboot701.cer
|
/theme.tar.bz2
|
||||||
SOURCES/redhatsecurebootca3.cer
|
kojilogs
|
||||||
SOURCES/redhatsecurebootca5.cer
|
/grub-*/
|
||||||
SOURCES/theme.tar.bz2
|
.build*.log
|
||||||
SOURCES/unifont-5.1.20080820.pcf.gz
|
.*.git/
|
||||||
|
tmp/
|
||||||
|
.*.sw?
|
||||||
|
results_grub2/
|
||||||
|
/gnulib-*.tar.?z
|
||||||
|
@ -1,9 +0,0 @@
|
|||||||
3d7eb6eaab28b88cb969ba9ab24af959f4d1b178 SOURCES/grub-2.02.tar.xz
|
|
||||||
4a07b56e28741884b86da6ac91f8f9929541a1e4 SOURCES/redhatsecureboot301.cer
|
|
||||||
3f94c47f1d08bacc7cb29bdd912e286b8d2f6fcf SOURCES/redhatsecureboot502.cer
|
|
||||||
039357ef97aab3e484d1119edd4528156f5859e6 SOURCES/redhatsecureboot601.cer
|
|
||||||
e89890ca0ded2f9058651cc5fa838b78db2e6cc2 SOURCES/redhatsecureboot701.cer
|
|
||||||
cf9230e69000076727e5b784ec871d22716dc5da SOURCES/redhatsecurebootca3.cer
|
|
||||||
e6f506462069aa17d2e8610503635c20f3a995c3 SOURCES/redhatsecurebootca5.cer
|
|
||||||
cf0b7763c528902da7e8b05cfa248f20c8825ce5 SOURCES/theme.tar.bz2
|
|
||||||
87f8600ba24e521b5d20bdf6c4b71af8ae861e3a SOURCES/unifont-5.1.20080820.pcf.gz
|
|
@ -0,0 +1,24 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Javier Martinez Canillas <javierm@redhat.com>
|
||||||
|
Date: Fri, 11 Jun 2021 12:10:45 +0200
|
||||||
|
Subject: [PATCH] Revert "templates: Fix user-facing typo with an incorrect use
|
||||||
|
of "it's""
|
||||||
|
|
||||||
|
This reverts commit 722737630889607c3b5761f1f5a48f1674cd2821.
|
||||||
|
---
|
||||||
|
util/grub.d/30_os-prober.in | 2 +-
|
||||||
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/util/grub.d/30_os-prober.in b/util/grub.d/30_os-prober.in
|
||||||
|
index 5984e92d29..9462248128 100644
|
||||||
|
--- a/util/grub.d/30_os-prober.in
|
||||||
|
+++ b/util/grub.d/30_os-prober.in
|
||||||
|
@@ -36,7 +36,7 @@ if ! command -v os-prober > /dev/null || ! command -v linux-boot-prober > /dev/n
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
-grub_warn "$(gettext_printf "os-prober will be executed to detect other bootable partitions.\nIts output will be used to detect bootable binaries on them and create new boot entries.")"
|
||||||
|
+grub_warn "$(gettext_printf "os-prober will be executed to detect other bootable partitions.\nIt's output will be used to detect bootable binaries on them and create new boot entries.")"
|
||||||
|
|
||||||
|
OSPROBED="`os-prober | tr ' ' '^' | paste -s -d ' '`"
|
||||||
|
if [ -z "${OSPROBED}" ] ; then
|
@ -0,0 +1,71 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Javier Martinez Canillas <javierm@redhat.com>
|
||||||
|
Date: Fri, 11 Jun 2021 12:10:54 +0200
|
||||||
|
Subject: [PATCH] Revert "templates: Properly disable the os-prober by default"
|
||||||
|
|
||||||
|
This reverts commit 54e0a1bbf1e9106901a557195bb35e5e20fb3925.
|
||||||
|
---
|
||||||
|
util/grub-mkconfig.in | 5 +----
|
||||||
|
util/grub.d/30_os-prober.in | 8 ++++----
|
||||||
|
2 files changed, 5 insertions(+), 8 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/util/grub-mkconfig.in b/util/grub-mkconfig.in
|
||||||
|
index f8cbb8d7a2..d3e879b8e5 100644
|
||||||
|
--- a/util/grub-mkconfig.in
|
||||||
|
+++ b/util/grub-mkconfig.in
|
||||||
|
@@ -140,9 +140,6 @@ GRUB_DEVICE_PARTUUID="`${grub_probe} --device ${GRUB_DEVICE} --target=partuuid 2
|
||||||
|
GRUB_DEVICE_BOOT="`${grub_probe} --target=device /boot`"
|
||||||
|
GRUB_DEVICE_BOOT_UUID="`${grub_probe} --device ${GRUB_DEVICE_BOOT} --target=fs_uuid 2> /dev/null`" || true
|
||||||
|
|
||||||
|
-# Disable os-prober by default due to security reasons.
|
||||||
|
-GRUB_DISABLE_OS_PROBER="true"
|
||||||
|
-
|
||||||
|
# Filesystem for the device containing our userland. Used for stuff like
|
||||||
|
# choosing Hurd filesystem module.
|
||||||
|
GRUB_FS="`${grub_probe} --device ${GRUB_DEVICE} --target=fs 2> /dev/null || echo unknown`"
|
||||||
|
@@ -204,7 +201,6 @@ export GRUB_DEVICE \
|
||||||
|
GRUB_DEVICE_PARTUUID \
|
||||||
|
GRUB_DEVICE_BOOT \
|
||||||
|
GRUB_DEVICE_BOOT_UUID \
|
||||||
|
- GRUB_DISABLE_OS_PROBER \
|
||||||
|
GRUB_FS \
|
||||||
|
GRUB_FONT \
|
||||||
|
GRUB_PRELOAD_MODULES \
|
||||||
|
@@ -246,6 +242,7 @@ export GRUB_DEFAULT \
|
||||||
|
GRUB_BACKGROUND \
|
||||||
|
GRUB_THEME \
|
||||||
|
GRUB_GFXPAYLOAD_LINUX \
|
||||||
|
+ GRUB_DISABLE_OS_PROBER \
|
||||||
|
GRUB_INIT_TUNE \
|
||||||
|
GRUB_SAVEDEFAULT \
|
||||||
|
GRUB_ENABLE_CRYPTODISK \
|
||||||
|
diff --git a/util/grub.d/30_os-prober.in b/util/grub.d/30_os-prober.in
|
||||||
|
index 9462248128..80685b15f4 100644
|
||||||
|
--- a/util/grub.d/30_os-prober.in
|
||||||
|
+++ b/util/grub.d/30_os-prober.in
|
||||||
|
@@ -26,8 +26,8 @@ export TEXTDOMAINDIR="@localedir@"
|
||||||
|
|
||||||
|
. "$pkgdatadir/grub-mkconfig_lib"
|
||||||
|
|
||||||
|
-if [ "x${GRUB_DISABLE_OS_PROBER}" = "xtrue" ]; then
|
||||||
|
- grub_warn "$(gettext_printf "os-prober will not be executed to detect other bootable partitions.\nSystems on them will not be added to the GRUB boot configuration.\nCheck GRUB_DISABLE_OS_PROBER documentation entry.")"
|
||||||
|
+if [ "x${GRUB_DISABLE_OS_PROBER}" = "xfalse" ]; then
|
||||||
|
+ gettext_printf "os-prober will not be executed to detect other bootable partitions.\nSystems on them will not be added to the GRUB boot configuration.\nCheck GRUB_DISABLE_OS_PROBER documentation entry.\n"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
@@ -36,12 +36,12 @@ if ! command -v os-prober > /dev/null || ! command -v linux-boot-prober > /dev/n
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
-grub_warn "$(gettext_printf "os-prober will be executed to detect other bootable partitions.\nIt's output will be used to detect bootable binaries on them and create new boot entries.")"
|
||||||
|
-
|
||||||
|
OSPROBED="`os-prober | tr ' ' '^' | paste -s -d ' '`"
|
||||||
|
if [ -z "${OSPROBED}" ] ; then
|
||||||
|
# empty os-prober output, nothing doing
|
||||||
|
exit 0
|
||||||
|
+else
|
||||||
|
+ grub_warn "$(gettext_printf "os-prober was executed to detect other bootable partitions.\nIt's output will be used to detect bootable binaries on them and create new boot entries.")"
|
||||||
|
fi
|
||||||
|
|
||||||
|
osx_entry() {
|
70
0003-Revert-templates-Disable-the-os-prober-by-default.patch
Normal file
70
0003-Revert-templates-Disable-the-os-prober-by-default.patch
Normal file
@ -0,0 +1,70 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Javier Martinez Canillas <javierm@redhat.com>
|
||||||
|
Date: Fri, 11 Jun 2021 12:10:58 +0200
|
||||||
|
Subject: [PATCH] Revert "templates: Disable the os-prober by default"
|
||||||
|
|
||||||
|
This reverts commit e346414725a70e5c74ee87ca14e580c66f517666.
|
||||||
|
---
|
||||||
|
docs/grub.texi | 18 ++++++++----------
|
||||||
|
util/grub.d/30_os-prober.in | 5 +----
|
||||||
|
2 files changed, 9 insertions(+), 14 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/docs/grub.texi b/docs/grub.texi
|
||||||
|
index f8b4b3b21a..69f08d289f 100644
|
||||||
|
--- a/docs/grub.texi
|
||||||
|
+++ b/docs/grub.texi
|
||||||
|
@@ -1519,13 +1519,10 @@ boot sequence. If you have problems, set this option to @samp{text} and
|
||||||
|
GRUB will tell Linux to boot in normal text mode.
|
||||||
|
|
||||||
|
@item GRUB_DISABLE_OS_PROBER
|
||||||
|
-The @command{grub-mkconfig} has a feature to use the external
|
||||||
|
-@command{os-prober} program to discover other operating systems installed on
|
||||||
|
-the same machine and generate appropriate menu entries for them. It is disabled
|
||||||
|
-by default since automatic and silent execution of @command{os-prober}, and
|
||||||
|
-creating boot entries based on that data, is a potential attack vector. Set
|
||||||
|
-this option to @samp{false} to enable this feature in the
|
||||||
|
-@command{grub-mkconfig} command.
|
||||||
|
+Normally, @command{grub-mkconfig} will try to use the external
|
||||||
|
+@command{os-prober} program, if installed, to discover other operating
|
||||||
|
+systems installed on the same system and generate appropriate menu entries
|
||||||
|
+for them. Set this option to @samp{true} to disable this.
|
||||||
|
|
||||||
|
@item GRUB_OS_PROBER_SKIP_LIST
|
||||||
|
List of space-separated FS UUIDs of filesystems to be ignored from os-prober
|
||||||
|
@@ -1853,9 +1850,10 @@ than zero; otherwise 0.
|
||||||
|
@section Multi-boot manual config
|
||||||
|
|
||||||
|
Currently autogenerating config files for multi-boot environments depends on
|
||||||
|
-os-prober and has several shortcomings. Due to that it is disabled by default.
|
||||||
|
-It is advised to use the power of GRUB syntax and do it yourself. A possible
|
||||||
|
-configuration is detailed here, feel free to adjust to your needs.
|
||||||
|
+os-prober and has several shortcomings. While fixing it is scheduled for the
|
||||||
|
+next release, meanwhile you can make use of the power of GRUB syntax and do it
|
||||||
|
+yourself. A possible configuration is detailed here, feel free to adjust to your
|
||||||
|
+needs.
|
||||||
|
|
||||||
|
First create a separate GRUB partition, big enough to hold GRUB. Some of the
|
||||||
|
following entries show how to load OS installer images from this same partition,
|
||||||
|
diff --git a/util/grub.d/30_os-prober.in b/util/grub.d/30_os-prober.in
|
||||||
|
index 80685b15f4..1b91c102f3 100644
|
||||||
|
--- a/util/grub.d/30_os-prober.in
|
||||||
|
+++ b/util/grub.d/30_os-prober.in
|
||||||
|
@@ -26,8 +26,7 @@ export TEXTDOMAINDIR="@localedir@"
|
||||||
|
|
||||||
|
. "$pkgdatadir/grub-mkconfig_lib"
|
||||||
|
|
||||||
|
-if [ "x${GRUB_DISABLE_OS_PROBER}" = "xfalse" ]; then
|
||||||
|
- gettext_printf "os-prober will not be executed to detect other bootable partitions.\nSystems on them will not be added to the GRUB boot configuration.\nCheck GRUB_DISABLE_OS_PROBER documentation entry.\n"
|
||||||
|
+if [ "x${GRUB_DISABLE_OS_PROBER}" = "xtrue" ]; then
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
@@ -40,8 +39,6 @@ OSPROBED="`os-prober | tr ' ' '^' | paste -s -d ' '`"
|
||||||
|
if [ -z "${OSPROBED}" ] ; then
|
||||||
|
# empty os-prober output, nothing doing
|
||||||
|
exit 0
|
||||||
|
-else
|
||||||
|
- grub_warn "$(gettext_printf "os-prober was executed to detect other bootable partitions.\nIt's output will be used to detect bootable binaries on them and create new boot entries.")"
|
||||||
|
fi
|
||||||
|
|
||||||
|
osx_entry() {
|
@ -35,20 +35,19 @@ moves the check into grub_dl_load_file.
|
|||||||
grub-core/loader/i386/efi/linux.c | 335 ++++++++++++++++++++++++++++++++++++++
|
grub-core/loader/i386/efi/linux.c | 335 ++++++++++++++++++++++++++++++++++++++
|
||||||
grub-core/loader/i386/pc/linux.c | 10 +-
|
grub-core/loader/i386/pc/linux.c | 10 +-
|
||||||
include/grub/arm/linux.h | 9 +
|
include/grub/arm/linux.h | 9 +
|
||||||
include/grub/arm64/linux.h | 10 ++
|
include/grub/arm64/linux.h | 9 +
|
||||||
include/grub/efi/efi.h | 7 +-
|
include/grub/efi/efi.h | 7 +-
|
||||||
include/grub/efi/linux.h | 31 ++++
|
include/grub/efi/linux.h | 31 ++++
|
||||||
include/grub/i386/linux.h | 1 +
|
13 files changed, 618 insertions(+), 69 deletions(-)
|
||||||
14 files changed, 620 insertions(+), 69 deletions(-)
|
|
||||||
create mode 100644 grub-core/loader/efi/linux.c
|
create mode 100644 grub-core/loader/efi/linux.c
|
||||||
create mode 100644 grub-core/loader/i386/efi/linux.c
|
create mode 100644 grub-core/loader/i386/efi/linux.c
|
||||||
create mode 100644 include/grub/efi/linux.h
|
create mode 100644 include/grub/efi/linux.h
|
||||||
|
|
||||||
diff --git a/grub-core/Makefile.core.def b/grub-core/Makefile.core.def
|
diff --git a/grub-core/Makefile.core.def b/grub-core/Makefile.core.def
|
||||||
index 9590e87d9..0b4b0c212 100644
|
index 8022e1c0a7..45d3edaa4d 100644
|
||||||
--- a/grub-core/Makefile.core.def
|
--- a/grub-core/Makefile.core.def
|
||||||
+++ b/grub-core/Makefile.core.def
|
+++ b/grub-core/Makefile.core.def
|
||||||
@@ -1626,13 +1626,6 @@ module = {
|
@@ -1734,13 +1734,6 @@ module = {
|
||||||
enable = i386_pc;
|
enable = i386_pc;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -62,7 +61,7 @@ index 9590e87d9..0b4b0c212 100644
|
|||||||
module = {
|
module = {
|
||||||
name = ntldr;
|
name = ntldr;
|
||||||
i386_pc = loader/i386/pc/ntldr.c;
|
i386_pc = loader/i386/pc/ntldr.c;
|
||||||
@@ -1685,7 +1678,9 @@ module = {
|
@@ -1796,7 +1789,9 @@ module = {
|
||||||
|
|
||||||
module = {
|
module = {
|
||||||
name = linux;
|
name = linux;
|
||||||
@ -70,13 +69,13 @@ index 9590e87d9..0b4b0c212 100644
|
|||||||
+ i386_pc = loader/i386/pc/linux.c;
|
+ i386_pc = loader/i386/pc/linux.c;
|
||||||
+ x86_64_efi = loader/i386/efi/linux.c;
|
+ x86_64_efi = loader/i386/efi/linux.c;
|
||||||
+ i386_efi = loader/i386/efi/linux.c;
|
+ i386_efi = loader/i386/efi/linux.c;
|
||||||
|
i386_xen_pvh = loader/i386/linux.c;
|
||||||
xen = loader/i386/xen.c;
|
xen = loader/i386/xen.c;
|
||||||
i386_pc = lib/i386/pc/vesa_modes_table.c;
|
i386_pc = lib/i386/pc/vesa_modes_table.c;
|
||||||
mips = loader/mips/linux.c;
|
@@ -1811,9 +1806,14 @@ module = {
|
||||||
@@ -1696,9 +1691,14 @@ module = {
|
|
||||||
arm_efi = loader/arm64/linux.c;
|
|
||||||
arm_uboot = loader/arm/linux.c;
|
|
||||||
arm64 = loader/arm64/linux.c;
|
arm64 = loader/arm64/linux.c;
|
||||||
|
riscv32 = loader/riscv/linux.c;
|
||||||
|
riscv64 = loader/riscv/linux.c;
|
||||||
+ emu = loader/emu/linux.c;
|
+ emu = loader/emu/linux.c;
|
||||||
+ fdt = lib/fdt.c;
|
+ fdt = lib/fdt.c;
|
||||||
+
|
+
|
||||||
@ -89,7 +88,7 @@ index 9590e87d9..0b4b0c212 100644
|
|||||||
|
|
||||||
module = {
|
module = {
|
||||||
diff --git a/grub-core/kern/dl.c b/grub-core/kern/dl.c
|
diff --git a/grub-core/kern/dl.c b/grub-core/kern/dl.c
|
||||||
index e394cd96f..04e804d16 100644
|
index 48f8a79073..b714937095 100644
|
||||||
--- a/grub-core/kern/dl.c
|
--- a/grub-core/kern/dl.c
|
||||||
+++ b/grub-core/kern/dl.c
|
+++ b/grub-core/kern/dl.c
|
||||||
@@ -38,6 +38,14 @@
|
@@ -38,6 +38,14 @@
|
||||||
@ -107,7 +106,7 @@ index e394cd96f..04e804d16 100644
|
|||||||
|
|
||||||
|
|
||||||
#pragma GCC diagnostic ignored "-Wcast-align"
|
#pragma GCC diagnostic ignored "-Wcast-align"
|
||||||
@@ -686,6 +694,19 @@ grub_dl_load_file (const char *filename)
|
@@ -695,6 +703,19 @@ grub_dl_load_file (const char *filename)
|
||||||
void *core = 0;
|
void *core = 0;
|
||||||
grub_dl_t mod = 0;
|
grub_dl_t mod = 0;
|
||||||
|
|
||||||
@ -126,13 +125,13 @@ index e394cd96f..04e804d16 100644
|
|||||||
+
|
+
|
||||||
grub_boot_time ("Loading module %s", filename);
|
grub_boot_time ("Loading module %s", filename);
|
||||||
|
|
||||||
file = grub_file_open (filename);
|
file = grub_file_open (filename, GRUB_FILE_TYPE_GRUB_MODULE);
|
||||||
diff --git a/grub-core/kern/efi/efi.c b/grub-core/kern/efi/efi.c
|
diff --git a/grub-core/kern/efi/efi.c b/grub-core/kern/efi/efi.c
|
||||||
index 708581fcb..c8a9d8307 100644
|
index 8cff7be028..35b8f67060 100644
|
||||||
--- a/grub-core/kern/efi/efi.c
|
--- a/grub-core/kern/efi/efi.c
|
||||||
+++ b/grub-core/kern/efi/efi.c
|
+++ b/grub-core/kern/efi/efi.c
|
||||||
@@ -273,6 +273,34 @@ grub_efi_get_variable (const char *var, const grub_efi_guid_t *guid,
|
@@ -286,6 +286,34 @@ grub_efi_get_variable (const char *var, const grub_efi_guid_t *guid,
|
||||||
return NULL;
|
return grub_efi_get_variable_with_attributes (var, guid, datasize_out, data_out, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
+grub_efi_boolean_t
|
+grub_efi_boolean_t
|
||||||
@ -167,7 +166,7 @@ index 708581fcb..c8a9d8307 100644
|
|||||||
|
|
||||||
/* Search the mods section from the PE32/PE32+ image. This code uses
|
/* Search the mods section from the PE32/PE32+ image. This code uses
|
||||||
diff --git a/grub-core/kern/efi/mm.c b/grub-core/kern/efi/mm.c
|
diff --git a/grub-core/kern/efi/mm.c b/grub-core/kern/efi/mm.c
|
||||||
index 42ad7c570..5cdf6c943 100644
|
index 9838fb2f50..f6aef0ef64 100644
|
||||||
--- a/grub-core/kern/efi/mm.c
|
--- a/grub-core/kern/efi/mm.c
|
||||||
+++ b/grub-core/kern/efi/mm.c
|
+++ b/grub-core/kern/efi/mm.c
|
||||||
@@ -113,6 +113,38 @@ grub_efi_drop_alloc (grub_efi_physical_address_t address,
|
@@ -113,6 +113,38 @@ grub_efi_drop_alloc (grub_efi_physical_address_t address,
|
||||||
@ -210,7 +209,7 @@ index 42ad7c570..5cdf6c943 100644
|
|||||||
void *
|
void *
|
||||||
grub_efi_allocate_pages_real (grub_efi_physical_address_t address,
|
grub_efi_allocate_pages_real (grub_efi_physical_address_t address,
|
||||||
diff --git a/grub-core/loader/arm64/linux.c b/grub-core/loader/arm64/linux.c
|
diff --git a/grub-core/loader/arm64/linux.c b/grub-core/loader/arm64/linux.c
|
||||||
index 1f86229f8..6c00af98d 100644
|
index ef3e9f9444..a312c66868 100644
|
||||||
--- a/grub-core/loader/arm64/linux.c
|
--- a/grub-core/loader/arm64/linux.c
|
||||||
+++ b/grub-core/loader/arm64/linux.c
|
+++ b/grub-core/loader/arm64/linux.c
|
||||||
@@ -29,6 +29,7 @@
|
@@ -29,6 +29,7 @@
|
||||||
@ -221,7 +220,7 @@ index 1f86229f8..6c00af98d 100644
|
|||||||
#include <grub/efi/pe32.h>
|
#include <grub/efi/pe32.h>
|
||||||
#include <grub/i18n.h>
|
#include <grub/i18n.h>
|
||||||
#include <grub/lib/cmdline.h>
|
#include <grub/lib/cmdline.h>
|
||||||
@@ -40,6 +41,7 @@ static int loaded;
|
@@ -41,6 +42,7 @@ static int loaded;
|
||||||
|
|
||||||
static void *kernel_addr;
|
static void *kernel_addr;
|
||||||
static grub_uint64_t kernel_size;
|
static grub_uint64_t kernel_size;
|
||||||
@ -229,7 +228,7 @@ index 1f86229f8..6c00af98d 100644
|
|||||||
|
|
||||||
static char *linux_args;
|
static char *linux_args;
|
||||||
static grub_uint32_t cmdline_size;
|
static grub_uint32_t cmdline_size;
|
||||||
@@ -66,7 +68,8 @@ grub_armxx_efi_linux_check_image (struct linux_armxx_kernel_header * lh)
|
@@ -67,7 +69,8 @@ grub_arch_efi_linux_check_image (struct linux_arch_kernel_header * lh)
|
||||||
static grub_err_t
|
static grub_err_t
|
||||||
finalize_params_linux (void)
|
finalize_params_linux (void)
|
||||||
{
|
{
|
||||||
@ -239,7 +238,7 @@ index 1f86229f8..6c00af98d 100644
|
|||||||
|
|
||||||
void *fdt;
|
void *fdt;
|
||||||
|
|
||||||
@@ -101,79 +104,70 @@ finalize_params_linux (void)
|
@@ -102,79 +105,70 @@ finalize_params_linux (void)
|
||||||
if (grub_fdt_install() != GRUB_ERR_NONE)
|
if (grub_fdt_install() != GRUB_ERR_NONE)
|
||||||
goto failure;
|
goto failure;
|
||||||
|
|
||||||
@ -251,7 +250,7 @@ index 1f86229f8..6c00af98d 100644
|
|||||||
-}
|
-}
|
||||||
-
|
-
|
||||||
-grub_err_t
|
-grub_err_t
|
||||||
-grub_armxx_efi_linux_boot_image (grub_addr_t addr, grub_size_t size, char *args)
|
-grub_arch_efi_linux_boot_image (grub_addr_t addr, grub_size_t size, char *args)
|
||||||
-{
|
-{
|
||||||
- grub_efi_memory_mapped_device_path_t *mempath;
|
- grub_efi_memory_mapped_device_path_t *mempath;
|
||||||
- grub_efi_handle_t image_handle;
|
- grub_efi_handle_t image_handle;
|
||||||
@ -337,7 +336,7 @@ index 1f86229f8..6c00af98d 100644
|
|||||||
+}
|
+}
|
||||||
+
|
+
|
||||||
+grub_err_t
|
+grub_err_t
|
||||||
+grub_armxx_efi_linux_boot_image (grub_addr_t addr, char *args)
|
+grub_arch_efi_linux_boot_image (grub_addr_t addr, char *args)
|
||||||
+{
|
+{
|
||||||
+ grub_err_t retval;
|
+ grub_err_t retval;
|
||||||
+
|
+
|
||||||
@ -360,21 +359,21 @@ index 1f86229f8..6c00af98d 100644
|
|||||||
- if (finalize_params_linux () != GRUB_ERR_NONE)
|
- if (finalize_params_linux () != GRUB_ERR_NONE)
|
||||||
- return grub_errno;
|
- return grub_errno;
|
||||||
-
|
-
|
||||||
- return (grub_armxx_efi_linux_boot_image((grub_addr_t)kernel_addr,
|
- return (grub_arch_efi_linux_boot_image((grub_addr_t)kernel_addr,
|
||||||
- kernel_size, linux_args));
|
- kernel_size, linux_args));
|
||||||
+ return grub_armxx_efi_linux_boot_image((grub_addr_t)kernel_addr, linux_args);
|
+ return (grub_arch_efi_linux_boot_image((grub_addr_t)kernel_addr, linux_args));
|
||||||
}
|
}
|
||||||
|
|
||||||
static grub_err_t
|
static grub_err_t
|
||||||
@@ -287,6 +281,7 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
@@ -288,6 +282,7 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
{
|
{
|
||||||
grub_file_t file = 0;
|
grub_file_t file = 0;
|
||||||
struct linux_armxx_kernel_header lh;
|
struct linux_arch_kernel_header lh;
|
||||||
+ struct grub_armxx_linux_pe_header *pe;
|
+ struct grub_armxx_linux_pe_header *pe;
|
||||||
|
grub_err_t err;
|
||||||
|
|
||||||
grub_dl_ref (my_mod);
|
grub_dl_ref (my_mod);
|
||||||
|
@@ -333,6 +328,15 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
@@ -331,6 +326,15 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
|
||||||
|
|
||||||
grub_dprintf ("linux", "kernel @ %p\n", kernel_addr);
|
grub_dprintf ("linux", "kernel @ %p\n", kernel_addr);
|
||||||
|
|
||||||
@ -391,20 +390,20 @@ index 1f86229f8..6c00af98d 100644
|
|||||||
linux_args = grub_malloc (cmdline_size);
|
linux_args = grub_malloc (cmdline_size);
|
||||||
if (!linux_args)
|
if (!linux_args)
|
||||||
diff --git a/grub-core/loader/arm64/xen_boot.c b/grub-core/loader/arm64/xen_boot.c
|
diff --git a/grub-core/loader/arm64/xen_boot.c b/grub-core/loader/arm64/xen_boot.c
|
||||||
index 1003a0b99..f35b16caa 100644
|
index 22cc25eccd..d9b7a9ba40 100644
|
||||||
--- a/grub-core/loader/arm64/xen_boot.c
|
--- a/grub-core/loader/arm64/xen_boot.c
|
||||||
+++ b/grub-core/loader/arm64/xen_boot.c
|
+++ b/grub-core/loader/arm64/xen_boot.c
|
||||||
@@ -266,7 +266,6 @@ xen_boot (void)
|
@@ -266,7 +266,6 @@ xen_boot (void)
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
return grub_armxx_efi_linux_boot_image (xen_hypervisor->start,
|
return grub_arch_efi_linux_boot_image (xen_hypervisor->start,
|
||||||
- xen_hypervisor->size,
|
- xen_hypervisor->size,
|
||||||
xen_hypervisor->cmdline);
|
xen_hypervisor->cmdline);
|
||||||
}
|
}
|
||||||
|
|
||||||
diff --git a/grub-core/loader/efi/linux.c b/grub-core/loader/efi/linux.c
|
diff --git a/grub-core/loader/efi/linux.c b/grub-core/loader/efi/linux.c
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..c24202a5d
|
index 0000000000..c24202a5dd
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/grub-core/loader/efi/linux.c
|
+++ b/grub-core/loader/efi/linux.c
|
||||||
@@ -0,0 +1,70 @@
|
@@ -0,0 +1,70 @@
|
||||||
@ -480,7 +479,7 @@ index 000000000..c24202a5d
|
|||||||
+#pragma GCC diagnostic pop
|
+#pragma GCC diagnostic pop
|
||||||
diff --git a/grub-core/loader/i386/efi/linux.c b/grub-core/loader/i386/efi/linux.c
|
diff --git a/grub-core/loader/i386/efi/linux.c b/grub-core/loader/i386/efi/linux.c
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..3db82e782
|
index 0000000000..bb2616a809
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/grub-core/loader/i386/efi/linux.c
|
+++ b/grub-core/loader/i386/efi/linux.c
|
||||||
@@ -0,0 +1,335 @@
|
@@ -0,0 +1,335 @@
|
||||||
@ -589,8 +588,7 @@ index 000000000..3db82e782
|
|||||||
+
|
+
|
||||||
+ for (i = 0; i < argc; i++)
|
+ for (i = 0; i < argc; i++)
|
||||||
+ {
|
+ {
|
||||||
+ grub_file_filter_disable_compression ();
|
+ files[i] = grub_file_open (argv[i], GRUB_FILE_TYPE_LINUX_INITRD | GRUB_FILE_TYPE_NO_DECOMPRESS);
|
||||||
+ files[i] = grub_file_open (argv[i]);
|
|
||||||
+ if (! files[i])
|
+ if (! files[i])
|
||||||
+ goto fail;
|
+ goto fail;
|
||||||
+ nfiles++;
|
+ nfiles++;
|
||||||
@ -643,7 +641,7 @@ index 000000000..3db82e782
|
|||||||
+ int argc, char *argv[])
|
+ int argc, char *argv[])
|
||||||
+{
|
+{
|
||||||
+ grub_file_t file = 0;
|
+ grub_file_t file = 0;
|
||||||
+ struct linux_kernel_header lh;
|
+ struct linux_i386_kernel_header lh;
|
||||||
+ grub_ssize_t len, start, filelen;
|
+ grub_ssize_t len, start, filelen;
|
||||||
+ void *kernel = NULL;
|
+ void *kernel = NULL;
|
||||||
+
|
+
|
||||||
@ -655,7 +653,7 @@ index 000000000..3db82e782
|
|||||||
+ goto fail;
|
+ goto fail;
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ file = grub_file_open (argv[0]);
|
+ file = grub_file_open (argv[0], GRUB_FILE_TYPE_LINUX_KERNEL);
|
||||||
+ if (! file)
|
+ if (! file)
|
||||||
+ goto fail;
|
+ goto fail;
|
||||||
+
|
+
|
||||||
@ -731,7 +729,8 @@ index 000000000..3db82e782
|
|||||||
+ grub_memcpy (linux_cmdline, LINUX_IMAGE, sizeof (LINUX_IMAGE));
|
+ grub_memcpy (linux_cmdline, LINUX_IMAGE, sizeof (LINUX_IMAGE));
|
||||||
+ grub_create_loader_cmdline (argc, argv,
|
+ grub_create_loader_cmdline (argc, argv,
|
||||||
+ linux_cmdline + sizeof (LINUX_IMAGE) - 1,
|
+ linux_cmdline + sizeof (LINUX_IMAGE) - 1,
|
||||||
+ lh.cmdline_size - (sizeof (LINUX_IMAGE) - 1));
|
+ lh.cmdline_size - (sizeof (LINUX_IMAGE) - 1),
|
||||||
|
+ GRUB_VERIFY_KERNEL_CMDLINE);
|
||||||
+
|
+
|
||||||
+ lh.cmd_line_ptr = (grub_uint32_t)(grub_addr_t)linux_cmdline;
|
+ lh.cmd_line_ptr = (grub_uint32_t)(grub_addr_t)linux_cmdline;
|
||||||
+
|
+
|
||||||
@ -820,10 +819,10 @@ index 000000000..3db82e782
|
|||||||
+ grub_unregister_command (cmd_initrdefi);
|
+ grub_unregister_command (cmd_initrdefi);
|
||||||
+}
|
+}
|
||||||
diff --git a/grub-core/loader/i386/pc/linux.c b/grub-core/loader/i386/pc/linux.c
|
diff --git a/grub-core/loader/i386/pc/linux.c b/grub-core/loader/i386/pc/linux.c
|
||||||
index b69cb7a3a..a3c87cf2f 100644
|
index 2a29952016..8be4c3b3f4 100644
|
||||||
--- a/grub-core/loader/i386/pc/linux.c
|
--- a/grub-core/loader/i386/pc/linux.c
|
||||||
+++ b/grub-core/loader/i386/pc/linux.c
|
+++ b/grub-core/loader/i386/pc/linux.c
|
||||||
@@ -468,14 +468,20 @@ grub_cmd_initrd (grub_command_t cmd __attribute__ ((unused)),
|
@@ -474,14 +474,20 @@ grub_cmd_initrd (grub_command_t cmd __attribute__ ((unused)),
|
||||||
return grub_errno;
|
return grub_errno;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -845,7 +844,7 @@ index b69cb7a3a..a3c87cf2f 100644
|
|||||||
grub_register_command ("initrd16", grub_cmd_initrd,
|
grub_register_command ("initrd16", grub_cmd_initrd,
|
||||||
0, N_("Load initrd."));
|
0, N_("Load initrd."));
|
||||||
my_mod = mod;
|
my_mod = mod;
|
||||||
@@ -484,5 +490,7 @@ GRUB_MOD_INIT(linux16)
|
@@ -490,5 +496,7 @@ GRUB_MOD_INIT(linux16)
|
||||||
GRUB_MOD_FINI(linux16)
|
GRUB_MOD_FINI(linux16)
|
||||||
{
|
{
|
||||||
grub_unregister_command (cmd_linux);
|
grub_unregister_command (cmd_linux);
|
||||||
@ -854,7 +853,7 @@ index b69cb7a3a..a3c87cf2f 100644
|
|||||||
+ grub_unregister_command (cmd_initrd16);
|
+ grub_unregister_command (cmd_initrd16);
|
||||||
}
|
}
|
||||||
diff --git a/include/grub/arm/linux.h b/include/grub/arm/linux.h
|
diff --git a/include/grub/arm/linux.h b/include/grub/arm/linux.h
|
||||||
index 712ba17b9..5900fc8a4 100644
|
index bcd5a7eb18..b582f67f66 100644
|
||||||
--- a/include/grub/arm/linux.h
|
--- a/include/grub/arm/linux.h
|
||||||
+++ b/include/grub/arm/linux.h
|
+++ b/include/grub/arm/linux.h
|
||||||
@@ -20,6 +20,7 @@
|
@@ -20,6 +20,7 @@
|
||||||
@ -878,25 +877,24 @@ index 712ba17b9..5900fc8a4 100644
|
|||||||
+
|
+
|
||||||
#if defined(__arm__)
|
#if defined(__arm__)
|
||||||
# define GRUB_LINUX_ARMXX_MAGIC_SIGNATURE GRUB_LINUX_ARM_MAGIC_SIGNATURE
|
# define GRUB_LINUX_ARMXX_MAGIC_SIGNATURE GRUB_LINUX_ARM_MAGIC_SIGNATURE
|
||||||
# define linux_armxx_kernel_header linux_arm_kernel_header
|
# define linux_arch_kernel_header linux_arm_kernel_header
|
||||||
+# define grub_armxx_linux_pe_header grub_arm_linux_pe_header
|
+# define grub_armxx_linux_pe_header grub_arm_linux_pe_header
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined GRUB_MACHINE_UBOOT
|
#if defined GRUB_MACHINE_UBOOT
|
||||||
diff --git a/include/grub/arm64/linux.h b/include/grub/arm64/linux.h
|
diff --git a/include/grub/arm64/linux.h b/include/grub/arm64/linux.h
|
||||||
index 8655067e0..7b533b571 100644
|
index 7e22b4ab69..ea030312df 100644
|
||||||
--- a/include/grub/arm64/linux.h
|
--- a/include/grub/arm64/linux.h
|
||||||
+++ b/include/grub/arm64/linux.h
|
+++ b/include/grub/arm64/linux.h
|
||||||
@@ -19,6 +19,8 @@
|
@@ -19,6 +19,7 @@
|
||||||
#ifndef GRUB_ARM64_LINUX_HEADER
|
#ifndef GRUB_ARM64_LINUX_HEADER
|
||||||
#define GRUB_ARM64_LINUX_HEADER 1
|
#define GRUB_ARM64_LINUX_HEADER 1
|
||||||
|
|
||||||
+#include <grub/efi/pe32.h>
|
+#include <grub/efi/pe32.h>
|
||||||
+
|
#include <grub/types.h>
|
||||||
#define GRUB_LINUX_ARM64_MAGIC_SIGNATURE 0x644d5241 /* 'ARM\x64' */
|
|
||||||
|
|
||||||
/* From linux/Documentation/arm64/booting.txt */
|
#define GRUB_LINUX_ARM64_MAGIC_SIGNATURE 0x644d5241 /* 'ARM\x64' */
|
||||||
@@ -36,9 +38,17 @@ struct linux_arm64_kernel_header
|
@@ -38,9 +39,17 @@ struct linux_arm64_kernel_header
|
||||||
grub_uint32_t hdr_offset; /* Offset of PE/COFF header */
|
grub_uint32_t hdr_offset; /* Offset of PE/COFF header */
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -909,13 +907,13 @@ index 8655067e0..7b533b571 100644
|
|||||||
+
|
+
|
||||||
#if defined(__aarch64__)
|
#if defined(__aarch64__)
|
||||||
# define GRUB_LINUX_ARMXX_MAGIC_SIGNATURE GRUB_LINUX_ARM64_MAGIC_SIGNATURE
|
# define GRUB_LINUX_ARMXX_MAGIC_SIGNATURE GRUB_LINUX_ARM64_MAGIC_SIGNATURE
|
||||||
# define linux_armxx_kernel_header linux_arm64_kernel_header
|
# define linux_arch_kernel_header linux_arm64_kernel_header
|
||||||
+# define grub_armxx_linux_pe_header grub_arm64_linux_pe_header
|
+# define grub_armxx_linux_pe_header grub_arm64_linux_pe_header
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* ! GRUB_ARM64_LINUX_HEADER */
|
#endif /* ! GRUB_ARM64_LINUX_HEADER */
|
||||||
diff --git a/include/grub/efi/efi.h b/include/grub/efi/efi.h
|
diff --git a/include/grub/efi/efi.h b/include/grub/efi/efi.h
|
||||||
index 2c6648d46..1061aee97 100644
|
index 83d958f994..6295df85f3 100644
|
||||||
--- a/include/grub/efi/efi.h
|
--- a/include/grub/efi/efi.h
|
||||||
+++ b/include/grub/efi/efi.h
|
+++ b/include/grub/efi/efi.h
|
||||||
@@ -47,6 +47,9 @@ EXPORT_FUNC(grub_efi_allocate_fixed) (grub_efi_physical_address_t address,
|
@@ -47,6 +47,9 @@ EXPORT_FUNC(grub_efi_allocate_fixed) (grub_efi_physical_address_t address,
|
||||||
@ -928,7 +926,7 @@ index 2c6648d46..1061aee97 100644
|
|||||||
void EXPORT_FUNC(grub_efi_free_pages) (grub_efi_physical_address_t address,
|
void EXPORT_FUNC(grub_efi_free_pages) (grub_efi_physical_address_t address,
|
||||||
grub_efi_uintn_t pages);
|
grub_efi_uintn_t pages);
|
||||||
grub_efi_uintn_t EXPORT_FUNC(grub_efi_find_mmap_size) (void);
|
grub_efi_uintn_t EXPORT_FUNC(grub_efi_find_mmap_size) (void);
|
||||||
@@ -82,6 +85,7 @@ EXPORT_FUNC (grub_efi_set_variable) (const char *var,
|
@@ -88,6 +91,7 @@ EXPORT_FUNC (grub_efi_set_variable) (const char *var,
|
||||||
const grub_efi_guid_t *guid,
|
const grub_efi_guid_t *guid,
|
||||||
void *data,
|
void *data,
|
||||||
grub_size_t datasize);
|
grub_size_t datasize);
|
||||||
@ -936,19 +934,19 @@ index 2c6648d46..1061aee97 100644
|
|||||||
int
|
int
|
||||||
EXPORT_FUNC (grub_efi_compare_device_paths) (const grub_efi_device_path_t *dp1,
|
EXPORT_FUNC (grub_efi_compare_device_paths) (const grub_efi_device_path_t *dp1,
|
||||||
const grub_efi_device_path_t *dp2);
|
const grub_efi_device_path_t *dp2);
|
||||||
@@ -95,8 +99,7 @@ void *EXPORT_FUNC(grub_efi_get_firmware_fdt)(void);
|
@@ -101,8 +105,7 @@ void *EXPORT_FUNC(grub_efi_get_firmware_fdt)(void);
|
||||||
grub_err_t EXPORT_FUNC(grub_efi_get_ram_base)(grub_addr_t *);
|
grub_err_t EXPORT_FUNC(grub_efi_get_ram_base)(grub_addr_t *);
|
||||||
#include <grub/cpu/linux.h>
|
#include <grub/cpu/linux.h>
|
||||||
grub_err_t grub_armxx_efi_linux_check_image(struct linux_armxx_kernel_header *lh);
|
grub_err_t grub_arch_efi_linux_check_image(struct linux_arch_kernel_header *lh);
|
||||||
-grub_err_t grub_armxx_efi_linux_boot_image(grub_addr_t addr, grub_size_t size,
|
-grub_err_t grub_arch_efi_linux_boot_image(grub_addr_t addr, grub_size_t size,
|
||||||
- char *args);
|
- char *args);
|
||||||
+grub_err_t grub_armxx_efi_linux_boot_image(grub_addr_t addr, char *args);
|
+grub_err_t grub_arch_efi_linux_boot_image(grub_addr_t addr, char *args);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
grub_addr_t grub_efi_modules_addr (void);
|
grub_addr_t grub_efi_modules_addr (void);
|
||||||
diff --git a/include/grub/efi/linux.h b/include/grub/efi/linux.h
|
diff --git a/include/grub/efi/linux.h b/include/grub/efi/linux.h
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..d9ede3677
|
index 0000000000..d9ede36773
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/include/grub/efi/linux.h
|
+++ b/include/grub/efi/linux.h
|
||||||
@@ -0,0 +1,31 @@
|
@@ -0,0 +1,31 @@
|
||||||
@ -983,15 +981,3 @@ index 000000000..d9ede3677
|
|||||||
+ void *kernel_param);
|
+ void *kernel_param);
|
||||||
+
|
+
|
||||||
+#endif /* ! GRUB_EFI_LINUX_HEADER */
|
+#endif /* ! GRUB_EFI_LINUX_HEADER */
|
||||||
diff --git a/include/grub/i386/linux.h b/include/grub/i386/linux.h
|
|
||||||
index 60c7c3b5e..bb19dbd5a 100644
|
|
||||||
--- a/include/grub/i386/linux.h
|
|
||||||
+++ b/include/grub/i386/linux.h
|
|
||||||
@@ -142,6 +142,7 @@ struct linux_i386_kernel_header
|
|
||||||
grub_uint64_t setup_data;
|
|
||||||
grub_uint64_t pref_address;
|
|
||||||
grub_uint32_t init_size;
|
|
||||||
+ grub_uint32_t handover_offset;
|
|
||||||
} GRUB_PACKED;
|
|
||||||
|
|
||||||
/* Boot parameters for Linux based on 2.6.12. This is used by the setup
|
|
@ -6,15 +6,17 @@ Subject: [PATCH] Rework linux command
|
|||||||
We want a single buffer that contains the entire kernel image in order to
|
We want a single buffer that contains the entire kernel image in order to
|
||||||
perform a TPM measurement. Allocate one and copy the entire kernel into it
|
perform a TPM measurement. Allocate one and copy the entire kernel into it
|
||||||
before pulling out the individual blocks later on.
|
before pulling out the individual blocks later on.
|
||||||
|
|
||||||
|
Signed-off-by: Matthew Garrett <mjg59@coreos.com>
|
||||||
---
|
---
|
||||||
grub-core/loader/i386/linux.c | 37 ++++++++++++++++++++++++-------------
|
grub-core/loader/i386/linux.c | 35 +++++++++++++++++++++++------------
|
||||||
1 file changed, 24 insertions(+), 13 deletions(-)
|
1 file changed, 23 insertions(+), 12 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/loader/i386/linux.c b/grub-core/loader/i386/linux.c
|
diff --git a/grub-core/loader/i386/linux.c b/grub-core/loader/i386/linux.c
|
||||||
index 9b53d3168..f7186be40 100644
|
index 9f74a96b19..dccf3bb300 100644
|
||||||
--- a/grub-core/loader/i386/linux.c
|
--- a/grub-core/loader/i386/linux.c
|
||||||
+++ b/grub-core/loader/i386/linux.c
|
+++ b/grub-core/loader/i386/linux.c
|
||||||
@@ -685,13 +685,15 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
@@ -649,13 +649,15 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
{
|
{
|
||||||
grub_file_t file = 0;
|
grub_file_t file = 0;
|
||||||
struct linux_i386_kernel_header lh;
|
struct linux_i386_kernel_header lh;
|
||||||
@ -31,7 +33,7 @@ index 9b53d3168..f7186be40 100644
|
|||||||
|
|
||||||
grub_dl_ref (my_mod);
|
grub_dl_ref (my_mod);
|
||||||
|
|
||||||
@@ -705,7 +707,15 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
@@ -669,7 +671,15 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
if (! file)
|
if (! file)
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
@ -48,7 +50,7 @@ index 9b53d3168..f7186be40 100644
|
|||||||
{
|
{
|
||||||
if (!grub_errno)
|
if (!grub_errno)
|
||||||
grub_error (GRUB_ERR_BAD_OS, N_("premature end of file %s"),
|
grub_error (GRUB_ERR_BAD_OS, N_("premature end of file %s"),
|
||||||
@@ -713,6 +723,9 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
@@ -677,6 +687,9 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -58,33 +60,25 @@ index 9b53d3168..f7186be40 100644
|
|||||||
if (lh.boot_flag != grub_cpu_to_le16_compile_time (0xaa55))
|
if (lh.boot_flag != grub_cpu_to_le16_compile_time (0xaa55))
|
||||||
{
|
{
|
||||||
grub_error (GRUB_ERR_BAD_OS, "invalid magic number");
|
grub_error (GRUB_ERR_BAD_OS, "invalid magic number");
|
||||||
@@ -804,6 +817,7 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
@@ -784,13 +797,11 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
preferred_address))
|
/* We've already read lh so there is no need to read it second time. */
|
||||||
goto fail;
|
len -= sizeof(lh);
|
||||||
|
|
||||||
+
|
- if ((len > 0) &&
|
||||||
grub_memset (&linux_params, 0, sizeof (linux_params));
|
- (grub_file_read (file, (char *) &linux_params + sizeof (lh), len) != len))
|
||||||
grub_memcpy (&linux_params.setup_sects, &lh.setup_sects, sizeof (lh) - 0x1F1);
|
+ linux_params_ptr = (void *)&linux_params;
|
||||||
|
+ if (len > 0)
|
||||||
@@ -812,13 +826,10 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
{
|
||||||
linux_params.ps_mouse = linux_params.padding10 = 0;
|
|
||||||
|
|
||||||
len = sizeof (linux_params) - sizeof (lh);
|
|
||||||
- if (grub_file_read (file, (char *) &linux_params + sizeof (lh), len) != len)
|
|
||||||
- {
|
|
||||||
- if (!grub_errno)
|
- if (!grub_errno)
|
||||||
- grub_error (GRUB_ERR_BAD_OS, N_("premature end of file %s"),
|
- grub_error (GRUB_ERR_BAD_OS, N_("premature end of file %s"),
|
||||||
- argv[0]);
|
- argv[0]);
|
||||||
- goto fail;
|
- goto fail;
|
||||||
- }
|
|
||||||
+
|
|
||||||
+ linux_params_ptr = (void *)&linux_params;
|
|
||||||
+ grub_memcpy (linux_params_ptr + sizeof (lh), kernel + kernel_offset, len);
|
+ grub_memcpy (linux_params_ptr + sizeof (lh), kernel + kernel_offset, len);
|
||||||
+ kernel_offset += len;
|
+ kernel_offset += len;
|
||||||
|
}
|
||||||
|
|
||||||
linux_params.type_of_loader = GRUB_LINUX_BOOT_LOADER_TYPE;
|
linux_params.code32_start = prot_mode_target + lh.code32_start - GRUB_LINUX_BZIMAGE_ADDR;
|
||||||
|
@@ -853,7 +864,7 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
@@ -877,7 +888,7 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
|
||||||
|
|
||||||
/* The other parameters are filled when booting. */
|
/* The other parameters are filled when booting. */
|
||||||
|
|
||||||
@ -93,8 +87,8 @@ index 9b53d3168..f7186be40 100644
|
|||||||
|
|
||||||
grub_dprintf ("linux", "bzImage, setup=0x%x, size=0x%x\n",
|
grub_dprintf ("linux", "bzImage, setup=0x%x, size=0x%x\n",
|
||||||
(unsigned) real_size, (unsigned) prot_size);
|
(unsigned) real_size, (unsigned) prot_size);
|
||||||
@@ -1025,9 +1036,7 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
@@ -1007,9 +1018,7 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
- (sizeof (LINUX_IMAGE) - 1));
|
}
|
||||||
|
|
||||||
len = prot_file_size;
|
len = prot_file_size;
|
||||||
- if (grub_file_read (file, prot_mode_mem, len) != len && !grub_errno)
|
- if (grub_file_read (file, prot_mode_mem, len) != len && !grub_errno)
|
||||||
@ -104,7 +98,7 @@ index 9b53d3168..f7186be40 100644
|
|||||||
|
|
||||||
if (grub_errno == GRUB_ERR_NONE)
|
if (grub_errno == GRUB_ERR_NONE)
|
||||||
{
|
{
|
||||||
@@ -1038,6 +1047,8 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
@@ -1020,6 +1029,8 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
|
|
||||||
fail:
|
fail:
|
||||||
|
|
@ -6,15 +6,17 @@ Subject: [PATCH] Rework linux16 command
|
|||||||
We want a single buffer that contains the entire kernel image in order to
|
We want a single buffer that contains the entire kernel image in order to
|
||||||
perform a TPM measurement. Allocate one and copy the entire kernel int it
|
perform a TPM measurement. Allocate one and copy the entire kernel int it
|
||||||
before pulling out the individual blocks later on.
|
before pulling out the individual blocks later on.
|
||||||
|
|
||||||
|
Signed-off-by: Matthew Garrett <mjg59@coreos.com>
|
||||||
---
|
---
|
||||||
grub-core/loader/i386/pc/linux.c | 34 +++++++++++++++++++++-------------
|
grub-core/loader/i386/pc/linux.c | 33 +++++++++++++++++++++------------
|
||||||
1 file changed, 21 insertions(+), 13 deletions(-)
|
1 file changed, 21 insertions(+), 12 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/loader/i386/pc/linux.c b/grub-core/loader/i386/pc/linux.c
|
diff --git a/grub-core/loader/i386/pc/linux.c b/grub-core/loader/i386/pc/linux.c
|
||||||
index a3c87cf2f..caa76bee8 100644
|
index 8be4c3b3f4..4b1750e360 100644
|
||||||
--- a/grub-core/loader/i386/pc/linux.c
|
--- a/grub-core/loader/i386/pc/linux.c
|
||||||
+++ b/grub-core/loader/i386/pc/linux.c
|
+++ b/grub-core/loader/i386/pc/linux.c
|
||||||
@@ -123,13 +123,14 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
@@ -124,13 +124,14 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
grub_file_t file = 0;
|
grub_file_t file = 0;
|
||||||
struct linux_i386_kernel_header lh;
|
struct linux_i386_kernel_header lh;
|
||||||
grub_uint8_t setup_sects;
|
grub_uint8_t setup_sects;
|
||||||
@ -30,7 +32,7 @@ index a3c87cf2f..caa76bee8 100644
|
|||||||
|
|
||||||
grub_dl_ref (my_mod);
|
grub_dl_ref (my_mod);
|
||||||
|
|
||||||
@@ -143,7 +144,15 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
@@ -144,7 +145,15 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
if (! file)
|
if (! file)
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
@ -47,7 +49,7 @@ index a3c87cf2f..caa76bee8 100644
|
|||||||
{
|
{
|
||||||
if (!grub_errno)
|
if (!grub_errno)
|
||||||
grub_error (GRUB_ERR_BAD_OS, N_("premature end of file %s"),
|
grub_error (GRUB_ERR_BAD_OS, N_("premature end of file %s"),
|
||||||
@@ -151,6 +160,9 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
@@ -152,6 +161,9 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -57,7 +59,7 @@ index a3c87cf2f..caa76bee8 100644
|
|||||||
if (lh.boot_flag != grub_cpu_to_le16_compile_time (0xaa55))
|
if (lh.boot_flag != grub_cpu_to_le16_compile_time (0xaa55))
|
||||||
{
|
{
|
||||||
grub_error (GRUB_ERR_BAD_OS, "invalid magic number");
|
grub_error (GRUB_ERR_BAD_OS, "invalid magic number");
|
||||||
@@ -314,13 +326,9 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
@@ -320,13 +332,9 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
grub_memmove (grub_linux_real_chunk, &lh, sizeof (lh));
|
grub_memmove (grub_linux_real_chunk, &lh, sizeof (lh));
|
||||||
|
|
||||||
len = real_size + GRUB_DISK_SECTOR_SIZE - sizeof (lh);
|
len = real_size + GRUB_DISK_SECTOR_SIZE - sizeof (lh);
|
||||||
@ -74,12 +76,11 @@ index a3c87cf2f..caa76bee8 100644
|
|||||||
|
|
||||||
if (lh.header != grub_cpu_to_le32_compile_time (GRUB_LINUX_I386_MAGIC_SIGNATURE)
|
if (lh.header != grub_cpu_to_le32_compile_time (GRUB_LINUX_I386_MAGIC_SIGNATURE)
|
||||||
|| grub_le_to_cpu16 (lh.version) < 0x0200)
|
|| grub_le_to_cpu16 (lh.version) < 0x0200)
|
||||||
@@ -355,10 +363,8 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
@@ -364,9 +372,8 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
}
|
}
|
||||||
|
|
||||||
len = grub_linux16_prot_size;
|
len = grub_linux16_prot_size;
|
||||||
- if (grub_file_read (file, grub_linux_prot_chunk, grub_linux16_prot_size)
|
- if (grub_file_read (file, grub_linux_prot_chunk, len) != len && !grub_errno)
|
||||||
- != (grub_ssize_t) grub_linux16_prot_size && !grub_errno)
|
|
||||||
- grub_error (GRUB_ERR_BAD_OS, N_("premature end of file %s"),
|
- grub_error (GRUB_ERR_BAD_OS, N_("premature end of file %s"),
|
||||||
- argv[0]);
|
- argv[0]);
|
||||||
+ grub_memcpy (grub_linux_prot_chunk, kernel + kernel_offset, len);
|
+ grub_memcpy (grub_linux_prot_chunk, kernel + kernel_offset, len);
|
||||||
@ -87,7 +88,7 @@ index a3c87cf2f..caa76bee8 100644
|
|||||||
|
|
||||||
if (grub_errno == GRUB_ERR_NONE)
|
if (grub_errno == GRUB_ERR_NONE)
|
||||||
{
|
{
|
||||||
@@ -368,6 +374,8 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
@@ -376,6 +383,8 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
|
|
||||||
fail:
|
fail:
|
||||||
|
|
@ -1,6 +1,6 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
From: Raymund Will <rw@suse.com>
|
From: Raymund Will <rw@suse.com>
|
||||||
Date: Fri, 10 Apr 2015 01:45:02 -0400
|
Date: Mon, 8 Jul 2019 11:55:18 +0200
|
||||||
Subject: [PATCH] Add secureboot support on efi chainloader
|
Subject: [PATCH] Add secureboot support on efi chainloader
|
||||||
|
|
||||||
Expand the chainloader to be able to verify the image by means of shim
|
Expand the chainloader to be able to verify the image by means of shim
|
||||||
@ -164,21 +164,36 @@ following branches:
|
|||||||
|
|
||||||
Bugzilla: https://bugzilla.redhat.com/show_bug.cgi?id=1347291
|
Bugzilla: https://bugzilla.redhat.com/show_bug.cgi?id=1347291
|
||||||
Signed-off-by: Laszlo Ersek <lersek@redhat.com>
|
Signed-off-by: Laszlo Ersek <lersek@redhat.com>
|
||||||
|
|
||||||
|
Also:
|
||||||
|
|
||||||
|
commit cc06f149fbd2d8c1da1e83173d21629ba97e0d92
|
||||||
|
Author: Raymund Will <rw@suse.com>
|
||||||
|
|
||||||
|
chainloader: Define machine types for RISC-V
|
||||||
|
|
||||||
|
The commit "Add secureboot support on efi chainloader" didn't add machine
|
||||||
|
types for RISC-V, so this patch adds them.
|
||||||
|
|
||||||
|
Note, that grub-core/loader/riscv/linux.c is skipped because Linux is not
|
||||||
|
supported yet. This patch might need a new revision once that's the case.
|
||||||
|
|
||||||
|
Signed-off-by: David Abdurachmanov <david.abdurachmanov@sifive.com>
|
||||||
---
|
---
|
||||||
grub-core/kern/efi/efi.c | 14 +-
|
grub-core/kern/efi/efi.c | 14 +-
|
||||||
grub-core/loader/arm64/linux.c | 4 +-
|
grub-core/loader/arm64/linux.c | 4 +-
|
||||||
grub-core/loader/efi/chainloader.c | 817 +++++++++++++++++++++++++++++++++----
|
grub-core/loader/efi/chainloader.c | 820 +++++++++++++++++++++++++++++++++----
|
||||||
grub-core/loader/efi/linux.c | 25 +-
|
grub-core/loader/efi/linux.c | 25 +-
|
||||||
grub-core/loader/i386/efi/linux.c | 17 +-
|
grub-core/loader/i386/efi/linux.c | 17 +-
|
||||||
include/grub/efi/linux.h | 2 +-
|
include/grub/efi/linux.h | 2 +-
|
||||||
include/grub/efi/pe32.h | 52 ++-
|
include/grub/efi/pe32.h | 52 ++-
|
||||||
7 files changed, 840 insertions(+), 91 deletions(-)
|
7 files changed, 844 insertions(+), 90 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/kern/efi/efi.c b/grub-core/kern/efi/efi.c
|
diff --git a/grub-core/kern/efi/efi.c b/grub-core/kern/efi/efi.c
|
||||||
index c8a9d8307..91129e335 100644
|
index 35b8f67060..4a2259aa1c 100644
|
||||||
--- a/grub-core/kern/efi/efi.c
|
--- a/grub-core/kern/efi/efi.c
|
||||||
+++ b/grub-core/kern/efi/efi.c
|
+++ b/grub-core/kern/efi/efi.c
|
||||||
@@ -283,14 +283,20 @@ grub_efi_secure_boot (void)
|
@@ -296,14 +296,20 @@ grub_efi_secure_boot (void)
|
||||||
grub_efi_boolean_t ret = 0;
|
grub_efi_boolean_t ret = 0;
|
||||||
|
|
||||||
secure_boot = grub_efi_get_variable("SecureBoot", &efi_var_guid, &datasize);
|
secure_boot = grub_efi_get_variable("SecureBoot", &efi_var_guid, &datasize);
|
||||||
@ -204,18 +219,18 @@ index c8a9d8307..91129e335 100644
|
|||||||
if (*secure_boot && !*setup_mode)
|
if (*secure_boot && !*setup_mode)
|
||||||
ret = 1;
|
ret = 1;
|
||||||
diff --git a/grub-core/loader/arm64/linux.c b/grub-core/loader/arm64/linux.c
|
diff --git a/grub-core/loader/arm64/linux.c b/grub-core/loader/arm64/linux.c
|
||||||
index 6c00af98d..a1ac7a388 100644
|
index a312c66868..04994d5c67 100644
|
||||||
--- a/grub-core/loader/arm64/linux.c
|
--- a/grub-core/loader/arm64/linux.c
|
||||||
+++ b/grub-core/loader/arm64/linux.c
|
+++ b/grub-core/loader/arm64/linux.c
|
||||||
@@ -282,6 +282,7 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
@@ -284,6 +284,7 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
grub_file_t file = 0;
|
struct linux_arch_kernel_header lh;
|
||||||
struct linux_armxx_kernel_header lh;
|
|
||||||
struct grub_armxx_linux_pe_header *pe;
|
struct grub_armxx_linux_pe_header *pe;
|
||||||
|
grub_err_t err;
|
||||||
+ int rc;
|
+ int rc;
|
||||||
|
|
||||||
grub_dl_ref (my_mod);
|
grub_dl_ref (my_mod);
|
||||||
|
|
||||||
@@ -326,7 +327,8 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
@@ -328,7 +329,8 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
|
|
||||||
grub_dprintf ("linux", "kernel @ %p\n", kernel_addr);
|
grub_dprintf ("linux", "kernel @ %p\n", kernel_addr);
|
||||||
|
|
||||||
@ -226,7 +241,7 @@ index 6c00af98d..a1ac7a388 100644
|
|||||||
grub_error (GRUB_ERR_INVALID_COMMAND, N_("%s has invalid signature"), argv[0]);
|
grub_error (GRUB_ERR_INVALID_COMMAND, N_("%s has invalid signature"), argv[0]);
|
||||||
goto fail;
|
goto fail;
|
||||||
diff --git a/grub-core/loader/efi/chainloader.c b/grub-core/loader/efi/chainloader.c
|
diff --git a/grub-core/loader/efi/chainloader.c b/grub-core/loader/efi/chainloader.c
|
||||||
index adc856366..af2189619 100644
|
index 2bd80f4db3..e6a8d4ad0e 100644
|
||||||
--- a/grub-core/loader/efi/chainloader.c
|
--- a/grub-core/loader/efi/chainloader.c
|
||||||
+++ b/grub-core/loader/efi/chainloader.c
|
+++ b/grub-core/loader/efi/chainloader.c
|
||||||
@@ -32,6 +32,8 @@
|
@@ -32,6 +32,8 @@
|
||||||
@ -261,15 +276,7 @@ index adc856366..af2189619 100644
|
|||||||
|
|
||||||
grub_dl_unref (my_mod);
|
grub_dl_unref (my_mod);
|
||||||
return GRUB_ERR_NONE;
|
return GRUB_ERR_NONE;
|
||||||
@@ -173,7 +181,6 @@ make_file_path (grub_efi_device_path_t *dp, const char *filename)
|
@@ -213,20 +221,694 @@ make_file_path (grub_efi_device_path_t *dp, const char *filename)
|
||||||
/* Fill the file path for the directory. */
|
|
||||||
d = (grub_efi_device_path_t *) ((char *) file_path
|
|
||||||
+ ((char *) d - (char *) dp));
|
|
||||||
- grub_efi_print_device_path (d);
|
|
||||||
copy_file_path ((grub_efi_file_path_device_path_t *) d,
|
|
||||||
dir_start, dir_end - dir_start);
|
|
||||||
|
|
||||||
@@ -191,20 +198,690 @@ make_file_path (grub_efi_device_path_t *dp, const char *filename)
|
|
||||||
return file_path;
|
return file_path;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -384,6 +391,10 @@ index adc856366..af2189619 100644
|
|||||||
+ GRUB_PE32_MACHINE_I386;
|
+ GRUB_PE32_MACHINE_I386;
|
||||||
+#elif defined(__ia64__)
|
+#elif defined(__ia64__)
|
||||||
+ GRUB_PE32_MACHINE_IA64;
|
+ GRUB_PE32_MACHINE_IA64;
|
||||||
|
+#elif defined(__riscv) && (__riscv_xlen == 32)
|
||||||
|
+ GRUB_PE32_MACHINE_RISCV32;
|
||||||
|
+#elif defined(__riscv) && (__riscv_xlen == 64)
|
||||||
|
+ GRUB_PE32_MACHINE_RISCV64;
|
||||||
+#else
|
+#else
|
||||||
+#error this architecture is not supported by grub2
|
+#error this architecture is not supported by grub2
|
||||||
+#endif
|
+#endif
|
||||||
@ -963,7 +974,7 @@ index adc856366..af2189619 100644
|
|||||||
|
|
||||||
if (argc == 0)
|
if (argc == 0)
|
||||||
return grub_error (GRUB_ERR_BAD_ARGUMENT, N_("filename expected"));
|
return grub_error (GRUB_ERR_BAD_ARGUMENT, N_("filename expected"));
|
||||||
@@ -216,15 +893,45 @@ grub_cmd_chainloader (grub_command_t cmd __attribute__ ((unused)),
|
@@ -238,15 +920,45 @@ grub_cmd_chainloader (grub_command_t cmd __attribute__ ((unused)),
|
||||||
address = 0;
|
address = 0;
|
||||||
image_handle = 0;
|
image_handle = 0;
|
||||||
file_path = 0;
|
file_path = 0;
|
||||||
@ -997,7 +1008,7 @@ index adc856366..af2189619 100644
|
|||||||
+ *(--p16) = 0;
|
+ *(--p16) = 0;
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
file = grub_file_open (filename);
|
file = grub_file_open (filename, GRUB_FILE_TYPE_EFI_CHAINLOADED_IMAGE);
|
||||||
if (! file)
|
if (! file)
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
@ -1011,7 +1022,7 @@ index adc856366..af2189619 100644
|
|||||||
if (! dev)
|
if (! dev)
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
@@ -261,17 +968,14 @@ grub_cmd_chainloader (grub_command_t cmd __attribute__ ((unused)),
|
@@ -283,17 +995,14 @@ grub_cmd_chainloader (grub_command_t cmd __attribute__ ((unused)),
|
||||||
if (! file_path)
|
if (! file_path)
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
@ -1032,7 +1043,7 @@ index adc856366..af2189619 100644
|
|||||||
|
|
||||||
status = efi_call_4 (b->allocate_pages, GRUB_EFI_ALLOCATE_ANY_PAGES,
|
status = efi_call_4 (b->allocate_pages, GRUB_EFI_ALLOCATE_ANY_PAGES,
|
||||||
GRUB_EFI_LOADER_CODE,
|
GRUB_EFI_LOADER_CODE,
|
||||||
@@ -285,7 +989,7 @@ grub_cmd_chainloader (grub_command_t cmd __attribute__ ((unused)),
|
@@ -307,7 +1016,7 @@ grub_cmd_chainloader (grub_command_t cmd __attribute__ ((unused)),
|
||||||
}
|
}
|
||||||
|
|
||||||
boot_image = (void *) ((grub_addr_t) address);
|
boot_image = (void *) ((grub_addr_t) address);
|
||||||
@ -1041,7 +1052,7 @@ index adc856366..af2189619 100644
|
|||||||
{
|
{
|
||||||
if (grub_errno == GRUB_ERR_NONE)
|
if (grub_errno == GRUB_ERR_NONE)
|
||||||
grub_error (GRUB_ERR_BAD_OS, N_("premature end of file %s"),
|
grub_error (GRUB_ERR_BAD_OS, N_("premature end of file %s"),
|
||||||
@@ -295,7 +999,7 @@ grub_cmd_chainloader (grub_command_t cmd __attribute__ ((unused)),
|
@@ -317,7 +1026,7 @@ grub_cmd_chainloader (grub_command_t cmd __attribute__ ((unused)),
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined (__i386__) || defined (__x86_64__)
|
#if defined (__i386__) || defined (__x86_64__)
|
||||||
@ -1050,12 +1061,12 @@ index adc856366..af2189619 100644
|
|||||||
{
|
{
|
||||||
struct grub_macho_fat_header *head = boot_image;
|
struct grub_macho_fat_header *head = boot_image;
|
||||||
if (head->magic
|
if (head->magic
|
||||||
@@ -304,6 +1008,14 @@ grub_cmd_chainloader (grub_command_t cmd __attribute__ ((unused)),
|
@@ -326,6 +1035,14 @@ grub_cmd_chainloader (grub_command_t cmd __attribute__ ((unused)),
|
||||||
grub_uint32_t i;
|
grub_uint32_t i;
|
||||||
struct grub_macho_fat_arch *archs
|
struct grub_macho_fat_arch *archs
|
||||||
= (struct grub_macho_fat_arch *) (head + 1);
|
= (struct grub_macho_fat_arch *) (head + 1);
|
||||||
+
|
+
|
||||||
+ if (grub_efi_secure_boot())
|
+ if (grub_efi_get_secureboot () == GRUB_EFI_SECUREBOOT_MODE_ENABLED)
|
||||||
+ {
|
+ {
|
||||||
+ grub_error (GRUB_ERR_BAD_OS,
|
+ grub_error (GRUB_ERR_BAD_OS,
|
||||||
+ "MACHO binaries are forbidden with Secure Boot");
|
+ "MACHO binaries are forbidden with Secure Boot");
|
||||||
@ -1065,7 +1076,7 @@ index adc856366..af2189619 100644
|
|||||||
for (i = 0; i < grub_cpu_to_le32 (head->nfat_arch); i++)
|
for (i = 0; i < grub_cpu_to_le32 (head->nfat_arch); i++)
|
||||||
{
|
{
|
||||||
if (GRUB_MACHO_CPUTYPE_IS_HOST_CURRENT (archs[i].cputype))
|
if (GRUB_MACHO_CPUTYPE_IS_HOST_CURRENT (archs[i].cputype))
|
||||||
@@ -318,79 +1030,39 @@ grub_cmd_chainloader (grub_command_t cmd __attribute__ ((unused)),
|
@@ -340,79 +1057,39 @@ grub_cmd_chainloader (grub_command_t cmd __attribute__ ((unused)),
|
||||||
> ~grub_cpu_to_le32 (archs[i].size)
|
> ~grub_cpu_to_le32 (archs[i].size)
|
||||||
|| grub_cpu_to_le32 (archs[i].offset)
|
|| grub_cpu_to_le32 (archs[i].offset)
|
||||||
+ grub_cpu_to_le32 (archs[i].size)
|
+ grub_cpu_to_le32 (archs[i].size)
|
||||||
@ -1162,7 +1173,7 @@ index adc856366..af2189619 100644
|
|||||||
if (dev)
|
if (dev)
|
||||||
grub_device_close (dev);
|
grub_device_close (dev);
|
||||||
|
|
||||||
@@ -402,6 +1074,9 @@ grub_cmd_chainloader (grub_command_t cmd __attribute__ ((unused)),
|
@@ -424,6 +1101,9 @@ grub_cmd_chainloader (grub_command_t cmd __attribute__ ((unused)),
|
||||||
if (address)
|
if (address)
|
||||||
efi_call_2 (b->free_pages, address, pages);
|
efi_call_2 (b->free_pages, address, pages);
|
||||||
|
|
||||||
@ -1173,7 +1184,7 @@ index adc856366..af2189619 100644
|
|||||||
|
|
||||||
return grub_errno;
|
return grub_errno;
|
||||||
diff --git a/grub-core/loader/efi/linux.c b/grub-core/loader/efi/linux.c
|
diff --git a/grub-core/loader/efi/linux.c b/grub-core/loader/efi/linux.c
|
||||||
index c24202a5d..c8ecce6df 100644
|
index c24202a5dd..c8ecce6dfd 100644
|
||||||
--- a/grub-core/loader/efi/linux.c
|
--- a/grub-core/loader/efi/linux.c
|
||||||
+++ b/grub-core/loader/efi/linux.c
|
+++ b/grub-core/loader/efi/linux.c
|
||||||
@@ -33,21 +33,34 @@ struct grub_efi_shim_lock
|
@@ -33,21 +33,34 @@ struct grub_efi_shim_lock
|
||||||
@ -1218,10 +1229,10 @@ index c24202a5d..c8ecce6df 100644
|
|||||||
|
|
||||||
#pragma GCC diagnostic push
|
#pragma GCC diagnostic push
|
||||||
diff --git a/grub-core/loader/i386/efi/linux.c b/grub-core/loader/i386/efi/linux.c
|
diff --git a/grub-core/loader/i386/efi/linux.c b/grub-core/loader/i386/efi/linux.c
|
||||||
index 3db82e782..8db228c5b 100644
|
index bb2616a809..6b24cbb948 100644
|
||||||
--- a/grub-core/loader/i386/efi/linux.c
|
--- a/grub-core/loader/i386/efi/linux.c
|
||||||
+++ b/grub-core/loader/i386/efi/linux.c
|
+++ b/grub-core/loader/i386/efi/linux.c
|
||||||
@@ -118,6 +118,8 @@ grub_cmd_initrd (grub_command_t cmd __attribute__ ((unused)),
|
@@ -117,6 +117,8 @@ grub_cmd_initrd (grub_command_t cmd __attribute__ ((unused)),
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1230,15 +1241,15 @@ index 3db82e782..8db228c5b 100644
|
|||||||
params->ramdisk_size = size;
|
params->ramdisk_size = size;
|
||||||
params->ramdisk_image = (grub_uint32_t)(grub_addr_t) initrd_mem;
|
params->ramdisk_image = (grub_uint32_t)(grub_addr_t) initrd_mem;
|
||||||
|
|
||||||
@@ -160,6 +162,7 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
@@ -159,6 +161,7 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
struct linux_kernel_header lh;
|
struct linux_i386_kernel_header lh;
|
||||||
grub_ssize_t len, start, filelen;
|
grub_ssize_t len, start, filelen;
|
||||||
void *kernel = NULL;
|
void *kernel = NULL;
|
||||||
+ int rc;
|
+ int rc;
|
||||||
|
|
||||||
grub_dl_ref (my_mod);
|
grub_dl_ref (my_mod);
|
||||||
|
|
||||||
@@ -185,11 +188,13 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
@@ -184,11 +187,13 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
|
|
||||||
if (grub_file_read (file, kernel, filelen) != filelen)
|
if (grub_file_read (file, kernel, filelen) != filelen)
|
||||||
{
|
{
|
||||||
@ -1254,7 +1265,7 @@ index 3db82e782..8db228c5b 100644
|
|||||||
{
|
{
|
||||||
grub_error (GRUB_ERR_INVALID_COMMAND, N_("%s has invalid signature"),
|
grub_error (GRUB_ERR_INVALID_COMMAND, N_("%s has invalid signature"),
|
||||||
argv[0]);
|
argv[0]);
|
||||||
@@ -204,6 +209,8 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
@@ -203,6 +208,8 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1263,7 +1274,7 @@ index 3db82e782..8db228c5b 100644
|
|||||||
grub_memset (params, 0, 16384);
|
grub_memset (params, 0, 16384);
|
||||||
|
|
||||||
grub_memcpy (&lh, kernel, sizeof (lh));
|
grub_memcpy (&lh, kernel, sizeof (lh));
|
||||||
@@ -242,6 +249,9 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
@@ -241,6 +248,9 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1286,7 +1297,7 @@ index 3db82e782..8db228c5b 100644
|
|||||||
grub_file_close (file);
|
grub_file_close (file);
|
||||||
|
|
||||||
diff --git a/include/grub/efi/linux.h b/include/grub/efi/linux.h
|
diff --git a/include/grub/efi/linux.h b/include/grub/efi/linux.h
|
||||||
index d9ede3677..0033d9305 100644
|
index d9ede36773..0033d9305a 100644
|
||||||
--- a/include/grub/efi/linux.h
|
--- a/include/grub/efi/linux.h
|
||||||
+++ b/include/grub/efi/linux.h
|
+++ b/include/grub/efi/linux.h
|
||||||
@@ -22,7 +22,7 @@
|
@@ -22,7 +22,7 @@
|
||||||
@ -1299,10 +1310,10 @@ index d9ede3677..0033d9305 100644
|
|||||||
grub_err_t
|
grub_err_t
|
||||||
EXPORT_FUNC(grub_efi_linux_boot) (void *kernel_address, grub_off_t offset,
|
EXPORT_FUNC(grub_efi_linux_boot) (void *kernel_address, grub_off_t offset,
|
||||||
diff --git a/include/grub/efi/pe32.h b/include/grub/efi/pe32.h
|
diff --git a/include/grub/efi/pe32.h b/include/grub/efi/pe32.h
|
||||||
index 7d44732d2..c03cc599f 100644
|
index 0ed8781f03..a43adf2746 100644
|
||||||
--- a/include/grub/efi/pe32.h
|
--- a/include/grub/efi/pe32.h
|
||||||
+++ b/include/grub/efi/pe32.h
|
+++ b/include/grub/efi/pe32.h
|
||||||
@@ -214,7 +214,11 @@ struct grub_pe64_optional_header
|
@@ -223,7 +223,11 @@ struct grub_pe64_optional_header
|
||||||
struct grub_pe32_section_table
|
struct grub_pe32_section_table
|
||||||
{
|
{
|
||||||
char name[8];
|
char name[8];
|
||||||
@ -1315,7 +1326,7 @@ index 7d44732d2..c03cc599f 100644
|
|||||||
grub_uint32_t virtual_address;
|
grub_uint32_t virtual_address;
|
||||||
grub_uint32_t raw_data_size;
|
grub_uint32_t raw_data_size;
|
||||||
grub_uint32_t raw_data_offset;
|
grub_uint32_t raw_data_offset;
|
||||||
@@ -225,12 +229,18 @@ struct grub_pe32_section_table
|
@@ -234,12 +238,18 @@ struct grub_pe32_section_table
|
||||||
grub_uint32_t characteristics;
|
grub_uint32_t characteristics;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -1338,7 +1349,7 @@ index 7d44732d2..c03cc599f 100644
|
|||||||
|
|
||||||
#define GRUB_PE32_SCN_ALIGN_1BYTES 0x00100000
|
#define GRUB_PE32_SCN_ALIGN_1BYTES 0x00100000
|
||||||
#define GRUB_PE32_SCN_ALIGN_2BYTES 0x00200000
|
#define GRUB_PE32_SCN_ALIGN_2BYTES 0x00200000
|
||||||
@@ -239,10 +249,28 @@ struct grub_pe32_section_table
|
@@ -248,10 +258,28 @@ struct grub_pe32_section_table
|
||||||
#define GRUB_PE32_SCN_ALIGN_16BYTES 0x00500000
|
#define GRUB_PE32_SCN_ALIGN_16BYTES 0x00500000
|
||||||
#define GRUB_PE32_SCN_ALIGN_32BYTES 0x00600000
|
#define GRUB_PE32_SCN_ALIGN_32BYTES 0x00600000
|
||||||
#define GRUB_PE32_SCN_ALIGN_64BYTES 0x00700000
|
#define GRUB_PE32_SCN_ALIGN_64BYTES 0x00700000
|
||||||
@ -1367,7 +1378,7 @@ index 7d44732d2..c03cc599f 100644
|
|||||||
#define GRUB_PE32_SIGNATURE_SIZE 4
|
#define GRUB_PE32_SIGNATURE_SIZE 4
|
||||||
|
|
||||||
struct grub_pe32_header
|
struct grub_pe32_header
|
||||||
@@ -265,6 +293,20 @@ struct grub_pe32_header
|
@@ -274,6 +302,20 @@ struct grub_pe32_header
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
@ -9,112 +9,94 @@ won't register commands if SB is enabled."
|
|||||||
|
|
||||||
Signed-off-by: Peter Jones <pjones@redhat.com>
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
---
|
---
|
||||||
grub-core/Makefile.core.def | 1 +
|
grub-core/commands/iorw.c | 7 +++++++
|
||||||
grub-core/commands/iorw.c | 7 +++++
|
grub-core/commands/memrw.c | 7 +++++++
|
||||||
grub-core/commands/memrw.c | 7 +++++
|
grub-core/kern/dl.c | 3 ++-
|
||||||
grub-core/kern/dl.c | 1 +
|
grub-core/kern/efi/efi.c | 34 ----------------------------------
|
||||||
grub-core/kern/efi/efi.c | 34 --------------------
|
grub-core/loader/efi/appleloader.c | 7 +++++++
|
||||||
grub-core/kern/efi/sb.c | 64 ++++++++++++++++++++++++++++++++++++++
|
|
||||||
grub-core/loader/efi/appleloader.c | 7 +++++
|
|
||||||
grub-core/loader/efi/chainloader.c | 1 +
|
grub-core/loader/efi/chainloader.c | 1 +
|
||||||
grub-core/loader/i386/bsd.c | 7 +++++
|
grub-core/loader/i386/bsd.c | 7 +++++++
|
||||||
grub-core/loader/i386/linux.c | 7 +++++
|
grub-core/loader/i386/linux.c | 7 +++++++
|
||||||
grub-core/loader/i386/pc/linux.c | 7 +++++
|
grub-core/loader/i386/pc/linux.c | 7 +++++++
|
||||||
grub-core/loader/multiboot.c | 7 +++++
|
grub-core/loader/multiboot.c | 7 +++++++
|
||||||
grub-core/loader/xnu.c | 7 +++++
|
grub-core/loader/xnu.c | 7 +++++++
|
||||||
include/grub/efi/efi.h | 1 -
|
include/grub/efi/efi.h | 1 -
|
||||||
include/grub/efi/sb.h | 29 +++++++++++++++++
|
|
||||||
include/grub/ia64/linux.h | 0
|
include/grub/ia64/linux.h | 0
|
||||||
include/grub/mips/linux.h | 0
|
include/grub/mips/linux.h | 0
|
||||||
include/grub/powerpc/linux.h | 0
|
include/grub/powerpc/linux.h | 0
|
||||||
include/grub/sparc64/linux.h | 0
|
include/grub/sparc64/linux.h | 0
|
||||||
grub-core/Makefile.am | 1 +
|
16 files changed, 59 insertions(+), 36 deletions(-)
|
||||||
20 files changed, 153 insertions(+), 35 deletions(-)
|
|
||||||
create mode 100644 grub-core/kern/efi/sb.c
|
|
||||||
create mode 100644 include/grub/efi/sb.h
|
|
||||||
create mode 100644 include/grub/ia64/linux.h
|
create mode 100644 include/grub/ia64/linux.h
|
||||||
create mode 100644 include/grub/mips/linux.h
|
create mode 100644 include/grub/mips/linux.h
|
||||||
create mode 100644 include/grub/powerpc/linux.h
|
create mode 100644 include/grub/powerpc/linux.h
|
||||||
create mode 100644 include/grub/sparc64/linux.h
|
create mode 100644 include/grub/sparc64/linux.h
|
||||||
|
|
||||||
diff --git a/grub-core/Makefile.core.def b/grub-core/Makefile.core.def
|
|
||||||
index 0b4b0c212..e92a7ef32 100644
|
|
||||||
--- a/grub-core/Makefile.core.def
|
|
||||||
+++ b/grub-core/Makefile.core.def
|
|
||||||
@@ -195,6 +195,7 @@ kernel = {
|
|
||||||
i386_multiboot = kern/i386/pc/acpi.c;
|
|
||||||
i386_coreboot = kern/acpi.c;
|
|
||||||
i386_multiboot = kern/acpi.c;
|
|
||||||
+ common = kern/efi/sb.c;
|
|
||||||
|
|
||||||
x86 = kern/i386/tsc.c;
|
|
||||||
x86 = kern/i386/tsc_pit.c;
|
|
||||||
diff --git a/grub-core/commands/iorw.c b/grub-core/commands/iorw.c
|
diff --git a/grub-core/commands/iorw.c b/grub-core/commands/iorw.c
|
||||||
index a0c164e54..41a7f3f04 100644
|
index 584baec8f9..7b2999b14b 100644
|
||||||
--- a/grub-core/commands/iorw.c
|
--- a/grub-core/commands/iorw.c
|
||||||
+++ b/grub-core/commands/iorw.c
|
+++ b/grub-core/commands/iorw.c
|
||||||
@@ -23,6 +23,7 @@
|
@@ -24,6 +24,7 @@
|
||||||
#include <grub/env.h>
|
|
||||||
#include <grub/cpu/io.h>
|
#include <grub/cpu/io.h>
|
||||||
#include <grub/i18n.h>
|
#include <grub/i18n.h>
|
||||||
|
#include <grub/lockdown.h>
|
||||||
+#include <grub/efi/sb.h>
|
+#include <grub/efi/sb.h>
|
||||||
|
|
||||||
GRUB_MOD_LICENSE ("GPLv3+");
|
GRUB_MOD_LICENSE ("GPLv3+");
|
||||||
|
|
||||||
@@ -118,6 +119,9 @@ grub_cmd_write (grub_command_t cmd, int argc, char **argv)
|
@@ -119,6 +120,9 @@ grub_cmd_write (grub_command_t cmd, int argc, char **argv)
|
||||||
|
|
||||||
GRUB_MOD_INIT(memrw)
|
GRUB_MOD_INIT(memrw)
|
||||||
{
|
{
|
||||||
+ if (grub_efi_secure_boot())
|
+ if (grub_efi_get_secureboot () == GRUB_EFI_SECUREBOOT_MODE_ENABLED)
|
||||||
+ return;
|
+ return;
|
||||||
+
|
+
|
||||||
cmd_read_byte =
|
cmd_read_byte =
|
||||||
grub_register_extcmd ("inb", grub_cmd_read, 0,
|
grub_register_extcmd ("inb", grub_cmd_read, 0,
|
||||||
N_("PORT"), N_("Read 8-bit value from PORT."),
|
N_("PORT"), N_("Read 8-bit value from PORT."),
|
||||||
@@ -146,6 +150,9 @@ GRUB_MOD_INIT(memrw)
|
@@ -147,6 +151,9 @@ GRUB_MOD_INIT(memrw)
|
||||||
|
|
||||||
GRUB_MOD_FINI(memrw)
|
GRUB_MOD_FINI(memrw)
|
||||||
{
|
{
|
||||||
+ if (grub_efi_secure_boot())
|
+ if (grub_efi_get_secureboot () == GRUB_EFI_SECUREBOOT_MODE_ENABLED)
|
||||||
+ return;
|
+ return;
|
||||||
+
|
+
|
||||||
grub_unregister_extcmd (cmd_read_byte);
|
grub_unregister_extcmd (cmd_read_byte);
|
||||||
grub_unregister_extcmd (cmd_read_word);
|
grub_unregister_extcmd (cmd_read_word);
|
||||||
grub_unregister_extcmd (cmd_read_dword);
|
grub_unregister_extcmd (cmd_read_dword);
|
||||||
diff --git a/grub-core/commands/memrw.c b/grub-core/commands/memrw.c
|
diff --git a/grub-core/commands/memrw.c b/grub-core/commands/memrw.c
|
||||||
index 98769eadb..088cbe9e2 100644
|
index d401a6db0e..39cf3a06db 100644
|
||||||
--- a/grub-core/commands/memrw.c
|
--- a/grub-core/commands/memrw.c
|
||||||
+++ b/grub-core/commands/memrw.c
|
+++ b/grub-core/commands/memrw.c
|
||||||
@@ -22,6 +22,7 @@
|
@@ -23,6 +23,7 @@
|
||||||
#include <grub/extcmd.h>
|
|
||||||
#include <grub/env.h>
|
#include <grub/env.h>
|
||||||
#include <grub/i18n.h>
|
#include <grub/i18n.h>
|
||||||
|
#include <grub/lockdown.h>
|
||||||
+#include <grub/efi/sb.h>
|
+#include <grub/efi/sb.h>
|
||||||
|
|
||||||
GRUB_MOD_LICENSE ("GPLv3+");
|
GRUB_MOD_LICENSE ("GPLv3+");
|
||||||
|
|
||||||
@@ -120,6 +121,9 @@ grub_cmd_write (grub_command_t cmd, int argc, char **argv)
|
@@ -121,6 +122,9 @@ grub_cmd_write (grub_command_t cmd, int argc, char **argv)
|
||||||
|
|
||||||
GRUB_MOD_INIT(memrw)
|
GRUB_MOD_INIT(memrw)
|
||||||
{
|
{
|
||||||
+ if (grub_efi_secure_boot())
|
+ if (grub_efi_get_secureboot () == GRUB_EFI_SECUREBOOT_MODE_ENABLED)
|
||||||
+ return;
|
+ return;
|
||||||
+
|
+
|
||||||
cmd_read_byte =
|
cmd_read_byte =
|
||||||
grub_register_extcmd ("read_byte", grub_cmd_read, 0,
|
grub_register_extcmd ("read_byte", grub_cmd_read, 0,
|
||||||
N_("ADDR"), N_("Read 8-bit value from ADDR."),
|
N_("ADDR"), N_("Read 8-bit value from ADDR."),
|
||||||
@@ -148,6 +152,9 @@ GRUB_MOD_INIT(memrw)
|
@@ -149,6 +153,9 @@ GRUB_MOD_INIT(memrw)
|
||||||
|
|
||||||
GRUB_MOD_FINI(memrw)
|
GRUB_MOD_FINI(memrw)
|
||||||
{
|
{
|
||||||
+ if (grub_efi_secure_boot())
|
+ if (grub_efi_get_secureboot () == GRUB_EFI_SECUREBOOT_MODE_ENABLED)
|
||||||
+ return;
|
+ return;
|
||||||
+
|
+
|
||||||
grub_unregister_extcmd (cmd_read_byte);
|
grub_unregister_extcmd (cmd_read_byte);
|
||||||
grub_unregister_extcmd (cmd_read_word);
|
grub_unregister_extcmd (cmd_read_word);
|
||||||
grub_unregister_extcmd (cmd_read_dword);
|
grub_unregister_extcmd (cmd_read_dword);
|
||||||
diff --git a/grub-core/kern/dl.c b/grub-core/kern/dl.c
|
diff --git a/grub-core/kern/dl.c b/grub-core/kern/dl.c
|
||||||
index 04e804d16..621070918 100644
|
index b714937095..7afb9e6f72 100644
|
||||||
--- a/grub-core/kern/dl.c
|
--- a/grub-core/kern/dl.c
|
||||||
+++ b/grub-core/kern/dl.c
|
+++ b/grub-core/kern/dl.c
|
||||||
@@ -32,6 +32,7 @@
|
@@ -32,6 +32,7 @@
|
||||||
@ -125,12 +107,21 @@ index 04e804d16..621070918 100644
|
|||||||
|
|
||||||
/* Platforms where modules are in a readonly area of memory. */
|
/* Platforms where modules are in a readonly area of memory. */
|
||||||
#if defined(GRUB_MACHINE_QEMU)
|
#if defined(GRUB_MACHINE_QEMU)
|
||||||
|
@@ -704,7 +705,7 @@ grub_dl_load_file (const char *filename)
|
||||||
|
grub_dl_t mod = 0;
|
||||||
|
|
||||||
|
#ifdef GRUB_MACHINE_EFI
|
||||||
|
- if (grub_efi_secure_boot ())
|
||||||
|
+ if (grub_efi_get_secureboot () == GRUB_EFI_SECUREBOOT_MODE_ENABLED)
|
||||||
|
{
|
||||||
|
#if 0
|
||||||
|
/* This is an error, but grub2-mkconfig still generates a pile of
|
||||||
diff --git a/grub-core/kern/efi/efi.c b/grub-core/kern/efi/efi.c
|
diff --git a/grub-core/kern/efi/efi.c b/grub-core/kern/efi/efi.c
|
||||||
index 91129e335..708581fcb 100644
|
index 4a2259aa1c..8cff7be028 100644
|
||||||
--- a/grub-core/kern/efi/efi.c
|
--- a/grub-core/kern/efi/efi.c
|
||||||
+++ b/grub-core/kern/efi/efi.c
|
+++ b/grub-core/kern/efi/efi.c
|
||||||
@@ -273,40 +273,6 @@ grub_efi_get_variable (const char *var, const grub_efi_guid_t *guid,
|
@@ -286,40 +286,6 @@ grub_efi_get_variable (const char *var, const grub_efi_guid_t *guid,
|
||||||
return NULL;
|
return grub_efi_get_variable_with_attributes (var, guid, datasize_out, data_out, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
-grub_efi_boolean_t
|
-grub_efi_boolean_t
|
||||||
@ -170,78 +161,8 @@ index 91129e335..708581fcb 100644
|
|||||||
#pragma GCC diagnostic ignored "-Wcast-align"
|
#pragma GCC diagnostic ignored "-Wcast-align"
|
||||||
|
|
||||||
/* Search the mods section from the PE32/PE32+ image. This code uses
|
/* Search the mods section from the PE32/PE32+ image. This code uses
|
||||||
diff --git a/grub-core/kern/efi/sb.c b/grub-core/kern/efi/sb.c
|
|
||||||
new file mode 100644
|
|
||||||
index 000000000..d74778b0c
|
|
||||||
--- /dev/null
|
|
||||||
+++ b/grub-core/kern/efi/sb.c
|
|
||||||
@@ -0,0 +1,64 @@
|
|
||||||
+/*
|
|
||||||
+ * GRUB -- GRand Unified Bootloader
|
|
||||||
+ * Copyright (C) 2014 Free Software Foundation, Inc.
|
|
||||||
+ *
|
|
||||||
+ * GRUB 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 3 of the License, or
|
|
||||||
+ * (at your option) any later version.
|
|
||||||
+ *
|
|
||||||
+ * GRUB 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 GRUB. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
+ */
|
|
||||||
+
|
|
||||||
+#include <grub/err.h>
|
|
||||||
+#include <grub/mm.h>
|
|
||||||
+#include <grub/types.h>
|
|
||||||
+#include <grub/cpu/linux.h>
|
|
||||||
+#include <grub/efi/efi.h>
|
|
||||||
+#include <grub/efi/pe32.h>
|
|
||||||
+#include <grub/efi/linux.h>
|
|
||||||
+#include <grub/efi/sb.h>
|
|
||||||
+
|
|
||||||
+int
|
|
||||||
+grub_efi_secure_boot (void)
|
|
||||||
+{
|
|
||||||
+#ifdef GRUB_MACHINE_EFI
|
|
||||||
+ grub_efi_guid_t efi_var_guid = GRUB_EFI_GLOBAL_VARIABLE_GUID;
|
|
||||||
+ grub_size_t datasize;
|
|
||||||
+ char *secure_boot = NULL;
|
|
||||||
+ char *setup_mode = NULL;
|
|
||||||
+ grub_efi_boolean_t ret = 0;
|
|
||||||
+
|
|
||||||
+ secure_boot = grub_efi_get_variable("SecureBoot", &efi_var_guid, &datasize);
|
|
||||||
+ if (datasize != 1 || !secure_boot)
|
|
||||||
+ {
|
|
||||||
+ grub_dprintf ("secureboot", "No SecureBoot variable\n");
|
|
||||||
+ goto out;
|
|
||||||
+ }
|
|
||||||
+ grub_dprintf ("secureboot", "SecureBoot: %d\n", *secure_boot);
|
|
||||||
+
|
|
||||||
+ setup_mode = grub_efi_get_variable("SetupMode", &efi_var_guid, &datasize);
|
|
||||||
+ if (datasize != 1 || !setup_mode)
|
|
||||||
+ {
|
|
||||||
+ grub_dprintf ("secureboot", "No SetupMode variable\n");
|
|
||||||
+ goto out;
|
|
||||||
+ }
|
|
||||||
+ grub_dprintf ("secureboot", "SetupMode: %d\n", *setup_mode);
|
|
||||||
+
|
|
||||||
+ if (*secure_boot && !*setup_mode)
|
|
||||||
+ ret = 1;
|
|
||||||
+
|
|
||||||
+ out:
|
|
||||||
+ grub_free (secure_boot);
|
|
||||||
+ grub_free (setup_mode);
|
|
||||||
+ return ret;
|
|
||||||
+#else
|
|
||||||
+ return 0;
|
|
||||||
+#endif
|
|
||||||
+}
|
|
||||||
diff --git a/grub-core/loader/efi/appleloader.c b/grub-core/loader/efi/appleloader.c
|
diff --git a/grub-core/loader/efi/appleloader.c b/grub-core/loader/efi/appleloader.c
|
||||||
index 74888c463..69c2a10d3 100644
|
index 74888c463b..585f2b5738 100644
|
||||||
--- a/grub-core/loader/efi/appleloader.c
|
--- a/grub-core/loader/efi/appleloader.c
|
||||||
+++ b/grub-core/loader/efi/appleloader.c
|
+++ b/grub-core/loader/efi/appleloader.c
|
||||||
@@ -24,6 +24,7 @@
|
@@ -24,6 +24,7 @@
|
||||||
@ -256,7 +177,7 @@ index 74888c463..69c2a10d3 100644
|
|||||||
|
|
||||||
GRUB_MOD_INIT(appleloader)
|
GRUB_MOD_INIT(appleloader)
|
||||||
{
|
{
|
||||||
+ if (grub_efi_secure_boot())
|
+ if (grub_efi_get_secureboot () == GRUB_EFI_SECUREBOOT_MODE_ENABLED)
|
||||||
+ return;
|
+ return;
|
||||||
+
|
+
|
||||||
cmd = grub_register_command ("appleloader", grub_cmd_appleloader,
|
cmd = grub_register_command ("appleloader", grub_cmd_appleloader,
|
||||||
@ -266,13 +187,13 @@ index 74888c463..69c2a10d3 100644
|
|||||||
|
|
||||||
GRUB_MOD_FINI(appleloader)
|
GRUB_MOD_FINI(appleloader)
|
||||||
{
|
{
|
||||||
+ if (grub_efi_secure_boot())
|
+ if (grub_efi_get_secureboot () == GRUB_EFI_SECUREBOOT_MODE_ENABLED)
|
||||||
+ return;
|
+ return;
|
||||||
+
|
+
|
||||||
grub_unregister_command (cmd);
|
grub_unregister_command (cmd);
|
||||||
}
|
}
|
||||||
diff --git a/grub-core/loader/efi/chainloader.c b/grub-core/loader/efi/chainloader.c
|
diff --git a/grub-core/loader/efi/chainloader.c b/grub-core/loader/efi/chainloader.c
|
||||||
index af2189619..5cd9b6e08 100644
|
index e6a8d4ad0e..07c4937898 100644
|
||||||
--- a/grub-core/loader/efi/chainloader.c
|
--- a/grub-core/loader/efi/chainloader.c
|
||||||
+++ b/grub-core/loader/efi/chainloader.c
|
+++ b/grub-core/loader/efi/chainloader.c
|
||||||
@@ -34,6 +34,7 @@
|
@@ -34,6 +34,7 @@
|
||||||
@ -284,10 +205,10 @@ index af2189619..5cd9b6e08 100644
|
|||||||
#include <grub/i18n.h>
|
#include <grub/i18n.h>
|
||||||
#include <grub/net.h>
|
#include <grub/net.h>
|
||||||
diff --git a/grub-core/loader/i386/bsd.c b/grub-core/loader/i386/bsd.c
|
diff --git a/grub-core/loader/i386/bsd.c b/grub-core/loader/i386/bsd.c
|
||||||
index 7f96515da..87709aa23 100644
|
index 5f3290ce17..54befc2662 100644
|
||||||
--- a/grub-core/loader/i386/bsd.c
|
--- a/grub-core/loader/i386/bsd.c
|
||||||
+++ b/grub-core/loader/i386/bsd.c
|
+++ b/grub-core/loader/i386/bsd.c
|
||||||
@@ -38,6 +38,7 @@
|
@@ -40,6 +40,7 @@
|
||||||
#ifdef GRUB_MACHINE_PCBIOS
|
#ifdef GRUB_MACHINE_PCBIOS
|
||||||
#include <grub/machine/int.h>
|
#include <grub/machine/int.h>
|
||||||
#endif
|
#endif
|
||||||
@ -295,92 +216,92 @@ index 7f96515da..87709aa23 100644
|
|||||||
|
|
||||||
GRUB_MOD_LICENSE ("GPLv3+");
|
GRUB_MOD_LICENSE ("GPLv3+");
|
||||||
|
|
||||||
@@ -2124,6 +2125,9 @@ static grub_command_t cmd_netbsd_module_elf, cmd_openbsd_ramdisk;
|
@@ -2137,6 +2138,9 @@ static grub_command_t cmd_netbsd_module_elf, cmd_openbsd_ramdisk;
|
||||||
|
|
||||||
GRUB_MOD_INIT (bsd)
|
GRUB_MOD_INIT (bsd)
|
||||||
{
|
{
|
||||||
+ if (grub_efi_secure_boot())
|
+ if (grub_efi_get_secureboot () == GRUB_EFI_SECUREBOOT_MODE_ENABLED)
|
||||||
+ return;
|
+ return;
|
||||||
+
|
+
|
||||||
/* Net and OpenBSD kernels are often compressed. */
|
/* Net and OpenBSD kernels are often compressed. */
|
||||||
grub_dl_load ("gzio");
|
grub_dl_load ("gzio");
|
||||||
|
|
||||||
@@ -2163,6 +2167,9 @@ GRUB_MOD_INIT (bsd)
|
@@ -2176,6 +2180,9 @@ GRUB_MOD_INIT (bsd)
|
||||||
|
|
||||||
GRUB_MOD_FINI (bsd)
|
GRUB_MOD_FINI (bsd)
|
||||||
{
|
{
|
||||||
+ if (grub_efi_secure_boot())
|
+ if (grub_efi_get_secureboot () == GRUB_EFI_SECUREBOOT_MODE_ENABLED)
|
||||||
+ return;
|
+ return;
|
||||||
+
|
+
|
||||||
grub_unregister_extcmd (cmd_freebsd);
|
grub_unregister_extcmd (cmd_freebsd);
|
||||||
grub_unregister_extcmd (cmd_openbsd);
|
grub_unregister_extcmd (cmd_openbsd);
|
||||||
grub_unregister_extcmd (cmd_netbsd);
|
grub_unregister_extcmd (cmd_netbsd);
|
||||||
diff --git a/grub-core/loader/i386/linux.c b/grub-core/loader/i386/linux.c
|
diff --git a/grub-core/loader/i386/linux.c b/grub-core/loader/i386/linux.c
|
||||||
index f7186be40..c84747ea8 100644
|
index dccf3bb300..4aeb0e4b9a 100644
|
||||||
--- a/grub-core/loader/i386/linux.c
|
--- a/grub-core/loader/i386/linux.c
|
||||||
+++ b/grub-core/loader/i386/linux.c
|
+++ b/grub-core/loader/i386/linux.c
|
||||||
@@ -35,6 +35,7 @@
|
@@ -37,6 +37,7 @@
|
||||||
#include <grub/i18n.h>
|
|
||||||
#include <grub/lib/cmdline.h>
|
|
||||||
#include <grub/linux.h>
|
#include <grub/linux.h>
|
||||||
|
#include <grub/machine/kernel.h>
|
||||||
|
#include <grub/safemath.h>
|
||||||
+#include <grub/efi/sb.h>
|
+#include <grub/efi/sb.h>
|
||||||
|
|
||||||
GRUB_MOD_LICENSE ("GPLv3+");
|
GRUB_MOD_LICENSE ("GPLv3+");
|
||||||
|
|
||||||
@@ -1156,6 +1157,9 @@ static grub_command_t cmd_linux, cmd_initrd;
|
@@ -1138,6 +1139,9 @@ static grub_command_t cmd_linux, cmd_initrd;
|
||||||
|
|
||||||
GRUB_MOD_INIT(linux)
|
GRUB_MOD_INIT(linux)
|
||||||
{
|
{
|
||||||
+ if (grub_efi_secure_boot())
|
+ if (grub_efi_get_secureboot () == GRUB_EFI_SECUREBOOT_MODE_ENABLED)
|
||||||
+ return;
|
+ return;
|
||||||
+
|
+
|
||||||
cmd_linux = grub_register_command ("linux", grub_cmd_linux,
|
cmd_linux = grub_register_command ("linux", grub_cmd_linux,
|
||||||
0, N_("Load Linux."));
|
0, N_("Load Linux."));
|
||||||
cmd_initrd = grub_register_command ("initrd", grub_cmd_initrd,
|
cmd_initrd = grub_register_command ("initrd", grub_cmd_initrd,
|
||||||
@@ -1165,6 +1169,9 @@ GRUB_MOD_INIT(linux)
|
@@ -1147,6 +1151,9 @@ GRUB_MOD_INIT(linux)
|
||||||
|
|
||||||
GRUB_MOD_FINI(linux)
|
GRUB_MOD_FINI(linux)
|
||||||
{
|
{
|
||||||
+ if (grub_efi_secure_boot())
|
+ if (grub_efi_get_secureboot () == GRUB_EFI_SECUREBOOT_MODE_ENABLED)
|
||||||
+ return;
|
+ return;
|
||||||
+
|
+
|
||||||
grub_unregister_command (cmd_linux);
|
grub_unregister_command (cmd_linux);
|
||||||
grub_unregister_command (cmd_initrd);
|
grub_unregister_command (cmd_initrd);
|
||||||
}
|
}
|
||||||
diff --git a/grub-core/loader/i386/pc/linux.c b/grub-core/loader/i386/pc/linux.c
|
diff --git a/grub-core/loader/i386/pc/linux.c b/grub-core/loader/i386/pc/linux.c
|
||||||
index caa76bee8..783a3cd93 100644
|
index 4b1750e360..e3fa1221e8 100644
|
||||||
--- a/grub-core/loader/i386/pc/linux.c
|
--- a/grub-core/loader/i386/pc/linux.c
|
||||||
+++ b/grub-core/loader/i386/pc/linux.c
|
+++ b/grub-core/loader/i386/pc/linux.c
|
||||||
@@ -35,6 +35,7 @@
|
@@ -36,6 +36,7 @@
|
||||||
#include <grub/i386/floppy.h>
|
|
||||||
#include <grub/lib/cmdline.h>
|
#include <grub/lib/cmdline.h>
|
||||||
#include <grub/linux.h>
|
#include <grub/linux.h>
|
||||||
|
#include <grub/safemath.h>
|
||||||
+#include <grub/efi/sb.h>
|
+#include <grub/efi/sb.h>
|
||||||
|
|
||||||
GRUB_MOD_LICENSE ("GPLv3+");
|
GRUB_MOD_LICENSE ("GPLv3+");
|
||||||
|
|
||||||
@@ -480,6 +481,9 @@ static grub_command_t cmd_linux, cmd_linux16, cmd_initrd, cmd_initrd16;
|
@@ -487,6 +488,9 @@ static grub_command_t cmd_linux, cmd_linux16, cmd_initrd, cmd_initrd16;
|
||||||
|
|
||||||
GRUB_MOD_INIT(linux16)
|
GRUB_MOD_INIT(linux16)
|
||||||
{
|
{
|
||||||
+ if (grub_efi_secure_boot())
|
+ if (grub_efi_get_secureboot () == GRUB_EFI_SECUREBOOT_MODE_ENABLED)
|
||||||
+ return;
|
+ return;
|
||||||
+
|
+
|
||||||
cmd_linux =
|
cmd_linux =
|
||||||
grub_register_command ("linux", grub_cmd_linux,
|
grub_register_command ("linux", grub_cmd_linux,
|
||||||
0, N_("Load Linux."));
|
0, N_("Load Linux."));
|
||||||
@@ -497,6 +501,9 @@ GRUB_MOD_INIT(linux16)
|
@@ -504,6 +508,9 @@ GRUB_MOD_INIT(linux16)
|
||||||
|
|
||||||
GRUB_MOD_FINI(linux16)
|
GRUB_MOD_FINI(linux16)
|
||||||
{
|
{
|
||||||
+ if (grub_efi_secure_boot())
|
+ if (grub_efi_get_secureboot () == GRUB_EFI_SECUREBOOT_MODE_ENABLED)
|
||||||
+ return;
|
+ return;
|
||||||
+
|
+
|
||||||
grub_unregister_command (cmd_linux);
|
grub_unregister_command (cmd_linux);
|
||||||
grub_unregister_command (cmd_linux16);
|
grub_unregister_command (cmd_linux16);
|
||||||
grub_unregister_command (cmd_initrd);
|
grub_unregister_command (cmd_initrd);
|
||||||
diff --git a/grub-core/loader/multiboot.c b/grub-core/loader/multiboot.c
|
diff --git a/grub-core/loader/multiboot.c b/grub-core/loader/multiboot.c
|
||||||
index 40c67e824..26df46a41 100644
|
index facb13f3d3..47e481f457 100644
|
||||||
--- a/grub-core/loader/multiboot.c
|
--- a/grub-core/loader/multiboot.c
|
||||||
+++ b/grub-core/loader/multiboot.c
|
+++ b/grub-core/loader/multiboot.c
|
||||||
@@ -50,6 +50,7 @@
|
@@ -50,6 +50,7 @@
|
||||||
@ -391,63 +312,63 @@ index 40c67e824..26df46a41 100644
|
|||||||
|
|
||||||
GRUB_MOD_LICENSE ("GPLv3+");
|
GRUB_MOD_LICENSE ("GPLv3+");
|
||||||
|
|
||||||
@@ -446,6 +447,9 @@ static grub_command_t cmd_multiboot, cmd_module;
|
@@ -444,6 +445,9 @@ static grub_command_t cmd_multiboot, cmd_module;
|
||||||
|
|
||||||
GRUB_MOD_INIT(multiboot)
|
GRUB_MOD_INIT(multiboot)
|
||||||
{
|
{
|
||||||
+ if (grub_efi_secure_boot())
|
+ if (grub_efi_get_secureboot () == GRUB_EFI_SECUREBOOT_MODE_ENABLED)
|
||||||
+ return;
|
+ return;
|
||||||
+
|
+
|
||||||
cmd_multiboot =
|
cmd_multiboot =
|
||||||
#ifdef GRUB_USE_MULTIBOOT2
|
#ifdef GRUB_USE_MULTIBOOT2
|
||||||
grub_register_command ("multiboot2", grub_cmd_multiboot,
|
grub_register_command ("multiboot2", grub_cmd_multiboot,
|
||||||
@@ -466,6 +470,9 @@ GRUB_MOD_INIT(multiboot)
|
@@ -464,6 +468,9 @@ GRUB_MOD_INIT(multiboot)
|
||||||
|
|
||||||
GRUB_MOD_FINI(multiboot)
|
GRUB_MOD_FINI(multiboot)
|
||||||
{
|
{
|
||||||
+ if (grub_efi_secure_boot())
|
+ if (grub_efi_get_secureboot () == GRUB_EFI_SECUREBOOT_MODE_ENABLED)
|
||||||
+ return;
|
+ return;
|
||||||
+
|
+
|
||||||
grub_unregister_command (cmd_multiboot);
|
grub_unregister_command (cmd_multiboot);
|
||||||
grub_unregister_command (cmd_module);
|
grub_unregister_command (cmd_module);
|
||||||
}
|
}
|
||||||
diff --git a/grub-core/loader/xnu.c b/grub-core/loader/xnu.c
|
diff --git a/grub-core/loader/xnu.c b/grub-core/loader/xnu.c
|
||||||
index c9885b1bc..df8dfdb4b 100644
|
index 1c0cf6a430..baa54e652a 100644
|
||||||
--- a/grub-core/loader/xnu.c
|
--- a/grub-core/loader/xnu.c
|
||||||
+++ b/grub-core/loader/xnu.c
|
+++ b/grub-core/loader/xnu.c
|
||||||
@@ -33,6 +33,7 @@
|
@@ -35,6 +35,7 @@
|
||||||
#include <grub/extcmd.h>
|
|
||||||
#include <grub/env.h>
|
|
||||||
#include <grub/i18n.h>
|
#include <grub/i18n.h>
|
||||||
|
#include <grub/verify.h>
|
||||||
|
#include <grub/safemath.h>
|
||||||
+#include <grub/efi/sb.h>
|
+#include <grub/efi/sb.h>
|
||||||
|
|
||||||
GRUB_MOD_LICENSE ("GPLv3+");
|
GRUB_MOD_LICENSE ("GPLv3+");
|
||||||
|
|
||||||
@@ -1469,6 +1470,9 @@ static grub_extcmd_t cmd_splash;
|
@@ -1497,6 +1498,9 @@ static grub_extcmd_t cmd_splash;
|
||||||
|
|
||||||
GRUB_MOD_INIT(xnu)
|
GRUB_MOD_INIT(xnu)
|
||||||
{
|
{
|
||||||
+ if (grub_efi_secure_boot())
|
+ if (grub_efi_get_secureboot () == GRUB_EFI_SECUREBOOT_MODE_ENABLED)
|
||||||
+ return;
|
+ return;
|
||||||
+
|
+
|
||||||
cmd_kernel = grub_register_command ("xnu_kernel", grub_cmd_xnu_kernel, 0,
|
cmd_kernel = grub_register_command ("xnu_kernel", grub_cmd_xnu_kernel, 0,
|
||||||
N_("Load XNU image."));
|
N_("Load XNU image."));
|
||||||
cmd_kernel64 = grub_register_command ("xnu_kernel64", grub_cmd_xnu_kernel64,
|
cmd_kernel64 = grub_register_command ("xnu_kernel64", grub_cmd_xnu_kernel64,
|
||||||
@@ -1509,6 +1513,9 @@ GRUB_MOD_INIT(xnu)
|
@@ -1540,6 +1544,9 @@ GRUB_MOD_INIT(xnu)
|
||||||
|
|
||||||
GRUB_MOD_FINI(xnu)
|
GRUB_MOD_FINI(xnu)
|
||||||
{
|
{
|
||||||
+ if (grub_efi_secure_boot())
|
+ if (grub_efi_get_secureboot () == GRUB_EFI_SECUREBOOT_MODE_ENABLED)
|
||||||
+ return;
|
+ return;
|
||||||
+
|
+
|
||||||
#ifndef GRUB_MACHINE_EMU
|
#ifndef GRUB_MACHINE_EMU
|
||||||
grub_unregister_command (cmd_resume);
|
grub_unregister_command (cmd_resume);
|
||||||
#endif
|
#endif
|
||||||
diff --git a/include/grub/efi/efi.h b/include/grub/efi/efi.h
|
diff --git a/include/grub/efi/efi.h b/include/grub/efi/efi.h
|
||||||
index 1061aee97..39480b386 100644
|
index 6295df85f3..585fa6662b 100644
|
||||||
--- a/include/grub/efi/efi.h
|
--- a/include/grub/efi/efi.h
|
||||||
+++ b/include/grub/efi/efi.h
|
+++ b/include/grub/efi/efi.h
|
||||||
@@ -85,7 +85,6 @@ EXPORT_FUNC (grub_efi_set_variable) (const char *var,
|
@@ -91,7 +91,6 @@ EXPORT_FUNC (grub_efi_set_variable) (const char *var,
|
||||||
const grub_efi_guid_t *guid,
|
const grub_efi_guid_t *guid,
|
||||||
void *data,
|
void *data,
|
||||||
grub_size_t datasize);
|
grub_size_t datasize);
|
||||||
@ -455,62 +376,15 @@ index 1061aee97..39480b386 100644
|
|||||||
int
|
int
|
||||||
EXPORT_FUNC (grub_efi_compare_device_paths) (const grub_efi_device_path_t *dp1,
|
EXPORT_FUNC (grub_efi_compare_device_paths) (const grub_efi_device_path_t *dp1,
|
||||||
const grub_efi_device_path_t *dp2);
|
const grub_efi_device_path_t *dp2);
|
||||||
diff --git a/include/grub/efi/sb.h b/include/grub/efi/sb.h
|
|
||||||
new file mode 100644
|
|
||||||
index 000000000..9629fbb0f
|
|
||||||
--- /dev/null
|
|
||||||
+++ b/include/grub/efi/sb.h
|
|
||||||
@@ -0,0 +1,29 @@
|
|
||||||
+/* sb.h - declare functions for EFI Secure Boot support */
|
|
||||||
+/*
|
|
||||||
+ * GRUB -- GRand Unified Bootloader
|
|
||||||
+ * Copyright (C) 2006,2007,2008,2009 Free Software Foundation, Inc.
|
|
||||||
+ *
|
|
||||||
+ * GRUB 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 3 of the License, or
|
|
||||||
+ * (at your option) any later version.
|
|
||||||
+ *
|
|
||||||
+ * GRUB 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 GRUB. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
+ */
|
|
||||||
+
|
|
||||||
+#ifndef GRUB_EFI_SB_HEADER
|
|
||||||
+#define GRUB_EFI_SB_HEADER 1
|
|
||||||
+
|
|
||||||
+#include <grub/types.h>
|
|
||||||
+#include <grub/dl.h>
|
|
||||||
+
|
|
||||||
+/* Functions. */
|
|
||||||
+int EXPORT_FUNC (grub_efi_secure_boot) (void);
|
|
||||||
+
|
|
||||||
+#endif /* ! GRUB_EFI_SB_HEADER */
|
|
||||||
diff --git a/include/grub/ia64/linux.h b/include/grub/ia64/linux.h
|
diff --git a/include/grub/ia64/linux.h b/include/grub/ia64/linux.h
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..e69de29bb
|
index 0000000000..e69de29bb2
|
||||||
diff --git a/include/grub/mips/linux.h b/include/grub/mips/linux.h
|
diff --git a/include/grub/mips/linux.h b/include/grub/mips/linux.h
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..e69de29bb
|
index 0000000000..e69de29bb2
|
||||||
diff --git a/include/grub/powerpc/linux.h b/include/grub/powerpc/linux.h
|
diff --git a/include/grub/powerpc/linux.h b/include/grub/powerpc/linux.h
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..e69de29bb
|
index 0000000000..e69de29bb2
|
||||||
diff --git a/include/grub/sparc64/linux.h b/include/grub/sparc64/linux.h
|
diff --git a/include/grub/sparc64/linux.h b/include/grub/sparc64/linux.h
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..e69de29bb
|
index 0000000000..e69de29bb2
|
||||||
diff --git a/grub-core/Makefile.am b/grub-core/Makefile.am
|
|
||||||
index f4ff62b76..9c69aa886 100644
|
|
||||||
--- a/grub-core/Makefile.am
|
|
||||||
+++ b/grub-core/Makefile.am
|
|
||||||
@@ -71,6 +71,7 @@ KERNEL_HEADER_FILES += $(top_srcdir)/include/grub/command.h
|
|
||||||
KERNEL_HEADER_FILES += $(top_srcdir)/include/grub/device.h
|
|
||||||
KERNEL_HEADER_FILES += $(top_srcdir)/include/grub/disk.h
|
|
||||||
KERNEL_HEADER_FILES += $(top_srcdir)/include/grub/dl.h
|
|
||||||
+KERNEL_HEADER_FILES += $(top_srcdir)/include/grub/efi/sb.h
|
|
||||||
KERNEL_HEADER_FILES += $(top_srcdir)/include/grub/env.h
|
|
||||||
KERNEL_HEADER_FILES += $(top_srcdir)/include/grub/env_private.h
|
|
||||||
KERNEL_HEADER_FILES += $(top_srcdir)/include/grub/err.h
|
|
@ -1,6 +1,6 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
From: Peter Jones <pjones@redhat.com>
|
From: Peter Jones <pjones@redhat.com>
|
||||||
Date: Tue, 14 Feb 2017 16:18:54 -0500
|
Date: Mon, 8 Jul 2019 12:32:37 +0200
|
||||||
Subject: [PATCH] Handle multi-arch (64-on-32) boot in linuxefi loader.
|
Subject: [PATCH] Handle multi-arch (64-on-32) boot in linuxefi loader.
|
||||||
|
|
||||||
Allow booting 64-bit kernels on 32-bit EFI on x86.
|
Allow booting 64-bit kernels on 32-bit EFI on x86.
|
||||||
@ -13,7 +13,7 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
3 files changed, 89 insertions(+), 37 deletions(-)
|
3 files changed, 89 insertions(+), 37 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/loader/efi/linux.c b/grub-core/loader/efi/linux.c
|
diff --git a/grub-core/loader/efi/linux.c b/grub-core/loader/efi/linux.c
|
||||||
index c8ecce6df..0622dfa48 100644
|
index c8ecce6dfd..0622dfa48d 100644
|
||||||
--- a/grub-core/loader/efi/linux.c
|
--- a/grub-core/loader/efi/linux.c
|
||||||
+++ b/grub-core/loader/efi/linux.c
|
+++ b/grub-core/loader/efi/linux.c
|
||||||
@@ -69,12 +69,17 @@ grub_linuxefi_secure_validate (void *data, grub_uint32_t size)
|
@@ -69,12 +69,17 @@ grub_linuxefi_secure_validate (void *data, grub_uint32_t size)
|
||||||
@ -37,7 +37,7 @@ index c8ecce6df..0622dfa48 100644
|
|||||||
|
|
||||||
return GRUB_ERR_BUG;
|
return GRUB_ERR_BUG;
|
||||||
diff --git a/grub-core/loader/i386/efi/linux.c b/grub-core/loader/i386/efi/linux.c
|
diff --git a/grub-core/loader/i386/efi/linux.c b/grub-core/loader/i386/efi/linux.c
|
||||||
index 8db228c5b..800c3e540 100644
|
index 6b24cbb948..3017d0f3e5 100644
|
||||||
--- a/grub-core/loader/i386/efi/linux.c
|
--- a/grub-core/loader/i386/efi/linux.c
|
||||||
+++ b/grub-core/loader/i386/efi/linux.c
|
+++ b/grub-core/loader/i386/efi/linux.c
|
||||||
@@ -44,14 +44,10 @@ static char *linux_cmdline;
|
@@ -44,14 +44,10 @@ static char *linux_cmdline;
|
||||||
@ -57,7 +57,7 @@ index 8db228c5b..800c3e540 100644
|
|||||||
params);
|
params);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -154,14 +150,20 @@ grub_cmd_initrd (grub_command_t cmd __attribute__ ((unused)),
|
@@ -153,14 +149,20 @@ grub_cmd_initrd (grub_command_t cmd __attribute__ ((unused)),
|
||||||
return grub_errno;
|
return grub_errno;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -71,7 +71,7 @@ index 8db228c5b..800c3e540 100644
|
|||||||
int argc, char *argv[])
|
int argc, char *argv[])
|
||||||
{
|
{
|
||||||
grub_file_t file = 0;
|
grub_file_t file = 0;
|
||||||
- struct linux_kernel_header lh;
|
- struct linux_i386_kernel_header lh;
|
||||||
- grub_ssize_t len, start, filelen;
|
- grub_ssize_t len, start, filelen;
|
||||||
+ struct linux_i386_kernel_header *lh = NULL;
|
+ struct linux_i386_kernel_header *lh = NULL;
|
||||||
+ grub_ssize_t start, filelen;
|
+ grub_ssize_t start, filelen;
|
||||||
@ -80,7 +80,7 @@ index 8db228c5b..800c3e540 100644
|
|||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
grub_dl_ref (my_mod);
|
grub_dl_ref (my_mod);
|
||||||
@@ -201,48 +203,79 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
@@ -200,48 +202,79 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -172,12 +172,13 @@ index 8db228c5b..800c3e540 100644
|
|||||||
if (!linux_cmdline)
|
if (!linux_cmdline)
|
||||||
{
|
{
|
||||||
grub_error (GRUB_ERR_OUT_OF_MEMORY, N_("can't allocate cmdline"));
|
grub_error (GRUB_ERR_OUT_OF_MEMORY, N_("can't allocate cmdline"));
|
||||||
@@ -255,21 +288,23 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
@@ -254,22 +287,24 @@ grub_cmd_linux (grub_command_t cmd __attribute__ ((unused)),
|
||||||
grub_memcpy (linux_cmdline, LINUX_IMAGE, sizeof (LINUX_IMAGE));
|
grub_memcpy (linux_cmdline, LINUX_IMAGE, sizeof (LINUX_IMAGE));
|
||||||
grub_create_loader_cmdline (argc, argv,
|
grub_create_loader_cmdline (argc, argv,
|
||||||
linux_cmdline + sizeof (LINUX_IMAGE) - 1,
|
linux_cmdline + sizeof (LINUX_IMAGE) - 1,
|
||||||
- lh.cmdline_size - (sizeof (LINUX_IMAGE) - 1));
|
- lh.cmdline_size - (sizeof (LINUX_IMAGE) - 1),
|
||||||
+ lh->cmdline_size - (sizeof (LINUX_IMAGE) - 1));
|
+ lh->cmdline_size - (sizeof (LINUX_IMAGE) - 1),
|
||||||
|
GRUB_VERIFY_KERNEL_CMDLINE);
|
||||||
|
|
||||||
- lh.cmd_line_ptr = (grub_uint32_t)(grub_addr_t)linux_cmdline;
|
- lh.cmd_line_ptr = (grub_uint32_t)(grub_addr_t)linux_cmdline;
|
||||||
+ grub_dprintf ("linux", "cmdline:%s\n", linux_cmdline);
|
+ grub_dprintf ("linux", "cmdline:%s\n", linux_cmdline);
|
||||||
@ -244,10 +245,10 @@ index 8db228c5b..800c3e540 100644
|
|||||||
if (kernel_mem && !loaded)
|
if (kernel_mem && !loaded)
|
||||||
grub_efi_free_pages ((grub_efi_physical_address_t)(grub_addr_t)kernel_mem,
|
grub_efi_free_pages ((grub_efi_physical_address_t)(grub_addr_t)kernel_mem,
|
||||||
diff --git a/include/grub/i386/linux.h b/include/grub/i386/linux.h
|
diff --git a/include/grub/i386/linux.h b/include/grub/i386/linux.h
|
||||||
index bb19dbd5a..8474a857e 100644
|
index eddf9251d9..25ef52c04e 100644
|
||||||
--- a/include/grub/i386/linux.h
|
--- a/include/grub/i386/linux.h
|
||||||
+++ b/include/grub/i386/linux.h
|
+++ b/include/grub/i386/linux.h
|
||||||
@@ -133,7 +133,12 @@ struct linux_i386_kernel_header
|
@@ -138,7 +138,12 @@ struct linux_i386_kernel_header
|
||||||
grub_uint32_t kernel_alignment;
|
grub_uint32_t kernel_alignment;
|
||||||
grub_uint8_t relocatable;
|
grub_uint8_t relocatable;
|
||||||
grub_uint8_t min_alignment;
|
grub_uint8_t min_alignment;
|
246
0010-re-write-.gitignore.patch
Normal file
246
0010-re-write-.gitignore.patch
Normal file
@ -0,0 +1,246 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Peter Jones <pjones@redhat.com>
|
||||||
|
Date: Mon, 8 Jul 2019 12:55:29 +0200
|
||||||
|
Subject: [PATCH] re-write .gitignore
|
||||||
|
|
||||||
|
---
|
||||||
|
.gitignore | 150 ++++++++++++++++++++++++++++++++++++++
|
||||||
|
docs/.gitignore | 5 ++
|
||||||
|
grub-core/.gitignore | 16 ++++
|
||||||
|
grub-core/lib/.gitignore | 1 +
|
||||||
|
include/grub/gcrypt/.gitignore | 2 +
|
||||||
|
po/.gitignore | 5 ++
|
||||||
|
util/bash-completion.d/.gitignore | 2 +
|
||||||
|
7 files changed, 181 insertions(+)
|
||||||
|
create mode 100644 docs/.gitignore
|
||||||
|
create mode 100644 grub-core/.gitignore
|
||||||
|
create mode 100644 grub-core/lib/.gitignore
|
||||||
|
create mode 100644 include/grub/gcrypt/.gitignore
|
||||||
|
create mode 100644 po/.gitignore
|
||||||
|
create mode 100644 util/bash-completion.d/.gitignore
|
||||||
|
|
||||||
|
diff --git a/.gitignore b/.gitignore
|
||||||
|
index f6a1bd0517..208d1d2325 100644
|
||||||
|
--- a/.gitignore
|
||||||
|
+++ b/.gitignore
|
||||||
|
@@ -275,3 +275,153 @@ widthspec.bin
|
||||||
|
/xfs_test
|
||||||
|
/xzcompress_test
|
||||||
|
/zfs_test
|
||||||
|
+=======
|
||||||
|
+# things ./autogen.sh will create
|
||||||
|
+/Makefile.utilgcry.def
|
||||||
|
+/ABOUT-NLS
|
||||||
|
+/aclocal.m4
|
||||||
|
+/autom4te.cache
|
||||||
|
+/build-aux
|
||||||
|
+/configure
|
||||||
|
+/gnulib
|
||||||
|
+/grub-core/lib/gnulib/
|
||||||
|
+/Makefile
|
||||||
|
+
|
||||||
|
+# things very common editors create that we never want
|
||||||
|
+*~
|
||||||
|
+.*.sw?
|
||||||
|
+*.patch
|
||||||
|
+
|
||||||
|
+# stuff you're likely to make while building test trees
|
||||||
|
+grub.cfg
|
||||||
|
+/build*/
|
||||||
|
+
|
||||||
|
+# built objects across the whole tree
|
||||||
|
+Makefile.in
|
||||||
|
+*.a
|
||||||
|
+*.am
|
||||||
|
+*.efi
|
||||||
|
+*.exec
|
||||||
|
+*.image
|
||||||
|
+*.img
|
||||||
|
+*.info
|
||||||
|
+*.lst
|
||||||
|
+*.marker
|
||||||
|
+/m4
|
||||||
|
+*.mod
|
||||||
|
+*.module
|
||||||
|
+*.o
|
||||||
|
+*.pf2
|
||||||
|
+*.yy.[ch]
|
||||||
|
+.deps/
|
||||||
|
+.deps-core/
|
||||||
|
+.deps-util/
|
||||||
|
+.dirstamp
|
||||||
|
+
|
||||||
|
+# next are things you get if you do ./configure in the topdir (for e.g.
|
||||||
|
+# "make dist" invocation.
|
||||||
|
+/config-util.h
|
||||||
|
+/config.h
|
||||||
|
+/include/grub/cpu
|
||||||
|
+/include/grub/machine
|
||||||
|
+/INSTALL
|
||||||
|
+/INSTALL.grub
|
||||||
|
+/po/Makefile.in.in
|
||||||
|
+/po/Makevars
|
||||||
|
+/po/Makevars.template
|
||||||
|
+/po/POTFILES
|
||||||
|
+/po/Rules-quot
|
||||||
|
+/stamp-h
|
||||||
|
+/stamp-h1
|
||||||
|
+bootstrap.log
|
||||||
|
+config.log
|
||||||
|
+config.status
|
||||||
|
+
|
||||||
|
+# stuff "make dist" creates
|
||||||
|
+ChangeLog
|
||||||
|
+grub-*.tar
|
||||||
|
+grub-*.tar.*
|
||||||
|
+
|
||||||
|
+# stuff "make" creates
|
||||||
|
+/[[:digit:]][[:digit:]]_?*
|
||||||
|
+/ascii.h
|
||||||
|
+/build-grub-gen-asciih
|
||||||
|
+/build-grub-gen-widthspec
|
||||||
|
+/build-grub-mkfont
|
||||||
|
+/config-util.h.in
|
||||||
|
+/garbage-gen
|
||||||
|
+/grub*-bios-setup
|
||||||
|
+/grub*-bios-setup.8
|
||||||
|
+/grub*-editenv
|
||||||
|
+/grub*-editenv.1
|
||||||
|
+/grub*-file
|
||||||
|
+/grub*-file.1
|
||||||
|
+/grub*-fs-tester
|
||||||
|
+/grub*-fstest
|
||||||
|
+/grub*-fstest.1
|
||||||
|
+/grub*-get-kernel-settings
|
||||||
|
+/grub*-get-kernel-settings.3
|
||||||
|
+/grub*-glue-efi
|
||||||
|
+/grub*-glue-efi.1
|
||||||
|
+/grub*-install
|
||||||
|
+/grub*-install.8
|
||||||
|
+/grub*-kbdcomp
|
||||||
|
+/grub*-kbdcomp.1
|
||||||
|
+/grub*-macbless
|
||||||
|
+/grub*-macbless.8
|
||||||
|
+/grub*-menulst2cfg
|
||||||
|
+/grub*-menulst2cfg.1
|
||||||
|
+/grub*-mount
|
||||||
|
+/grub*-mount.1
|
||||||
|
+/grub*-mkconfig
|
||||||
|
+/grub*-mkconfig.8
|
||||||
|
+/grub*-mkconfig_lib
|
||||||
|
+/grub*-mkfont
|
||||||
|
+/grub*-mkfont.1
|
||||||
|
+/grub*-mkimage
|
||||||
|
+/grub*-mkimage.1
|
||||||
|
+/grub*-mklayout
|
||||||
|
+/grub*-mklayout.1
|
||||||
|
+/grub*-mknetdir
|
||||||
|
+/grub*-mknetdir.1
|
||||||
|
+/grub*-mkpasswd-pbkdf2
|
||||||
|
+/grub*-mkpasswd-pbkdf2.1
|
||||||
|
+/grub*-mkrelpath
|
||||||
|
+/grub*-mkrelpath.1
|
||||||
|
+/grub*-mkrescue
|
||||||
|
+/grub*-mkrescue.1
|
||||||
|
+/grub*-mkstandalone
|
||||||
|
+/grub*-mkstandalone.1
|
||||||
|
+/grub*-ofpathname
|
||||||
|
+/grub*-ofpathname.8
|
||||||
|
+/grub*-probe
|
||||||
|
+/grub*-probe.8
|
||||||
|
+/grub*-reboot
|
||||||
|
+/grub*-reboot.8
|
||||||
|
+/grub*-render-label
|
||||||
|
+/grub*-render-label.1
|
||||||
|
+/grub*-script-check
|
||||||
|
+/grub*-script-check.1
|
||||||
|
+/grub*-set-bootflag
|
||||||
|
+/grub*-set-bootflag.1
|
||||||
|
+/grub*-set-default
|
||||||
|
+/grub*-set-default.8
|
||||||
|
+/grub*-set-password
|
||||||
|
+/grub*-set-password.8
|
||||||
|
+/grub*-shell
|
||||||
|
+/grub*-shell-tester
|
||||||
|
+/grub*-sparc64-setup
|
||||||
|
+/grub*-sparc64-setup.8
|
||||||
|
+/grub*-syslinux2cfg
|
||||||
|
+/grub*-syslinux2cfg.1
|
||||||
|
+/grub*-switch-to-blscfg
|
||||||
|
+/grub*-switch-to-blscfg.8
|
||||||
|
+/grub_fstest.pp
|
||||||
|
+/grub_fstest_init.c
|
||||||
|
+/grub_fstest_init.lst
|
||||||
|
+/grub_script.tab.[ch]
|
||||||
|
+/libgrub.pp
|
||||||
|
+/libgrub_a_init.c
|
||||||
|
+/libgrub_a_init.lst
|
||||||
|
+/stamp-h.in
|
||||||
|
+/widthspec.h
|
||||||
|
diff --git a/docs/.gitignore b/docs/.gitignore
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000000..e1d849ef95
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/docs/.gitignore
|
||||||
|
@@ -0,0 +1,5 @@
|
||||||
|
+/*.in
|
||||||
|
+/Makefile
|
||||||
|
+/stamp-1
|
||||||
|
+/stamp-vti
|
||||||
|
+/version*.texi
|
||||||
|
diff --git a/grub-core/.gitignore b/grub-core/.gitignore
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000000..2acce28115
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/grub-core/.gitignore
|
||||||
|
@@ -0,0 +1,16 @@
|
||||||
|
+/*.lst
|
||||||
|
+/Makefile
|
||||||
|
+/Makefile.gcry.def
|
||||||
|
+/unidata.c
|
||||||
|
+/build-grub-module-verifier
|
||||||
|
+/gdb_grub
|
||||||
|
+/genmod.sh
|
||||||
|
+/gensyminfo.sh
|
||||||
|
+/gentrigtables
|
||||||
|
+/gmodule.pl
|
||||||
|
+/grub_script.tab.[ch]
|
||||||
|
+/modinfo.sh
|
||||||
|
+/rs_decoder.h
|
||||||
|
+/symlist.c
|
||||||
|
+/symlist.h
|
||||||
|
+/trigtables.c
|
||||||
|
diff --git a/grub-core/lib/.gitignore b/grub-core/lib/.gitignore
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000000..6815459140
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/grub-core/lib/.gitignore
|
||||||
|
@@ -0,0 +1 @@
|
||||||
|
+/libgcrypt-grub/
|
||||||
|
diff --git a/include/grub/gcrypt/.gitignore b/include/grub/gcrypt/.gitignore
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000000..8fbf564624
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/include/grub/gcrypt/.gitignore
|
||||||
|
@@ -0,0 +1,2 @@
|
||||||
|
+g10lib.h
|
||||||
|
+gcrypt.h
|
||||||
|
diff --git a/po/.gitignore b/po/.gitignore
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000000..f507e7741e
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/po/.gitignore
|
||||||
|
@@ -0,0 +1,5 @@
|
||||||
|
+/Makefile
|
||||||
|
+/POTFILES*.in
|
||||||
|
+/grub.pot
|
||||||
|
+/remove-potcdate.sed
|
||||||
|
+/stamp-po
|
||||||
|
diff --git a/util/bash-completion.d/.gitignore b/util/bash-completion.d/.gitignore
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000000..6813a527ad
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/util/bash-completion.d/.gitignore
|
||||||
|
@@ -0,0 +1,2 @@
|
||||||
|
+Makefile
|
||||||
|
+grub
|
@ -7,16 +7,20 @@ This is an implementation of IBM client architecture (CAS) reboot for GRUB.
|
|||||||
|
|
||||||
There are cases where the POWER firmware must reboot in order to support
|
There are cases where the POWER firmware must reboot in order to support
|
||||||
specific features requested by a kernel. The kernel calls
|
specific features requested by a kernel. The kernel calls
|
||||||
ibm,client-architecture-support and it may either return or reboot with the new
|
ibm,client-architecture-support and it may either return or reboot with
|
||||||
feature set. eg:
|
the new feature set. eg:
|
||||||
|
|
||||||
Calling ibm,client-architecture-support.../
|
Calling ibm,client-architecture-support.../
|
||||||
Elapsed time since release of system processors: 70959 mins 50 secs
|
Elapsed time since release of system processors: 70959 mins 50 secs
|
||||||
Welcome to GRUB!
|
Welcome to GRUB!
|
||||||
|
|
||||||
Instead of return to the GRUB menu, it will check if the flag for CAS reboot is
|
Instead of return to the GRUB menu, it will check if the flag for CAS
|
||||||
set. If so, grub will automatically boot the last booted kernel using the same
|
reboot is set. If so, grub will automatically boot the last booted
|
||||||
parameters
|
kernel using the same parameters
|
||||||
|
|
||||||
|
Signed-off-by: Paulo Flabiano Smorigo <pfsmorigo@br.ibm.com>
|
||||||
|
[rharwood@redhat.com: commit message rewrap]
|
||||||
|
Signed-off-by: Robbie Harwood <rharwood@redhat.com>
|
||||||
---
|
---
|
||||||
grub-core/kern/ieee1275/openfw.c | 63 ++++++++++++++++++++++++++++++++++++++++
|
grub-core/kern/ieee1275/openfw.c | 63 ++++++++++++++++++++++++++++++++++++++++
|
||||||
grub-core/normal/main.c | 19 ++++++++++++
|
grub-core/normal/main.c | 19 ++++++++++++
|
||||||
@ -25,10 +29,10 @@ parameters
|
|||||||
4 files changed, 91 insertions(+)
|
4 files changed, 91 insertions(+)
|
||||||
|
|
||||||
diff --git a/grub-core/kern/ieee1275/openfw.c b/grub-core/kern/ieee1275/openfw.c
|
diff --git a/grub-core/kern/ieee1275/openfw.c b/grub-core/kern/ieee1275/openfw.c
|
||||||
index 62929d983..2d53c0e86 100644
|
index 4d493ab766..3a6689abb1 100644
|
||||||
--- a/grub-core/kern/ieee1275/openfw.c
|
--- a/grub-core/kern/ieee1275/openfw.c
|
||||||
+++ b/grub-core/kern/ieee1275/openfw.c
|
+++ b/grub-core/kern/ieee1275/openfw.c
|
||||||
@@ -588,3 +588,66 @@ grub_ieee1275_get_boot_dev (void)
|
@@ -591,3 +591,66 @@ grub_ieee1275_get_boot_dev (void)
|
||||||
|
|
||||||
return bootpath;
|
return bootpath;
|
||||||
}
|
}
|
||||||
@ -96,10 +100,10 @@ index 62929d983..2d53c0e86 100644
|
|||||||
+ return 0;
|
+ return 0;
|
||||||
+}
|
+}
|
||||||
diff --git a/grub-core/normal/main.c b/grub-core/normal/main.c
|
diff --git a/grub-core/normal/main.c b/grub-core/normal/main.c
|
||||||
index 78a70a8bf..249e19bc7 100644
|
index c4ebe9e22a..70614de156 100644
|
||||||
--- a/grub-core/normal/main.c
|
--- a/grub-core/normal/main.c
|
||||||
+++ b/grub-core/normal/main.c
|
+++ b/grub-core/normal/main.c
|
||||||
@@ -33,6 +33,9 @@
|
@@ -34,6 +34,9 @@
|
||||||
#include <grub/charset.h>
|
#include <grub/charset.h>
|
||||||
#include <grub/script_sh.h>
|
#include <grub/script_sh.h>
|
||||||
#include <grub/bufio.h>
|
#include <grub/bufio.h>
|
||||||
@ -109,7 +113,7 @@ index 78a70a8bf..249e19bc7 100644
|
|||||||
|
|
||||||
GRUB_MOD_LICENSE ("GPLv3+");
|
GRUB_MOD_LICENSE ("GPLv3+");
|
||||||
|
|
||||||
@@ -275,6 +278,22 @@ grub_normal_execute (const char *config, int nested, int batch)
|
@@ -276,6 +279,22 @@ grub_normal_execute (const char *config, int nested, int batch)
|
||||||
{
|
{
|
||||||
menu = read_config_file (config);
|
menu = read_config_file (config);
|
||||||
|
|
||||||
@ -133,20 +137,20 @@ index 78a70a8bf..249e19bc7 100644
|
|||||||
grub_errno = GRUB_ERR_NONE;
|
grub_errno = GRUB_ERR_NONE;
|
||||||
}
|
}
|
||||||
diff --git a/grub-core/script/execute.c b/grub-core/script/execute.c
|
diff --git a/grub-core/script/execute.c b/grub-core/script/execute.c
|
||||||
index a8502d907..ab78ca87f 100644
|
index 25158407dd..ad80399246 100644
|
||||||
--- a/grub-core/script/execute.c
|
--- a/grub-core/script/execute.c
|
||||||
+++ b/grub-core/script/execute.c
|
+++ b/grub-core/script/execute.c
|
||||||
@@ -27,6 +27,9 @@
|
@@ -28,6 +28,9 @@
|
||||||
#include <grub/normal.h>
|
|
||||||
#include <grub/extcmd.h>
|
#include <grub/extcmd.h>
|
||||||
#include <grub/i18n.h>
|
#include <grub/i18n.h>
|
||||||
|
#include <grub/verify.h>
|
||||||
+#ifdef GRUB_MACHINE_IEEE1275
|
+#ifdef GRUB_MACHINE_IEEE1275
|
||||||
+#include <grub/ieee1275/ieee1275.h>
|
+#include <grub/ieee1275/ieee1275.h>
|
||||||
+#endif
|
+#endif
|
||||||
|
|
||||||
/* Max digits for a char is 3 (0xFF is 255), similarly for an int it
|
/* Max digits for a char is 3 (0xFF is 255), similarly for an int it
|
||||||
is sizeof (int) * 3, and one extra for a possible -ve sign. */
|
is sizeof (int) * 3, and one extra for a possible -ve sign. */
|
||||||
@@ -877,6 +880,10 @@ grub_script_execute_sourcecode (const char *source)
|
@@ -883,6 +886,10 @@ grub_script_execute_sourcecode (const char *source)
|
||||||
grub_err_t ret = 0;
|
grub_err_t ret = 0;
|
||||||
struct grub_script *parsed_script;
|
struct grub_script *parsed_script;
|
||||||
|
|
||||||
@ -158,10 +162,10 @@ index a8502d907..ab78ca87f 100644
|
|||||||
{
|
{
|
||||||
char *line;
|
char *line;
|
||||||
diff --git a/include/grub/ieee1275/ieee1275.h b/include/grub/ieee1275/ieee1275.h
|
diff --git a/include/grub/ieee1275/ieee1275.h b/include/grub/ieee1275/ieee1275.h
|
||||||
index 8868f3a75..2310f33db 100644
|
index 73e2f46447..0a599607f3 100644
|
||||||
--- a/include/grub/ieee1275/ieee1275.h
|
--- a/include/grub/ieee1275/ieee1275.h
|
||||||
+++ b/include/grub/ieee1275/ieee1275.h
|
+++ b/include/grub/ieee1275/ieee1275.h
|
||||||
@@ -252,6 +252,8 @@ int EXPORT_FUNC(grub_ieee1275_devalias_next) (struct grub_ieee1275_devalias *ali
|
@@ -254,6 +254,8 @@ int EXPORT_FUNC(grub_ieee1275_devalias_next) (struct grub_ieee1275_devalias *ali
|
||||||
void EXPORT_FUNC(grub_ieee1275_children_peer) (struct grub_ieee1275_devalias *alias);
|
void EXPORT_FUNC(grub_ieee1275_children_peer) (struct grub_ieee1275_devalias *alias);
|
||||||
void EXPORT_FUNC(grub_ieee1275_children_first) (const char *devpath,
|
void EXPORT_FUNC(grub_ieee1275_children_first) (const char *devpath,
|
||||||
struct grub_ieee1275_devalias *alias);
|
struct grub_ieee1275_devalias *alias);
|
@ -10,12 +10,14 @@ This should fix this bugzilla:
|
|||||||
https://bugzilla.redhat.com/show_bug.cgi?id=908519
|
https://bugzilla.redhat.com/show_bug.cgi?id=908519
|
||||||
|
|
||||||
Signed-off-by: Peter Jones <pjones@redhat.com>
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
|
Signed-off-by: Paulo Flabiano Smorigo <pfsmorigo@br.ibm.com>
|
||||||
|
Signed-off-by: Robbie Harwood <rharwood@redhat.com>
|
||||||
---
|
---
|
||||||
grub-core/term/terminfo.c | 2 +-
|
grub-core/term/terminfo.c | 2 +-
|
||||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
diff --git a/grub-core/term/terminfo.c b/grub-core/term/terminfo.c
|
diff --git a/grub-core/term/terminfo.c b/grub-core/term/terminfo.c
|
||||||
index d317efa36..29df35e6d 100644
|
index 85ecf06b4d..05c88dcf49 100644
|
||||||
--- a/grub-core/term/terminfo.c
|
--- a/grub-core/term/terminfo.c
|
||||||
+++ b/grub-core/term/terminfo.c
|
+++ b/grub-core/term/terminfo.c
|
||||||
@@ -151,7 +151,7 @@ grub_terminfo_set_current (struct grub_term_output *term,
|
@@ -151,7 +151,7 @@ grub_terminfo_set_current (struct grub_term_output *term,
|
@ -5,6 +5,9 @@ Subject: [PATCH] Disable GRUB video support for IBM power machines
|
|||||||
|
|
||||||
Should fix the problem in bugzilla:
|
Should fix the problem in bugzilla:
|
||||||
https://bugzilla.redhat.com/show_bug.cgi?id=973205
|
https://bugzilla.redhat.com/show_bug.cgi?id=973205
|
||||||
|
|
||||||
|
Signed-off-by: Paulo Flabiano Smorigo <pfsmorigo@br.ibm.com>
|
||||||
|
Signed-off-by: Robbie Harwood <rharwood@redhat.com>
|
||||||
---
|
---
|
||||||
grub-core/kern/ieee1275/cmain.c | 5 ++++-
|
grub-core/kern/ieee1275/cmain.c | 5 ++++-
|
||||||
grub-core/video/ieee1275.c | 9 ++++++---
|
grub-core/video/ieee1275.c | 9 ++++++---
|
||||||
@ -12,7 +15,7 @@ https://bugzilla.redhat.com/show_bug.cgi?id=973205
|
|||||||
3 files changed, 12 insertions(+), 4 deletions(-)
|
3 files changed, 12 insertions(+), 4 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/kern/ieee1275/cmain.c b/grub-core/kern/ieee1275/cmain.c
|
diff --git a/grub-core/kern/ieee1275/cmain.c b/grub-core/kern/ieee1275/cmain.c
|
||||||
index 3e12e6b24..3e14f5393 100644
|
index 20cbbd761e..04df9d2c66 100644
|
||||||
--- a/grub-core/kern/ieee1275/cmain.c
|
--- a/grub-core/kern/ieee1275/cmain.c
|
||||||
+++ b/grub-core/kern/ieee1275/cmain.c
|
+++ b/grub-core/kern/ieee1275/cmain.c
|
||||||
@@ -90,7 +90,10 @@ grub_ieee1275_find_options (void)
|
@@ -90,7 +90,10 @@ grub_ieee1275_find_options (void)
|
||||||
@ -28,7 +31,7 @@ index 3e12e6b24..3e14f5393 100644
|
|||||||
/* Old Macs have no key repeat, newer ones have fully working one.
|
/* Old Macs have no key repeat, newer ones have fully working one.
|
||||||
The ones inbetween when repeated key generates an escaoe sequence
|
The ones inbetween when repeated key generates an escaoe sequence
|
||||||
diff --git a/grub-core/video/ieee1275.c b/grub-core/video/ieee1275.c
|
diff --git a/grub-core/video/ieee1275.c b/grub-core/video/ieee1275.c
|
||||||
index 17a3dbbb5..b8e4b3feb 100644
|
index 17a3dbbb57..b8e4b3feb3 100644
|
||||||
--- a/grub-core/video/ieee1275.c
|
--- a/grub-core/video/ieee1275.c
|
||||||
+++ b/grub-core/video/ieee1275.c
|
+++ b/grub-core/video/ieee1275.c
|
||||||
@@ -352,9 +352,12 @@ static struct grub_video_adapter grub_video_ieee1275_adapter =
|
@@ -352,9 +352,12 @@ static struct grub_video_adapter grub_video_ieee1275_adapter =
|
||||||
@ -48,13 +51,13 @@ index 17a3dbbb5..b8e4b3feb 100644
|
|||||||
|
|
||||||
GRUB_MOD_FINI(ieee1275_fb)
|
GRUB_MOD_FINI(ieee1275_fb)
|
||||||
diff --git a/include/grub/ieee1275/ieee1275.h b/include/grub/ieee1275/ieee1275.h
|
diff --git a/include/grub/ieee1275/ieee1275.h b/include/grub/ieee1275/ieee1275.h
|
||||||
index 2310f33db..ca08bd966 100644
|
index 0a599607f3..b5a1d49bbc 100644
|
||||||
--- a/include/grub/ieee1275/ieee1275.h
|
--- a/include/grub/ieee1275/ieee1275.h
|
||||||
+++ b/include/grub/ieee1275/ieee1275.h
|
+++ b/include/grub/ieee1275/ieee1275.h
|
||||||
@@ -146,6 +146,8 @@ enum grub_ieee1275_flag
|
@@ -148,6 +148,8 @@ enum grub_ieee1275_flag
|
||||||
GRUB_IEEE1275_FLAG_BROKEN_REPEAT,
|
|
||||||
|
|
||||||
GRUB_IEEE1275_FLAG_CURSORONOFF_ANSI_BROKEN,
|
GRUB_IEEE1275_FLAG_CURSORONOFF_ANSI_BROKEN,
|
||||||
|
|
||||||
|
GRUB_IEEE1275_FLAG_RAW_DEVNAMES,
|
||||||
+
|
+
|
||||||
+ GRUB_IEEE1275_FLAG_DISABLE_VIDEO_SUPPORT
|
+ GRUB_IEEE1275_FLAG_DISABLE_VIDEO_SUPPORT
|
||||||
};
|
};
|
@ -10,10 +10,10 @@ Apparently these go in a new place now.
|
|||||||
2 files changed, 11 insertions(+), 1 deletion(-)
|
2 files changed, 11 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
diff --git a/configure.ac b/configure.ac
|
diff --git a/configure.ac b/configure.ac
|
||||||
index c7888e40f..783118ccd 100644
|
index 7517fc49d9..8331f95b64 100644
|
||||||
--- a/configure.ac
|
--- a/configure.ac
|
||||||
+++ b/configure.ac
|
+++ b/configure.ac
|
||||||
@@ -289,6 +289,14 @@ AC_SUBST(grubdirname)
|
@@ -314,6 +314,14 @@ AC_SUBST(grubdirname)
|
||||||
AC_DEFINE_UNQUOTED(GRUB_DIR_NAME, "$grubdirname",
|
AC_DEFINE_UNQUOTED(GRUB_DIR_NAME, "$grubdirname",
|
||||||
[Default grub directory name])
|
[Default grub directory name])
|
||||||
|
|
||||||
@ -28,7 +28,7 @@ index c7888e40f..783118ccd 100644
|
|||||||
#
|
#
|
||||||
# Checks for build programs.
|
# Checks for build programs.
|
||||||
#
|
#
|
||||||
@@ -498,6 +506,9 @@ HOST_CFLAGS="$HOST_CFLAGS $grub_cv_cc_w_extra_flags"
|
@@ -525,6 +533,9 @@ HOST_CFLAGS="$HOST_CFLAGS $grub_cv_cc_w_extra_flags"
|
||||||
# Check for target programs.
|
# Check for target programs.
|
||||||
#
|
#
|
||||||
|
|
||||||
@ -39,7 +39,7 @@ index c7888e40f..783118ccd 100644
|
|||||||
if test "x$target_alias" != x && test "x$host_alias" != "x$target_alias"; then
|
if test "x$target_alias" != x && test "x$host_alias" != "x$target_alias"; then
|
||||||
tmp_ac_tool_prefix="$ac_tool_prefix"
|
tmp_ac_tool_prefix="$ac_tool_prefix"
|
||||||
diff --git a/util/bash-completion.d/Makefile.am b/util/bash-completion.d/Makefile.am
|
diff --git a/util/bash-completion.d/Makefile.am b/util/bash-completion.d/Makefile.am
|
||||||
index 136287cf1..61108f054 100644
|
index 136287cf1b..61108f0542 100644
|
||||||
--- a/util/bash-completion.d/Makefile.am
|
--- a/util/bash-completion.d/Makefile.am
|
||||||
+++ b/util/bash-completion.d/Makefile.am
|
+++ b/util/bash-completion.d/Makefile.am
|
||||||
@@ -6,7 +6,6 @@ EXTRA_DIST = $(bash_completion_source)
|
@@ -6,7 +6,6 @@ EXTRA_DIST = $(bash_completion_source)
|
@ -12,10 +12,10 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
1 file changed, 58 insertions(+), 27 deletions(-)
|
1 file changed, 58 insertions(+), 27 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/normal/menu.c b/grub-core/normal/menu.c
|
diff --git a/grub-core/normal/menu.c b/grub-core/normal/menu.c
|
||||||
index e7a83c2d6..d2f64b05e 100644
|
index 8397886fa0..d7a222e681 100644
|
||||||
--- a/grub-core/normal/menu.c
|
--- a/grub-core/normal/menu.c
|
||||||
+++ b/grub-core/normal/menu.c
|
+++ b/grub-core/normal/menu.c
|
||||||
@@ -163,16 +163,41 @@ grub_menu_set_timeout (int timeout)
|
@@ -163,15 +163,40 @@ grub_menu_set_timeout (int timeout)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -51,14 +51,13 @@ index e7a83c2d6..d2f64b05e 100644
|
|||||||
-get_and_remove_first_entry_number (const char *name)
|
-get_and_remove_first_entry_number (const char *name)
|
||||||
+get_and_remove_first_entry_number (grub_menu_t menu, const char *name)
|
+get_and_remove_first_entry_number (grub_menu_t menu, const char *name)
|
||||||
{
|
{
|
||||||
const char *val;
|
const char *val, *tail;
|
||||||
char *tail;
|
|
||||||
int entry;
|
int entry;
|
||||||
+ int sz = 0;
|
+ int sz = 0;
|
||||||
|
|
||||||
val = grub_env_get (name);
|
val = grub_env_get (name);
|
||||||
if (! val)
|
if (! val)
|
||||||
@@ -182,9 +207,39 @@ get_and_remove_first_entry_number (const char *name)
|
@@ -181,9 +206,39 @@ get_and_remove_first_entry_number (const char *name)
|
||||||
|
|
||||||
entry = (int) grub_strtoul (val, &tail, 0);
|
entry = (int) grub_strtoul (val, &tail, 0);
|
||||||
|
|
||||||
@ -99,7 +98,7 @@ index e7a83c2d6..d2f64b05e 100644
|
|||||||
while (*tail && grub_isspace (*tail))
|
while (*tail && grub_isspace (*tail))
|
||||||
tail++;
|
tail++;
|
||||||
grub_env_set (name, tail);
|
grub_env_set (name, tail);
|
||||||
@@ -347,7 +402,7 @@ grub_menu_execute_with_fallback (grub_menu_t menu,
|
@@ -346,7 +401,7 @@ grub_menu_execute_with_fallback (grub_menu_t menu,
|
||||||
grub_menu_execute_entry (entry, 1);
|
grub_menu_execute_entry (entry, 1);
|
||||||
|
|
||||||
/* Deal with fallback entries. */
|
/* Deal with fallback entries. */
|
||||||
@ -108,7 +107,7 @@ index e7a83c2d6..d2f64b05e 100644
|
|||||||
>= 0)
|
>= 0)
|
||||||
{
|
{
|
||||||
grub_print_error ();
|
grub_print_error ();
|
||||||
@@ -465,30 +520,6 @@ grub_menu_register_viewer (struct grub_menu_viewer *viewer)
|
@@ -464,30 +519,6 @@ grub_menu_register_viewer (struct grub_menu_viewer *viewer)
|
||||||
viewers = viewer;
|
viewers = viewer;
|
||||||
}
|
}
|
||||||
|
|
@ -20,17 +20,17 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
grub-core/kern/mips/arc/init.c | 2 +-
|
grub-core/kern/mips/arc/init.c | 2 +-
|
||||||
grub-core/kern/mips/loongson/init.c | 2 +-
|
grub-core/kern/mips/loongson/init.c | 2 +-
|
||||||
grub-core/kern/mips/qemu_mips/init.c | 2 +-
|
grub-core/kern/mips/qemu_mips/init.c | 2 +-
|
||||||
grub-core/kern/misc.c | 2 +-
|
grub-core/kern/misc.c | 11 ++++++++++-
|
||||||
grub-core/kern/uboot/init.c | 6 +++---
|
grub-core/kern/uboot/init.c | 6 +++---
|
||||||
grub-core/kern/xen/init.c | 2 +-
|
grub-core/kern/xen/init.c | 2 +-
|
||||||
include/grub/misc.h | 2 +-
|
include/grub/misc.h | 2 +-
|
||||||
14 files changed, 39 insertions(+), 21 deletions(-)
|
14 files changed, 48 insertions(+), 21 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/commands/minicmd.c b/grub-core/commands/minicmd.c
|
diff --git a/grub-core/commands/minicmd.c b/grub-core/commands/minicmd.c
|
||||||
index a3a118241..b25ca4b9f 100644
|
index fa498931ed..2bd3ac76f2 100644
|
||||||
--- a/grub-core/commands/minicmd.c
|
--- a/grub-core/commands/minicmd.c
|
||||||
+++ b/grub-core/commands/minicmd.c
|
+++ b/grub-core/commands/minicmd.c
|
||||||
@@ -176,12 +176,24 @@ grub_mini_cmd_lsmod (struct grub_command *cmd __attribute__ ((unused)),
|
@@ -182,12 +182,24 @@ grub_mini_cmd_lsmod (struct grub_command *cmd __attribute__ ((unused)),
|
||||||
}
|
}
|
||||||
|
|
||||||
/* exit */
|
/* exit */
|
||||||
@ -60,10 +60,10 @@ index a3a118241..b25ca4b9f 100644
|
|||||||
}
|
}
|
||||||
|
|
||||||
diff --git a/grub-core/kern/efi/efi.c b/grub-core/kern/efi/efi.c
|
diff --git a/grub-core/kern/efi/efi.c b/grub-core/kern/efi/efi.c
|
||||||
index 708581fcb..e339f264b 100644
|
index 8cff7be028..05d8237a9b 100644
|
||||||
--- a/grub-core/kern/efi/efi.c
|
--- a/grub-core/kern/efi/efi.c
|
||||||
+++ b/grub-core/kern/efi/efi.c
|
+++ b/grub-core/kern/efi/efi.c
|
||||||
@@ -164,11 +164,16 @@ grub_reboot (void)
|
@@ -165,11 +165,16 @@ grub_reboot (void)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -83,7 +83,7 @@ index 708581fcb..e339f264b 100644
|
|||||||
}
|
}
|
||||||
|
|
||||||
diff --git a/grub-core/kern/emu/main.c b/grub-core/kern/emu/main.c
|
diff --git a/grub-core/kern/emu/main.c b/grub-core/kern/emu/main.c
|
||||||
index 425bb9603..55ea5a11c 100644
|
index 425bb96034..55ea5a11cc 100644
|
||||||
--- a/grub-core/kern/emu/main.c
|
--- a/grub-core/kern/emu/main.c
|
||||||
+++ b/grub-core/kern/emu/main.c
|
+++ b/grub-core/kern/emu/main.c
|
||||||
@@ -67,7 +67,7 @@ grub_reboot (void)
|
@@ -67,7 +67,7 @@ grub_reboot (void)
|
||||||
@ -96,10 +96,10 @@ index 425bb9603..55ea5a11c 100644
|
|||||||
grub_reboot ();
|
grub_reboot ();
|
||||||
}
|
}
|
||||||
diff --git a/grub-core/kern/emu/misc.c b/grub-core/kern/emu/misc.c
|
diff --git a/grub-core/kern/emu/misc.c b/grub-core/kern/emu/misc.c
|
||||||
index 76661337f..82012a72f 100644
|
index dfd8a8ec48..0ff13bcaf8 100644
|
||||||
--- a/grub-core/kern/emu/misc.c
|
--- a/grub-core/kern/emu/misc.c
|
||||||
+++ b/grub-core/kern/emu/misc.c
|
+++ b/grub-core/kern/emu/misc.c
|
||||||
@@ -137,9 +137,10 @@ xasprintf (const char *fmt, ...)
|
@@ -151,9 +151,10 @@ xasprintf (const char *fmt, ...)
|
||||||
|
|
||||||
#if !defined (GRUB_MACHINE_EMU) || defined (GRUB_UTIL)
|
#if !defined (GRUB_MACHINE_EMU) || defined (GRUB_UTIL)
|
||||||
void
|
void
|
||||||
@ -113,7 +113,7 @@ index 76661337f..82012a72f 100644
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
diff --git a/grub-core/kern/i386/coreboot/init.c b/grub-core/kern/i386/coreboot/init.c
|
diff --git a/grub-core/kern/i386/coreboot/init.c b/grub-core/kern/i386/coreboot/init.c
|
||||||
index 3314f027f..36f9134b7 100644
|
index 3314f027fe..36f9134b7b 100644
|
||||||
--- a/grub-core/kern/i386/coreboot/init.c
|
--- a/grub-core/kern/i386/coreboot/init.c
|
||||||
+++ b/grub-core/kern/i386/coreboot/init.c
|
+++ b/grub-core/kern/i386/coreboot/init.c
|
||||||
@@ -41,7 +41,7 @@ extern grub_uint8_t _end[];
|
@@ -41,7 +41,7 @@ extern grub_uint8_t _end[];
|
||||||
@ -126,7 +126,7 @@ index 3314f027f..36f9134b7 100644
|
|||||||
/* We can't use grub_fatal() in this function. This would create an infinite
|
/* We can't use grub_fatal() in this function. This would create an infinite
|
||||||
loop, since grub_fatal() calls grub_abort() which in turn calls grub_exit(). */
|
loop, since grub_fatal() calls grub_abort() which in turn calls grub_exit(). */
|
||||||
diff --git a/grub-core/kern/i386/qemu/init.c b/grub-core/kern/i386/qemu/init.c
|
diff --git a/grub-core/kern/i386/qemu/init.c b/grub-core/kern/i386/qemu/init.c
|
||||||
index 271b6fbfa..9fafe98f0 100644
|
index 271b6fbfab..9fafe98f01 100644
|
||||||
--- a/grub-core/kern/i386/qemu/init.c
|
--- a/grub-core/kern/i386/qemu/init.c
|
||||||
+++ b/grub-core/kern/i386/qemu/init.c
|
+++ b/grub-core/kern/i386/qemu/init.c
|
||||||
@@ -42,7 +42,7 @@ extern grub_uint8_t _end[];
|
@@ -42,7 +42,7 @@ extern grub_uint8_t _end[];
|
||||||
@ -139,10 +139,10 @@ index 271b6fbfa..9fafe98f0 100644
|
|||||||
/* We can't use grub_fatal() in this function. This would create an infinite
|
/* We can't use grub_fatal() in this function. This would create an infinite
|
||||||
loop, since grub_fatal() calls grub_abort() which in turn calls grub_exit(). */
|
loop, since grub_fatal() calls grub_abort() which in turn calls grub_exit(). */
|
||||||
diff --git a/grub-core/kern/ieee1275/init.c b/grub-core/kern/ieee1275/init.c
|
diff --git a/grub-core/kern/ieee1275/init.c b/grub-core/kern/ieee1275/init.c
|
||||||
index 0d8ebf58b..f5423ce27 100644
|
index d483e35eed..e71d158416 100644
|
||||||
--- a/grub-core/kern/ieee1275/init.c
|
--- a/grub-core/kern/ieee1275/init.c
|
||||||
+++ b/grub-core/kern/ieee1275/init.c
|
+++ b/grub-core/kern/ieee1275/init.c
|
||||||
@@ -68,7 +68,7 @@ grub_addr_t grub_ieee1275_original_stack;
|
@@ -71,7 +71,7 @@ grub_addr_t grub_ieee1275_original_stack;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -152,7 +152,7 @@ index 0d8ebf58b..f5423ce27 100644
|
|||||||
grub_ieee1275_exit ();
|
grub_ieee1275_exit ();
|
||||||
}
|
}
|
||||||
diff --git a/grub-core/kern/mips/arc/init.c b/grub-core/kern/mips/arc/init.c
|
diff --git a/grub-core/kern/mips/arc/init.c b/grub-core/kern/mips/arc/init.c
|
||||||
index 3834a1490..86b3a25ec 100644
|
index 2ed3ff3191..5c40c34078 100644
|
||||||
--- a/grub-core/kern/mips/arc/init.c
|
--- a/grub-core/kern/mips/arc/init.c
|
||||||
+++ b/grub-core/kern/mips/arc/init.c
|
+++ b/grub-core/kern/mips/arc/init.c
|
||||||
@@ -276,7 +276,7 @@ grub_halt (void)
|
@@ -276,7 +276,7 @@ grub_halt (void)
|
||||||
@ -165,7 +165,7 @@ index 3834a1490..86b3a25ec 100644
|
|||||||
GRUB_ARC_FIRMWARE_VECTOR->exit ();
|
GRUB_ARC_FIRMWARE_VECTOR->exit ();
|
||||||
|
|
||||||
diff --git a/grub-core/kern/mips/loongson/init.c b/grub-core/kern/mips/loongson/init.c
|
diff --git a/grub-core/kern/mips/loongson/init.c b/grub-core/kern/mips/loongson/init.c
|
||||||
index 7b96531b9..dff598ca7 100644
|
index 7b96531b98..dff598ca7b 100644
|
||||||
--- a/grub-core/kern/mips/loongson/init.c
|
--- a/grub-core/kern/mips/loongson/init.c
|
||||||
+++ b/grub-core/kern/mips/loongson/init.c
|
+++ b/grub-core/kern/mips/loongson/init.c
|
||||||
@@ -304,7 +304,7 @@ grub_halt (void)
|
@@ -304,7 +304,7 @@ grub_halt (void)
|
||||||
@ -178,7 +178,7 @@ index 7b96531b9..dff598ca7 100644
|
|||||||
grub_halt ();
|
grub_halt ();
|
||||||
}
|
}
|
||||||
diff --git a/grub-core/kern/mips/qemu_mips/init.c b/grub-core/kern/mips/qemu_mips/init.c
|
diff --git a/grub-core/kern/mips/qemu_mips/init.c b/grub-core/kern/mips/qemu_mips/init.c
|
||||||
index be88b77d2..8b6c55ffc 100644
|
index be88b77d22..8b6c55ffc0 100644
|
||||||
--- a/grub-core/kern/mips/qemu_mips/init.c
|
--- a/grub-core/kern/mips/qemu_mips/init.c
|
||||||
+++ b/grub-core/kern/mips/qemu_mips/init.c
|
+++ b/grub-core/kern/mips/qemu_mips/init.c
|
||||||
@@ -75,7 +75,7 @@ grub_machine_fini (int flags __attribute__ ((unused)))
|
@@ -75,7 +75,7 @@ grub_machine_fini (int flags __attribute__ ((unused)))
|
||||||
@ -191,10 +191,10 @@ index be88b77d2..8b6c55ffc 100644
|
|||||||
grub_halt ();
|
grub_halt ();
|
||||||
}
|
}
|
||||||
diff --git a/grub-core/kern/misc.c b/grub-core/kern/misc.c
|
diff --git a/grub-core/kern/misc.c b/grub-core/kern/misc.c
|
||||||
index 3b633d51f..952411d5d 100644
|
index 3af336ee22..63b586d09c 100644
|
||||||
--- a/grub-core/kern/misc.c
|
--- a/grub-core/kern/misc.c
|
||||||
+++ b/grub-core/kern/misc.c
|
+++ b/grub-core/kern/misc.c
|
||||||
@@ -1095,7 +1095,7 @@ grub_abort (void)
|
@@ -1209,9 +1209,18 @@ grub_abort (void)
|
||||||
grub_getkey ();
|
grub_getkey ();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -202,9 +202,20 @@ index 3b633d51f..952411d5d 100644
|
|||||||
+ grub_exit (1);
|
+ grub_exit (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
+#if defined (__clang__) && !defined (GRUB_UTIL)
|
||||||
|
+/* clang emits references to abort(). */
|
||||||
|
+void __attribute__ ((noreturn))
|
||||||
|
+abort (void)
|
||||||
|
+{
|
||||||
|
+ grub_abort ();
|
||||||
|
+}
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
void
|
void
|
||||||
|
grub_fatal (const char *fmt, ...)
|
||||||
|
{
|
||||||
diff --git a/grub-core/kern/uboot/init.c b/grub-core/kern/uboot/init.c
|
diff --git a/grub-core/kern/uboot/init.c b/grub-core/kern/uboot/init.c
|
||||||
index 3e338645c..be2a5be1d 100644
|
index 3e338645c5..be2a5be1d0 100644
|
||||||
--- a/grub-core/kern/uboot/init.c
|
--- a/grub-core/kern/uboot/init.c
|
||||||
+++ b/grub-core/kern/uboot/init.c
|
+++ b/grub-core/kern/uboot/init.c
|
||||||
@@ -39,9 +39,9 @@ extern grub_size_t grub_total_module_size;
|
@@ -39,9 +39,9 @@ extern grub_size_t grub_total_module_size;
|
||||||
@ -229,10 +240,10 @@ index 3e338645c..be2a5be1d 100644
|
|||||||
else if (ver > API_SIG_VERSION)
|
else if (ver > API_SIG_VERSION)
|
||||||
{
|
{
|
||||||
diff --git a/grub-core/kern/xen/init.c b/grub-core/kern/xen/init.c
|
diff --git a/grub-core/kern/xen/init.c b/grub-core/kern/xen/init.c
|
||||||
index 0559c033c..fce526d41 100644
|
index 782ca72952..708b060f32 100644
|
||||||
--- a/grub-core/kern/xen/init.c
|
--- a/grub-core/kern/xen/init.c
|
||||||
+++ b/grub-core/kern/xen/init.c
|
+++ b/grub-core/kern/xen/init.c
|
||||||
@@ -549,7 +549,7 @@ grub_machine_init (void)
|
@@ -584,7 +584,7 @@ grub_machine_init (void)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -242,10 +253,10 @@ index 0559c033c..fce526d41 100644
|
|||||||
struct sched_shutdown arg;
|
struct sched_shutdown arg;
|
||||||
|
|
||||||
diff --git a/include/grub/misc.h b/include/grub/misc.h
|
diff --git a/include/grub/misc.h b/include/grub/misc.h
|
||||||
index 372f009e8..83fd69f4a 100644
|
index 7d2b551969..fd18e6320b 100644
|
||||||
--- a/include/grub/misc.h
|
--- a/include/grub/misc.h
|
||||||
+++ b/include/grub/misc.h
|
+++ b/include/grub/misc.h
|
||||||
@@ -334,7 +334,7 @@ int EXPORT_FUNC(grub_vsnprintf) (char *str, grub_size_t n, const char *fmt,
|
@@ -353,7 +353,7 @@ int EXPORT_FUNC(grub_vsnprintf) (char *str, grub_size_t n, const char *fmt,
|
||||||
char *EXPORT_FUNC(grub_xasprintf) (const char *fmt, ...)
|
char *EXPORT_FUNC(grub_xasprintf) (const char *fmt, ...)
|
||||||
__attribute__ ((format (GNU_PRINTF, 1, 2))) WARN_UNUSED_RESULT;
|
__attribute__ ((format (GNU_PRINTF, 1, 2))) WARN_UNUSED_RESULT;
|
||||||
char *EXPORT_FUNC(grub_xvasprintf) (const char *fmt, va_list args) WARN_UNUSED_RESULT;
|
char *EXPORT_FUNC(grub_xvasprintf) (const char *fmt, va_list args) WARN_UNUSED_RESULT;
|
@ -6,30 +6,38 @@ Subject: [PATCH] Make efi machines load an env block from a variable
|
|||||||
Signed-off-by: Peter Jones <pjones@redhat.com>
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
---
|
---
|
||||||
grub-core/Makefile.core.def | 1 +
|
grub-core/Makefile.core.def | 1 +
|
||||||
grub-core/kern/efi/init.c | 34 +++++++++++++++++++++++++++++++++-
|
grub-core/kern/efi/init.c | 36 +++++++++++++++++++++++++++++++++++-
|
||||||
2 files changed, 34 insertions(+), 1 deletion(-)
|
2 files changed, 36 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
diff --git a/grub-core/Makefile.core.def b/grub-core/Makefile.core.def
|
diff --git a/grub-core/Makefile.core.def b/grub-core/Makefile.core.def
|
||||||
index e92a7ef32..f80653882 100644
|
index 45d3edaa4d..c865a08b02 100644
|
||||||
--- a/grub-core/Makefile.core.def
|
--- a/grub-core/Makefile.core.def
|
||||||
+++ b/grub-core/Makefile.core.def
|
+++ b/grub-core/Makefile.core.def
|
||||||
@@ -191,6 +191,7 @@ kernel = {
|
@@ -207,6 +207,7 @@ kernel = {
|
||||||
efi = term/efi/console.c;
|
|
||||||
efi = kern/acpi.c;
|
|
||||||
efi = kern/efi/acpi.c;
|
efi = kern/efi/acpi.c;
|
||||||
|
efi = kern/efi/sb.c;
|
||||||
|
efi = kern/lockdown.c;
|
||||||
+ efi = lib/envblk.c;
|
+ efi = lib/envblk.c;
|
||||||
i386_coreboot = kern/i386/pc/acpi.c;
|
i386_coreboot = kern/i386/pc/acpi.c;
|
||||||
i386_multiboot = kern/i386/pc/acpi.c;
|
i386_multiboot = kern/i386/pc/acpi.c;
|
||||||
i386_coreboot = kern/acpi.c;
|
i386_coreboot = kern/acpi.c;
|
||||||
diff --git a/grub-core/kern/efi/init.c b/grub-core/kern/efi/init.c
|
diff --git a/grub-core/kern/efi/init.c b/grub-core/kern/efi/init.c
|
||||||
index 3dfdf2d22..71d2279a0 100644
|
index 7facacf09c..6d39bd3ad2 100644
|
||||||
--- a/grub-core/kern/efi/init.c
|
--- a/grub-core/kern/efi/init.c
|
||||||
+++ b/grub-core/kern/efi/init.c
|
+++ b/grub-core/kern/efi/init.c
|
||||||
@@ -25,9 +25,40 @@
|
@@ -27,8 +27,11 @@
|
||||||
#include <grub/env.h>
|
#include <grub/env.h>
|
||||||
#include <grub/mm.h>
|
#include <grub/mm.h>
|
||||||
#include <grub/kernel.h>
|
#include <grub/kernel.h>
|
||||||
|
+
|
||||||
|
#include <grub/stack_protector.h>
|
||||||
|
|
||||||
+#include <grub/lib/envblk.h>
|
+#include <grub/lib/envblk.h>
|
||||||
|
+
|
||||||
|
#ifdef GRUB_STACK_PROTECTOR
|
||||||
|
|
||||||
|
static grub_efi_guid_t rng_protocol_guid = GRUB_EFI_RNG_PROTOCOL_GUID;
|
||||||
|
@@ -82,6 +85,36 @@ stack_protector_init (void)
|
||||||
|
|
||||||
grub_addr_t grub_modbase;
|
grub_addr_t grub_modbase;
|
||||||
|
|
||||||
@ -54,8 +62,8 @@ index 3dfdf2d22..71d2279a0 100644
|
|||||||
+ struct grub_envblk envblk_s = { NULL, 0 };
|
+ struct grub_envblk envblk_s = { NULL, 0 };
|
||||||
+ grub_envblk_t envblk = &envblk_s;
|
+ grub_envblk_t envblk = &envblk_s;
|
||||||
+
|
+
|
||||||
+ envblk_s.buf = grub_efi_get_variable ("GRUB_ENV", &efi_grub_guid,
|
+ grub_efi_get_variable ("GRUB_ENV", &efi_grub_guid, &envblk_s.size,
|
||||||
+ &envblk_s.size);
|
+ (void **) &envblk_s.buf);
|
||||||
+ if (!envblk_s.buf || envblk_s.size < 1)
|
+ if (!envblk_s.buf || envblk_s.size < 1)
|
||||||
+ return;
|
+ return;
|
||||||
+
|
+
|
||||||
@ -66,7 +74,7 @@ index 3dfdf2d22..71d2279a0 100644
|
|||||||
void
|
void
|
||||||
grub_efi_init (void)
|
grub_efi_init (void)
|
||||||
{
|
{
|
||||||
@@ -42,10 +73,11 @@ grub_efi_init (void)
|
@@ -108,10 +141,11 @@ grub_efi_init (void)
|
||||||
efi_call_4 (grub_efi_system_table->boot_services->set_watchdog_timer,
|
efi_call_4 (grub_efi_system_table->boot_services->set_watchdog_timer,
|
||||||
0, 0, 0, NULL);
|
0, 0, 0, NULL);
|
||||||
|
|
@ -3,8 +3,11 @@ From: Mark Hamzy <hamzy@us.ibm.com>
|
|||||||
Date: Wed, 28 Mar 2012 14:46:41 -0500
|
Date: Wed, 28 Mar 2012 14:46:41 -0500
|
||||||
Subject: [PATCH] Migrate PPC from Yaboot to Grub2
|
Subject: [PATCH] Migrate PPC from Yaboot to Grub2
|
||||||
|
|
||||||
Add configuration support for serial terminal consoles. This will set the
|
Add configuration support for serial terminal consoles. This will set
|
||||||
maximum screen size so that text is not overwritten.
|
the maximum screen size so that text is not overwritten.
|
||||||
|
|
||||||
|
Signed-off-by: Mark Hamzy <hamzy@us.ibm.com>
|
||||||
|
Signed-off-by: Robbie Harwood <rharwood@redhat.com>
|
||||||
---
|
---
|
||||||
Makefile.util.def | 7 +++
|
Makefile.util.def | 7 +++
|
||||||
util/grub.d/20_ppc_terminfo.in | 114 +++++++++++++++++++++++++++++++++++++++++
|
util/grub.d/20_ppc_terminfo.in | 114 +++++++++++++++++++++++++++++++++++++++++
|
||||||
@ -12,10 +15,10 @@ maximum screen size so that text is not overwritten.
|
|||||||
create mode 100644 util/grub.d/20_ppc_terminfo.in
|
create mode 100644 util/grub.d/20_ppc_terminfo.in
|
||||||
|
|
||||||
diff --git a/Makefile.util.def b/Makefile.util.def
|
diff --git a/Makefile.util.def b/Makefile.util.def
|
||||||
index 3180ac880..c7b775bce 100644
|
index f8b356cc1f..2c9b283a23 100644
|
||||||
--- a/Makefile.util.def
|
--- a/Makefile.util.def
|
||||||
+++ b/Makefile.util.def
|
+++ b/Makefile.util.def
|
||||||
@@ -487,6 +487,13 @@ script = {
|
@@ -508,6 +508,13 @@ script = {
|
||||||
condition = COND_HOST_LINUX;
|
condition = COND_HOST_LINUX;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -31,7 +34,7 @@ index 3180ac880..c7b775bce 100644
|
|||||||
common = util/grub.d/30_os-prober.in;
|
common = util/grub.d/30_os-prober.in;
|
||||||
diff --git a/util/grub.d/20_ppc_terminfo.in b/util/grub.d/20_ppc_terminfo.in
|
diff --git a/util/grub.d/20_ppc_terminfo.in b/util/grub.d/20_ppc_terminfo.in
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..10d665868
|
index 0000000000..10d6658682
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/util/grub.d/20_ppc_terminfo.in
|
+++ b/util/grub.d/20_ppc_terminfo.in
|
||||||
@@ -0,0 +1,114 @@
|
@@ -0,0 +1,114 @@
|
@ -8,16 +8,19 @@ found. It was originally written by Matthew Garrett, and adapted to fix the
|
|||||||
"No modules are loaded on grub2 network boot" issue:
|
"No modules are loaded on grub2 network boot" issue:
|
||||||
|
|
||||||
https://bugzilla.redhat.com/show_bug.cgi?id=857936
|
https://bugzilla.redhat.com/show_bug.cgi?id=857936
|
||||||
|
|
||||||
|
Signed-off-by: Paulo Flabiano Smorigo <pfsmorigo@br.ibm.com>
|
||||||
|
Signed-off-by: Robbie Harwood <rharwood@redhat.com>
|
||||||
---
|
---
|
||||||
grub-core/kern/main.c | 13 ++++++-------
|
grub-core/kern/main.c | 13 ++++++-------
|
||||||
grub-core/normal/main.c | 25 ++++++++++++++++++++++++-
|
grub-core/normal/main.c | 25 ++++++++++++++++++++++++-
|
||||||
2 files changed, 30 insertions(+), 8 deletions(-)
|
2 files changed, 30 insertions(+), 8 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/kern/main.c b/grub-core/kern/main.c
|
diff --git a/grub-core/kern/main.c b/grub-core/kern/main.c
|
||||||
index 9cad0c448..8ab7794c4 100644
|
index 73967e2f5b..d1de9fa687 100644
|
||||||
--- a/grub-core/kern/main.c
|
--- a/grub-core/kern/main.c
|
||||||
+++ b/grub-core/kern/main.c
|
+++ b/grub-core/kern/main.c
|
||||||
@@ -127,16 +127,15 @@ grub_set_prefix_and_root (void)
|
@@ -128,16 +128,15 @@ grub_set_prefix_and_root (void)
|
||||||
|
|
||||||
grub_machine_get_bootlocation (&fwdevice, &fwpath);
|
grub_machine_get_bootlocation (&fwdevice, &fwpath);
|
||||||
|
|
||||||
@ -41,10 +44,10 @@ index 9cad0c448..8ab7794c4 100644
|
|||||||
}
|
}
|
||||||
|
|
||||||
diff --git a/grub-core/normal/main.c b/grub-core/normal/main.c
|
diff --git a/grub-core/normal/main.c b/grub-core/normal/main.c
|
||||||
index 249e19bc7..759c475c4 100644
|
index 70614de156..62571e6dfc 100644
|
||||||
--- a/grub-core/normal/main.c
|
--- a/grub-core/normal/main.c
|
||||||
+++ b/grub-core/normal/main.c
|
+++ b/grub-core/normal/main.c
|
||||||
@@ -338,7 +338,30 @@ grub_cmd_normal (struct grub_command *cmd __attribute__ ((unused)),
|
@@ -339,7 +339,30 @@ grub_cmd_normal (struct grub_command *cmd __attribute__ ((unused)),
|
||||||
/* Guess the config filename. It is necessary to make CONFIG static,
|
/* Guess the config filename. It is necessary to make CONFIG static,
|
||||||
so that it won't get broken by longjmp. */
|
so that it won't get broken by longjmp. */
|
||||||
char *config;
|
char *config;
|
||||||
@ -59,7 +62,7 @@ index 249e19bc7..759c475c4 100644
|
|||||||
+ {
|
+ {
|
||||||
+ grub_file_t file;
|
+ grub_file_t file;
|
||||||
+
|
+
|
||||||
+ file = grub_file_open (config);
|
+ file = grub_file_open (config, GRUB_FILE_TYPE_CONFIG);
|
||||||
+ if (file)
|
+ if (file)
|
||||||
+ {
|
+ {
|
||||||
+ grub_file_close (file);
|
+ grub_file_close (file);
|
@ -3,17 +3,20 @@ From: Peter Jones <pjones@redhat.com>
|
|||||||
Date: Mon, 1 Oct 2012 13:24:37 -0400
|
Date: Mon, 1 Oct 2012 13:24:37 -0400
|
||||||
Subject: [PATCH] Pass "\x[[:hex:]][[:hex:]]" straight through unmolested.
|
Subject: [PATCH] Pass "\x[[:hex:]][[:hex:]]" straight through unmolested.
|
||||||
|
|
||||||
|
Don't munge raw spaces when we're doing our cmdline escaping (#923374)
|
||||||
|
|
||||||
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
---
|
---
|
||||||
grub-core/commands/wildcard.c | 16 +++++++++++++++-
|
grub-core/commands/wildcard.c | 16 +++++++++++++++-
|
||||||
grub-core/lib/cmdline.c | 34 ++++++++++++++++++++++++++++++++--
|
grub-core/lib/cmdline.c | 25 +++++++++++++++++++++++--
|
||||||
grub-core/script/execute.c | 43 +++++++++++++++++++++++++++++++++++++------
|
grub-core/script/execute.c | 43 +++++++++++++++++++++++++++++++++++++------
|
||||||
3 files changed, 84 insertions(+), 9 deletions(-)
|
3 files changed, 75 insertions(+), 9 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/commands/wildcard.c b/grub-core/commands/wildcard.c
|
diff --git a/grub-core/commands/wildcard.c b/grub-core/commands/wildcard.c
|
||||||
index 9b4e72766..02c46f9fd 100644
|
index cc3290311f..8f67a4be7f 100644
|
||||||
--- a/grub-core/commands/wildcard.c
|
--- a/grub-core/commands/wildcard.c
|
||||||
+++ b/grub-core/commands/wildcard.c
|
+++ b/grub-core/commands/wildcard.c
|
||||||
@@ -462,6 +462,12 @@ check_file (const char *dir, const char *basename)
|
@@ -488,6 +488,12 @@ check_file (const char *dir, const char *basename)
|
||||||
return ctx.found;
|
return ctx.found;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -26,7 +29,7 @@ index 9b4e72766..02c46f9fd 100644
|
|||||||
static void
|
static void
|
||||||
unescape (char *out, const char *in, const char *end)
|
unescape (char *out, const char *in, const char *end)
|
||||||
{
|
{
|
||||||
@@ -470,7 +476,15 @@ unescape (char *out, const char *in, const char *end)
|
@@ -496,7 +502,15 @@ unescape (char *out, const char *in, const char *end)
|
||||||
|
|
||||||
for (optr = out, iptr = in; iptr < end;)
|
for (optr = out, iptr = in; iptr < end;)
|
||||||
{
|
{
|
||||||
@ -44,7 +47,7 @@ index 9b4e72766..02c46f9fd 100644
|
|||||||
*optr++ = iptr[1];
|
*optr++ = iptr[1];
|
||||||
iptr += 2;
|
iptr += 2;
|
||||||
diff --git a/grub-core/lib/cmdline.c b/grub-core/lib/cmdline.c
|
diff --git a/grub-core/lib/cmdline.c b/grub-core/lib/cmdline.c
|
||||||
index d5e10ee87..0a5b2afb9 100644
|
index ed0b149dca..8e2294d8ff 100644
|
||||||
--- a/grub-core/lib/cmdline.c
|
--- a/grub-core/lib/cmdline.c
|
||||||
+++ b/grub-core/lib/cmdline.c
|
+++ b/grub-core/lib/cmdline.c
|
||||||
@@ -20,6 +20,12 @@
|
@@ -20,6 +20,12 @@
|
||||||
@ -75,21 +78,12 @@ index d5e10ee87..0a5b2afb9 100644
|
|||||||
size++;
|
size++;
|
||||||
else if (*c == ' ')
|
else if (*c == ' ')
|
||||||
space = 1;
|
space = 1;
|
||||||
@@ -85,7 +97,25 @@ int grub_create_loader_cmdline (int argc, char *argv[], char *buf,
|
@@ -86,7 +98,16 @@ grub_create_loader_cmdline (int argc, char *argv[], char *buf,
|
||||||
|
|
||||||
while (*c)
|
while (*c)
|
||||||
{
|
{
|
||||||
- if (*c == '\\' || *c == '\'' || *c == '"')
|
- if (*c == '\\' || *c == '\'' || *c == '"')
|
||||||
+ if (*c == ' ')
|
+ if (*c == '\\' && *(c+1) == 'x' &&
|
||||||
+ {
|
|
||||||
+ *buf++ = '\\';
|
|
||||||
+ *buf++ = 'x';
|
|
||||||
+ *buf++ = '2';
|
|
||||||
+ *buf++ = '0';
|
|
||||||
+ c++;
|
|
||||||
+ continue;
|
|
||||||
+ }
|
|
||||||
+ else if (*c == '\\' && *(c+1) == 'x' &&
|
|
||||||
+ is_hex(*(c+2)) && is_hex(*(c+3)))
|
+ is_hex(*(c+2)) && is_hex(*(c+3)))
|
||||||
+ {
|
+ {
|
||||||
+ *buf++ = *c++;
|
+ *buf++ = *c++;
|
||||||
@ -103,10 +97,10 @@ index d5e10ee87..0a5b2afb9 100644
|
|||||||
|
|
||||||
*buf++ = *c;
|
*buf++ = *c;
|
||||||
diff --git a/grub-core/script/execute.c b/grub-core/script/execute.c
|
diff --git a/grub-core/script/execute.c b/grub-core/script/execute.c
|
||||||
index ab78ca87f..cf6cd6601 100644
|
index ad80399246..0c6dd9c520 100644
|
||||||
--- a/grub-core/script/execute.c
|
--- a/grub-core/script/execute.c
|
||||||
+++ b/grub-core/script/execute.c
|
+++ b/grub-core/script/execute.c
|
||||||
@@ -55,6 +55,12 @@ static struct grub_script_scope *scope = 0;
|
@@ -56,6 +56,12 @@ static struct grub_script_scope *scope = 0;
|
||||||
/* Wildcard translator for GRUB script. */
|
/* Wildcard translator for GRUB script. */
|
||||||
struct grub_script_wildcard_translator *grub_wildcard_translator;
|
struct grub_script_wildcard_translator *grub_wildcard_translator;
|
||||||
|
|
||||||
@ -119,7 +113,7 @@ index ab78ca87f..cf6cd6601 100644
|
|||||||
static char*
|
static char*
|
||||||
wildcard_escape (const char *s)
|
wildcard_escape (const char *s)
|
||||||
{
|
{
|
||||||
@@ -71,7 +77,15 @@ wildcard_escape (const char *s)
|
@@ -72,7 +78,15 @@ wildcard_escape (const char *s)
|
||||||
i = 0;
|
i = 0;
|
||||||
while ((ch = *s++))
|
while ((ch = *s++))
|
||||||
{
|
{
|
||||||
@ -136,7 +130,7 @@ index ab78ca87f..cf6cd6601 100644
|
|||||||
p[i++] = '\\';
|
p[i++] = '\\';
|
||||||
p[i++] = ch;
|
p[i++] = ch;
|
||||||
}
|
}
|
||||||
@@ -95,7 +109,14 @@ wildcard_unescape (const char *s)
|
@@ -96,7 +110,14 @@ wildcard_unescape (const char *s)
|
||||||
i = 0;
|
i = 0;
|
||||||
while ((ch = *s++))
|
while ((ch = *s++))
|
||||||
{
|
{
|
||||||
@ -152,7 +146,7 @@ index ab78ca87f..cf6cd6601 100644
|
|||||||
p[i++] = *s++;
|
p[i++] = *s++;
|
||||||
else
|
else
|
||||||
p[i++] = ch;
|
p[i++] = ch;
|
||||||
@@ -397,10 +418,20 @@ parse_string (const char *str,
|
@@ -398,10 +419,20 @@ parse_string (const char *str,
|
||||||
switch (*ptr)
|
switch (*ptr)
|
||||||
{
|
{
|
||||||
case '\\':
|
case '\\':
|
1609
0021-blscfg-add-blscfg-module-to-parse-Boot-Loader-Specif.patch
Normal file
1609
0021-blscfg-add-blscfg-module-to-parse-Boot-Loader-Specif.patch
Normal file
File diff suppressed because it is too large
Load Diff
@ -20,10 +20,10 @@ Signed-off-by: David A. Marlin <dmarlin@redhat.com>
|
|||||||
2 files changed, 17 insertions(+), 1 deletion(-)
|
2 files changed, 17 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
diff --git a/util/grub-mkconfig.in b/util/grub-mkconfig.in
|
diff --git a/util/grub-mkconfig.in b/util/grub-mkconfig.in
|
||||||
index b0a8626dd..f68d4925e 100644
|
index d3e879b8e5..8ea2315ebc 100644
|
||||||
--- a/util/grub-mkconfig.in
|
--- a/util/grub-mkconfig.in
|
||||||
+++ b/util/grub-mkconfig.in
|
+++ b/util/grub-mkconfig.in
|
||||||
@@ -254,7 +254,8 @@ export GRUB_DEFAULT \
|
@@ -248,7 +248,8 @@ export GRUB_DEFAULT \
|
||||||
GRUB_ENABLE_CRYPTODISK \
|
GRUB_ENABLE_CRYPTODISK \
|
||||||
GRUB_BADRAM \
|
GRUB_BADRAM \
|
||||||
GRUB_OS_PROBER_SKIP_LIST \
|
GRUB_OS_PROBER_SKIP_LIST \
|
||||||
@ -34,7 +34,7 @@ index b0a8626dd..f68d4925e 100644
|
|||||||
if test "x${grub_cfg}" != "x"; then
|
if test "x${grub_cfg}" != "x"; then
|
||||||
rm -f "${grub_cfg}.new"
|
rm -f "${grub_cfg}.new"
|
||||||
diff --git a/util/grub.d/10_linux.in b/util/grub.d/10_linux.in
|
diff --git a/util/grub.d/10_linux.in b/util/grub.d/10_linux.in
|
||||||
index 87a7da349..233754ff2 100644
|
index e8b01c0d0c..dc75a1c30b 100644
|
||||||
--- a/util/grub.d/10_linux.in
|
--- a/util/grub.d/10_linux.in
|
||||||
+++ b/util/grub.d/10_linux.in
|
+++ b/util/grub.d/10_linux.in
|
||||||
@@ -153,6 +153,13 @@ EOF
|
@@ -153,6 +153,13 @@ EOF
|
@ -9,7 +9,7 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
1 file changed, 2 insertions(+)
|
1 file changed, 2 insertions(+)
|
||||||
|
|
||||||
diff --git a/util/grub.d/00_header.in b/util/grub.d/00_header.in
|
diff --git a/util/grub.d/00_header.in b/util/grub.d/00_header.in
|
||||||
index 93a90233e..858b526c9 100644
|
index 93a90233ea..858b526c92 100644
|
||||||
--- a/util/grub.d/00_header.in
|
--- a/util/grub.d/00_header.in
|
||||||
+++ b/util/grub.d/00_header.in
|
+++ b/util/grub.d/00_header.in
|
||||||
@@ -43,6 +43,8 @@ if [ "x${GRUB_DEFAULT_BUTTON}" = "xsaved" ] ; then GRUB_DEFAULT_BUTTON='${saved_
|
@@ -43,6 +43,8 @@ if [ "x${GRUB_DEFAULT_BUTTON}" = "xsaved" ] ; then GRUB_DEFAULT_BUTTON='${saved_
|
85
0024-Don-t-say-GNU-Linux-in-generated-menus.patch
Normal file
85
0024-Don-t-say-GNU-Linux-in-generated-menus.patch
Normal file
@ -0,0 +1,85 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Peter Jones <pjones@redhat.com>
|
||||||
|
Date: Mon, 14 Mar 2011 14:27:42 -0400
|
||||||
|
Subject: [PATCH] Don't say "GNU/Linux" in generated menus.
|
||||||
|
|
||||||
|
[rharwood: say it even less]
|
||||||
|
---
|
||||||
|
grub-core/normal/main.c | 2 +-
|
||||||
|
tests/util/grub-shell-tester.in | 2 +-
|
||||||
|
tests/util/grub-shell.in | 2 +-
|
||||||
|
util/grub.d/10_linux.in | 4 ++--
|
||||||
|
util/grub.d/20_linux_xen.in | 4 ++--
|
||||||
|
5 files changed, 7 insertions(+), 7 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/grub-core/normal/main.c b/grub-core/normal/main.c
|
||||||
|
index 7ca2e5400b..98372217ad 100644
|
||||||
|
--- a/grub-core/normal/main.c
|
||||||
|
+++ b/grub-core/normal/main.c
|
||||||
|
@@ -218,7 +218,7 @@ grub_normal_init_page (struct grub_term_output *term,
|
||||||
|
|
||||||
|
grub_term_cls (term);
|
||||||
|
|
||||||
|
- msg_formatted = grub_xasprintf (_("GNU GRUB version %s"), PACKAGE_VERSION);
|
||||||
|
+ msg_formatted = grub_xasprintf (_("GRUB version %s"), PACKAGE_VERSION);
|
||||||
|
if (!msg_formatted)
|
||||||
|
return;
|
||||||
|
|
||||||
|
diff --git a/tests/util/grub-shell-tester.in b/tests/util/grub-shell-tester.in
|
||||||
|
index 8a87109b15..9a4319d4f4 100644
|
||||||
|
--- a/tests/util/grub-shell-tester.in
|
||||||
|
+++ b/tests/util/grub-shell-tester.in
|
||||||
|
@@ -56,7 +56,7 @@ for option in "$@"; do
|
||||||
|
usage
|
||||||
|
exit 0 ;;
|
||||||
|
-v | --version)
|
||||||
|
- echo "$0 (GNU GRUB ${PACKAGE_VERSION})"
|
||||||
|
+ echo "$0 (GRUB ${PACKAGE_VERSION})"
|
||||||
|
exit 0 ;;
|
||||||
|
--modules=*)
|
||||||
|
ms=`echo "$option" | sed -e 's/--modules=//'`
|
||||||
|
diff --git a/tests/util/grub-shell.in b/tests/util/grub-shell.in
|
||||||
|
index 93e9f51484..ec1182bf93 100644
|
||||||
|
--- a/tests/util/grub-shell.in
|
||||||
|
+++ b/tests/util/grub-shell.in
|
||||||
|
@@ -209,7 +209,7 @@ for option in "$@"; do
|
||||||
|
usage
|
||||||
|
exit 0 ;;
|
||||||
|
-v | --version)
|
||||||
|
- echo "$0 (GNU GRUB ${PACKAGE_VERSION})"
|
||||||
|
+ echo "$0 (GRUB ${PACKAGE_VERSION})"
|
||||||
|
exit 0 ;;
|
||||||
|
--trim)
|
||||||
|
trim=1
|
||||||
|
diff --git a/util/grub.d/10_linux.in b/util/grub.d/10_linux.in
|
||||||
|
index dc75a1c30b..4a499c53a6 100644
|
||||||
|
--- a/util/grub.d/10_linux.in
|
||||||
|
+++ b/util/grub.d/10_linux.in
|
||||||
|
@@ -29,9 +29,9 @@ export TEXTDOMAINDIR="@localedir@"
|
||||||
|
CLASS="--class gnu-linux --class gnu --class os"
|
||||||
|
|
||||||
|
if [ "x${GRUB_DISTRIBUTOR}" = "x" ] ; then
|
||||||
|
- OS=GNU/Linux
|
||||||
|
+ OS="$(sed 's, release .*$,,g' /etc/system-release)"
|
||||||
|
else
|
||||||
|
- OS="${GRUB_DISTRIBUTOR} GNU/Linux"
|
||||||
|
+ OS="${GRUB_DISTRIBUTOR}"
|
||||||
|
CLASS="--class $(echo ${GRUB_DISTRIBUTOR} | tr 'A-Z' 'a-z' | cut -d' ' -f1|LC_ALL=C sed 's,[^[:alnum:]_],_,g') ${CLASS}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
diff --git a/util/grub.d/20_linux_xen.in b/util/grub.d/20_linux_xen.in
|
||||||
|
index 3b1f470492..ada20775a1 100644
|
||||||
|
--- a/util/grub.d/20_linux_xen.in
|
||||||
|
+++ b/util/grub.d/20_linux_xen.in
|
||||||
|
@@ -29,9 +29,9 @@ export TEXTDOMAINDIR="@localedir@"
|
||||||
|
CLASS="--class gnu-linux --class gnu --class os --class xen"
|
||||||
|
|
||||||
|
if [ "x${GRUB_DISTRIBUTOR}" = "x" ] ; then
|
||||||
|
- OS=GNU/Linux
|
||||||
|
+ OS="$(sed 's, release .*$,,g' /etc/system-release)"
|
||||||
|
else
|
||||||
|
- OS="${GRUB_DISTRIBUTOR} GNU/Linux"
|
||||||
|
+ OS="${GRUB_DISTRIBUTOR}"
|
||||||
|
CLASS="--class $(echo ${GRUB_DISTRIBUTOR} | tr 'A-Z' 'a-z' | cut -d' ' -f1|LC_ALL=C sed 's,[^[:alnum:]_],_,g') ${CLASS}"
|
||||||
|
fi
|
||||||
|
|
@ -8,7 +8,7 @@ Subject: [PATCH] Add .eh_frame to list of relocations stripped
|
|||||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
diff --git a/conf/Makefile.common b/conf/Makefile.common
|
diff --git a/conf/Makefile.common b/conf/Makefile.common
|
||||||
index 311da61c6..044ab3abe 100644
|
index 2a1a886f6d..191b1a70c6 100644
|
||||||
--- a/conf/Makefile.common
|
--- a/conf/Makefile.common
|
||||||
+++ b/conf/Makefile.common
|
+++ b/conf/Makefile.common
|
||||||
@@ -38,7 +38,7 @@ CFLAGS_KERNEL = $(CFLAGS_PLATFORM) -ffreestanding
|
@@ -38,7 +38,7 @@ CFLAGS_KERNEL = $(CFLAGS_PLATFORM) -ffreestanding
|
@ -14,7 +14,7 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
diff --git a/util/grub.d/10_linux.in b/util/grub.d/10_linux.in
|
diff --git a/util/grub.d/10_linux.in b/util/grub.d/10_linux.in
|
||||||
index 6299836b5..b744438e0 100644
|
index 4a499c53a6..cf8d118698 100644
|
||||||
--- a/util/grub.d/10_linux.in
|
--- a/util/grub.d/10_linux.in
|
||||||
+++ b/util/grub.d/10_linux.in
|
+++ b/util/grub.d/10_linux.in
|
||||||
@@ -26,7 +26,7 @@ datarootdir="@datarootdir@"
|
@@ -26,7 +26,7 @@ datarootdir="@datarootdir@"
|
@ -17,10 +17,10 @@ Signed-off-by: Mark Salter <msalter@redhat.com>
|
|||||||
1 file changed, 3 insertions(+), 2 deletions(-)
|
1 file changed, 3 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/normal/main.c b/grub-core/normal/main.c
|
diff --git a/grub-core/normal/main.c b/grub-core/normal/main.c
|
||||||
index 0ce59fdc3..a3713efcd 100644
|
index 98372217ad..bf24e65713 100644
|
||||||
--- a/grub-core/normal/main.c
|
--- a/grub-core/normal/main.c
|
||||||
+++ b/grub-core/normal/main.c
|
+++ b/grub-core/normal/main.c
|
||||||
@@ -343,7 +343,7 @@ grub_cmd_normal (struct grub_command *cmd __attribute__ ((unused)),
|
@@ -347,7 +347,7 @@ grub_cmd_normal (struct grub_command *cmd __attribute__ ((unused)),
|
||||||
char *config;
|
char *config;
|
||||||
const char *prefix, *fw_path;
|
const char *prefix, *fw_path;
|
||||||
|
|
||||||
@ -29,7 +29,7 @@ index 0ce59fdc3..a3713efcd 100644
|
|||||||
if (fw_path)
|
if (fw_path)
|
||||||
{
|
{
|
||||||
config = grub_xasprintf ("%s/grub.cfg", fw_path);
|
config = grub_xasprintf ("%s/grub.cfg", fw_path);
|
||||||
@@ -366,7 +366,8 @@ grub_cmd_normal (struct grub_command *cmd __attribute__ ((unused)),
|
@@ -370,7 +370,8 @@ grub_cmd_normal (struct grub_command *cmd __attribute__ ((unused)),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
127
0028-Try-mac-guid-etc-before-grub.cfg-on-tftp-config-file.patch
Normal file
127
0028-Try-mac-guid-etc-before-grub.cfg-on-tftp-config-file.patch
Normal file
@ -0,0 +1,127 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Peter Jones <pjones@redhat.com>
|
||||||
|
Date: Mon, 8 Jul 2019 17:33:22 +0200
|
||||||
|
Subject: [PATCH] Try mac/guid/etc before grub.cfg on tftp config files.
|
||||||
|
|
||||||
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
|
---
|
||||||
|
grub-core/normal/main.c | 97 ++++++++++++++++++++++++++-----------------------
|
||||||
|
1 file changed, 51 insertions(+), 46 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/grub-core/normal/main.c b/grub-core/normal/main.c
|
||||||
|
index bf24e65713..0a99768f75 100644
|
||||||
|
--- a/grub-core/normal/main.c
|
||||||
|
+++ b/grub-core/normal/main.c
|
||||||
|
@@ -345,61 +345,66 @@ grub_cmd_normal (struct grub_command *cmd __attribute__ ((unused)),
|
||||||
|
/* Guess the config filename. It is necessary to make CONFIG static,
|
||||||
|
so that it won't get broken by longjmp. */
|
||||||
|
char *config;
|
||||||
|
- const char *prefix, *fw_path;
|
||||||
|
-
|
||||||
|
- prefix = fw_path = grub_env_get ("fw_path");
|
||||||
|
- if (fw_path)
|
||||||
|
- {
|
||||||
|
- config = grub_xasprintf ("%s/grub.cfg", fw_path);
|
||||||
|
- if (config)
|
||||||
|
- {
|
||||||
|
- grub_file_t file;
|
||||||
|
-
|
||||||
|
- file = grub_file_open (config, GRUB_FILE_TYPE_CONFIG);
|
||||||
|
- if (file)
|
||||||
|
- {
|
||||||
|
- grub_file_close (file);
|
||||||
|
- grub_enter_normal_mode (config);
|
||||||
|
- }
|
||||||
|
- else
|
||||||
|
- {
|
||||||
|
- /* Ignore all errors. */
|
||||||
|
- grub_errno = 0;
|
||||||
|
- }
|
||||||
|
- grub_free (config);
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
+ const char *prefix;
|
||||||
|
+ const char *net_search_cfg;
|
||||||
|
+ int disable_net_search = 0;
|
||||||
|
|
||||||
|
+ prefix = grub_env_get ("fw_path");
|
||||||
|
if (! prefix)
|
||||||
|
prefix = grub_env_get ("prefix");
|
||||||
|
+
|
||||||
|
+ net_search_cfg = grub_env_get ("feature_net_search_cfg");
|
||||||
|
+ if (net_search_cfg && net_search_cfg[0] == 'n')
|
||||||
|
+ disable_net_search = 1;
|
||||||
|
+
|
||||||
|
if (prefix)
|
||||||
|
{
|
||||||
|
- grub_size_t config_len;
|
||||||
|
- int disable_net_search = 0;
|
||||||
|
- const char *net_search_cfg;
|
||||||
|
-
|
||||||
|
- config_len = grub_strlen (prefix) +
|
||||||
|
- sizeof ("/grub.cfg-XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX");
|
||||||
|
- config = grub_malloc (config_len);
|
||||||
|
-
|
||||||
|
- if (!config)
|
||||||
|
- goto quit;
|
||||||
|
-
|
||||||
|
- grub_snprintf (config, config_len, "%s/grub.cfg", prefix);
|
||||||
|
-
|
||||||
|
- net_search_cfg = grub_env_get ("feature_net_search_cfg");
|
||||||
|
- if (net_search_cfg && net_search_cfg[0] == 'n')
|
||||||
|
- disable_net_search = 1;
|
||||||
|
-
|
||||||
|
if (grub_strncmp (prefix + 1, "tftp", sizeof ("tftp") - 1) == 0 &&
|
||||||
|
!disable_net_search)
|
||||||
|
- grub_net_search_config_file (config);
|
||||||
|
+ {
|
||||||
|
+ grub_size_t config_len;
|
||||||
|
+ config_len = grub_strlen (prefix) +
|
||||||
|
+ sizeof ("/grub.cfg-XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX");
|
||||||
|
+ config = grub_malloc (config_len);
|
||||||
|
|
||||||
|
- grub_enter_normal_mode (config);
|
||||||
|
- grub_free (config);
|
||||||
|
- }
|
||||||
|
+ if (! config)
|
||||||
|
+ goto quit;
|
||||||
|
+
|
||||||
|
+ grub_snprintf (config, config_len, "%s/grub.cfg", prefix);
|
||||||
|
+
|
||||||
|
+ grub_net_search_configfile (config);
|
||||||
|
+
|
||||||
|
+ grub_enter_normal_mode (config);
|
||||||
|
+ grub_free (config);
|
||||||
|
+ config = NULL;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (!config)
|
||||||
|
+ {
|
||||||
|
+ config = grub_xasprintf ("%s/grub.cfg", prefix);
|
||||||
|
+ if (config)
|
||||||
|
+ {
|
||||||
|
+ grub_file_t file;
|
||||||
|
+
|
||||||
|
+ file = grub_file_open (config, GRUB_FILE_TYPE_CONFIG);
|
||||||
|
+ if (file)
|
||||||
|
+ {
|
||||||
|
+ grub_file_close (file);
|
||||||
|
+ grub_enter_normal_mode (config);
|
||||||
|
+ }
|
||||||
|
+ else
|
||||||
|
+ {
|
||||||
|
+ /* Ignore all errors. */
|
||||||
|
+ grub_errno = 0;
|
||||||
|
+ }
|
||||||
|
+ grub_free (config);
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
else
|
||||||
|
- grub_enter_normal_mode (0);
|
||||||
|
+ {
|
||||||
|
+ grub_enter_normal_mode (0);
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
else
|
||||||
|
grub_enter_normal_mode (argv[0]);
|
@ -14,7 +14,7 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
1 file changed, 2 insertions(+), 1 deletion(-)
|
1 file changed, 2 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
diff --git a/util/grub.d/10_linux.in b/util/grub.d/10_linux.in
|
diff --git a/util/grub.d/10_linux.in b/util/grub.d/10_linux.in
|
||||||
index b744438e0..43d98476b 100644
|
index cf8d118698..5f6d3c8d52 100644
|
||||||
--- a/util/grub.d/10_linux.in
|
--- a/util/grub.d/10_linux.in
|
||||||
+++ b/util/grub.d/10_linux.in
|
+++ b/util/grub.d/10_linux.in
|
||||||
@@ -29,7 +29,8 @@ export TEXTDOMAINDIR="@localedir@"
|
@@ -29,7 +29,8 @@ export TEXTDOMAINDIR="@localedir@"
|
@ -10,10 +10,10 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
1 file changed, 8 insertions(+)
|
1 file changed, 8 insertions(+)
|
||||||
|
|
||||||
diff --git a/util/grub-mkconfig_lib.in b/util/grub-mkconfig_lib.in
|
diff --git a/util/grub-mkconfig_lib.in b/util/grub-mkconfig_lib.in
|
||||||
index 1001a1223..1a4a57898 100644
|
index 301d1ac229..0f6505bf3b 100644
|
||||||
--- a/util/grub-mkconfig_lib.in
|
--- a/util/grub-mkconfig_lib.in
|
||||||
+++ b/util/grub-mkconfig_lib.in
|
+++ b/util/grub-mkconfig_lib.in
|
||||||
@@ -249,6 +249,14 @@ version_test_gt ()
|
@@ -253,6 +253,14 @@ version_test_gt ()
|
||||||
*.old:*.old) ;;
|
*.old:*.old) ;;
|
||||||
*.old:*) version_test_gt_a="`echo "$version_test_gt_a" | sed -e 's/\.old$//'`" ; version_test_gt_cmp=gt ;;
|
*.old:*) version_test_gt_a="`echo "$version_test_gt_a" | sed -e 's/\.old$//'`" ; version_test_gt_cmp=gt ;;
|
||||||
*:*.old) version_test_gt_b="`echo "$version_test_gt_b" | sed -e 's/\.old$//'`" ; version_test_gt_cmp=ge ;;
|
*:*.old) version_test_gt_b="`echo "$version_test_gt_b" | sed -e 's/\.old$//'`" ; version_test_gt_cmp=ge ;;
|
@ -1,22 +1,22 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
From: Peter Jones <pjones@redhat.com>
|
From: Peter Jones <pjones@redhat.com>
|
||||||
Date: Fri, 3 Oct 2014 11:08:03 -0400
|
Date: Tue, 9 Jul 2019 10:35:16 +0200
|
||||||
Subject: [PATCH] Try $prefix if $fw_path doesn't work.
|
Subject: [PATCH] Try $prefix if $fw_path doesn't work.
|
||||||
|
|
||||||
Related: rhbz#1148652
|
Related: rhbz#1148652
|
||||||
|
|
||||||
Signed-off-by: Peter Jones <pjones@redhat.com>
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
---
|
---
|
||||||
grub-core/kern/ieee1275/init.c | 28 +++++-----
|
grub-core/kern/ieee1275/init.c | 28 +++++----
|
||||||
grub-core/net/net.c | 2 +-
|
grub-core/net/net.c | 2 +-
|
||||||
grub-core/normal/main.c | 120 ++++++++++++++++++++---------------------
|
grub-core/normal/main.c | 134 ++++++++++++++++++++---------------------
|
||||||
3 files changed, 75 insertions(+), 75 deletions(-)
|
3 files changed, 82 insertions(+), 82 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/kern/ieee1275/init.c b/grub-core/kern/ieee1275/init.c
|
diff --git a/grub-core/kern/ieee1275/init.c b/grub-core/kern/ieee1275/init.c
|
||||||
index f5423ce27..e01bc6eab 100644
|
index e71d158416..0cd2a62723 100644
|
||||||
--- a/grub-core/kern/ieee1275/init.c
|
--- a/grub-core/kern/ieee1275/init.c
|
||||||
+++ b/grub-core/kern/ieee1275/init.c
|
+++ b/grub-core/kern/ieee1275/init.c
|
||||||
@@ -124,23 +124,25 @@ grub_machine_get_bootlocation (char **device, char **path)
|
@@ -127,23 +127,25 @@ grub_machine_get_bootlocation (char **device, char **path)
|
||||||
grub_free (canon);
|
grub_free (canon);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -56,10 +56,10 @@ index f5423ce27..e01bc6eab 100644
|
|||||||
}
|
}
|
||||||
|
|
||||||
diff --git a/grub-core/net/net.c b/grub-core/net/net.c
|
diff --git a/grub-core/net/net.c b/grub-core/net/net.c
|
||||||
index 0769bf850..16d2ce06d 100644
|
index 4d3eb5c1a5..0ef148f4ad 100644
|
||||||
--- a/grub-core/net/net.c
|
--- a/grub-core/net/net.c
|
||||||
+++ b/grub-core/net/net.c
|
+++ b/grub-core/net/net.c
|
||||||
@@ -1850,7 +1850,7 @@ grub_net_search_configfile (char *config)
|
@@ -1869,7 +1869,7 @@ grub_net_search_config_file (char *config)
|
||||||
/* Remove the remaining minus sign at the end. */
|
/* Remove the remaining minus sign at the end. */
|
||||||
config[config_len] = '\0';
|
config[config_len] = '\0';
|
||||||
|
|
||||||
@ -69,10 +69,10 @@ index 0769bf850..16d2ce06d 100644
|
|||||||
|
|
||||||
static struct grub_preboot *fini_hnd;
|
static struct grub_preboot *fini_hnd;
|
||||||
diff --git a/grub-core/normal/main.c b/grub-core/normal/main.c
|
diff --git a/grub-core/normal/main.c b/grub-core/normal/main.c
|
||||||
index 7d9c4f09b..b69f9e738 100644
|
index 0a99768f75..55558cc0b9 100644
|
||||||
--- a/grub-core/normal/main.c
|
--- a/grub-core/normal/main.c
|
||||||
+++ b/grub-core/normal/main.c
|
+++ b/grub-core/normal/main.c
|
||||||
@@ -331,74 +331,72 @@ grub_enter_normal_mode (const char *config)
|
@@ -335,81 +335,79 @@ grub_enter_normal_mode (const char *config)
|
||||||
grub_boot_time ("Exiting normal mode");
|
grub_boot_time ("Exiting normal mode");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -82,12 +82,19 @@ index 7d9c4f09b..b69f9e738 100644
|
|||||||
+ char *config;
|
+ char *config;
|
||||||
+ const char *prefix;
|
+ const char *prefix;
|
||||||
+ grub_err_t err = GRUB_ERR_FILE_NOT_FOUND;
|
+ grub_err_t err = GRUB_ERR_FILE_NOT_FOUND;
|
||||||
|
+ const char *net_search_cfg;
|
||||||
|
+ int disable_net_search = 0;
|
||||||
+
|
+
|
||||||
+ prefix = grub_env_get (variable);
|
+ prefix = grub_env_get (variable);
|
||||||
+ if (!prefix)
|
+ if (!prefix)
|
||||||
+ return GRUB_ERR_FILE_NOT_FOUND;
|
+ return GRUB_ERR_FILE_NOT_FOUND;
|
||||||
+
|
+
|
||||||
+ if (grub_strncmp (prefix + 1, "tftp", sizeof ("tftp") - 1) == 0)
|
+ net_search_cfg = grub_env_get ("feature_net_search_cfg");
|
||||||
|
+ if (net_search_cfg && net_search_cfg[0] == 'n')
|
||||||
|
+ disable_net_search = 1;
|
||||||
|
+
|
||||||
|
+ if (grub_strncmp (prefix + 1, "tftp", sizeof ("tftp") - 1) == 0 &&
|
||||||
|
+ !disable_net_search)
|
||||||
+ {
|
+ {
|
||||||
+ grub_size_t config_len;
|
+ grub_size_t config_len;
|
||||||
+ config_len = grub_strlen (prefix) +
|
+ config_len = grub_strlen (prefix) +
|
||||||
@ -98,7 +105,7 @@ index 7d9c4f09b..b69f9e738 100644
|
|||||||
+ return GRUB_ERR_FILE_NOT_FOUND;
|
+ return GRUB_ERR_FILE_NOT_FOUND;
|
||||||
+
|
+
|
||||||
+ grub_snprintf (config, config_len, "%s/grub.cfg", prefix);
|
+ grub_snprintf (config, config_len, "%s/grub.cfg", prefix);
|
||||||
+ err = grub_net_search_configfile (config);
|
+ err = grub_net_search_config_file (config);
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ if (err != GRUB_ERR_NONE)
|
+ if (err != GRUB_ERR_NONE)
|
||||||
@ -107,7 +114,7 @@ index 7d9c4f09b..b69f9e738 100644
|
|||||||
+ if (config)
|
+ if (config)
|
||||||
+ {
|
+ {
|
||||||
+ grub_file_t file;
|
+ grub_file_t file;
|
||||||
+ file = grub_file_open (config);
|
+ file = grub_file_open (config, GRUB_FILE_TYPE_CONFIG);
|
||||||
+ if (file)
|
+ if (file)
|
||||||
+ {
|
+ {
|
||||||
+ grub_file_close (file);
|
+ grub_file_close (file);
|
||||||
@ -135,14 +142,21 @@ index 7d9c4f09b..b69f9e738 100644
|
|||||||
- so that it won't get broken by longjmp. */
|
- so that it won't get broken by longjmp. */
|
||||||
- char *config;
|
- char *config;
|
||||||
- const char *prefix;
|
- const char *prefix;
|
||||||
|
- const char *net_search_cfg;
|
||||||
|
- int disable_net_search = 0;
|
||||||
-
|
-
|
||||||
- prefix = grub_env_get ("fw_path");
|
- prefix = grub_env_get ("fw_path");
|
||||||
- if (! prefix)
|
- if (! prefix)
|
||||||
- prefix = grub_env_get ("prefix");
|
- prefix = grub_env_get ("prefix");
|
||||||
-
|
-
|
||||||
|
- net_search_cfg = grub_env_get ("feature_net_search_cfg");
|
||||||
|
- if (net_search_cfg && net_search_cfg[0] == 'n')
|
||||||
|
- disable_net_search = 1;
|
||||||
|
-
|
||||||
- if (prefix)
|
- if (prefix)
|
||||||
- {
|
- {
|
||||||
- if (grub_strncmp (prefix + 1, "tftp", sizeof ("tftp") - 1) == 0)
|
- if (grub_strncmp (prefix + 1, "tftp", sizeof ("tftp") - 1) == 0 &&
|
||||||
|
- !disable_net_search)
|
||||||
- {
|
- {
|
||||||
- grub_size_t config_len;
|
- grub_size_t config_len;
|
||||||
- config_len = grub_strlen (prefix) +
|
- config_len = grub_strlen (prefix) +
|
||||||
@ -168,7 +182,7 @@ index 7d9c4f09b..b69f9e738 100644
|
|||||||
- {
|
- {
|
||||||
- grub_file_t file;
|
- grub_file_t file;
|
||||||
-
|
-
|
||||||
- file = grub_file_open (config);
|
- file = grub_file_open (config, GRUB_FILE_TYPE_CONFIG);
|
||||||
- if (file)
|
- if (file)
|
||||||
- {
|
- {
|
||||||
- grub_file_close (file);
|
- grub_file_close (file);
|
@ -12,7 +12,7 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
1 file changed, 27 insertions(+), 7 deletions(-)
|
1 file changed, 27 insertions(+), 7 deletions(-)
|
||||||
|
|
||||||
diff --git a/util/grub.d/10_linux.in b/util/grub.d/10_linux.in
|
diff --git a/util/grub.d/10_linux.in b/util/grub.d/10_linux.in
|
||||||
index 43d98476b..a8a8e2cf3 100644
|
index 5f6d3c8d52..786dbabb4a 100644
|
||||||
--- a/util/grub.d/10_linux.in
|
--- a/util/grub.d/10_linux.in
|
||||||
+++ b/util/grub.d/10_linux.in
|
+++ b/util/grub.d/10_linux.in
|
||||||
@@ -78,6 +78,32 @@ case x"$GRUB_FS" in
|
@@ -78,6 +78,32 @@ case x"$GRUB_FS" in
|
@ -8,36 +8,43 @@ without having to alter the grub.cfg. The hashed password now
|
|||||||
lives in a root-only-readable configuration file.
|
lives in a root-only-readable configuration file.
|
||||||
|
|
||||||
Resolves: rhbz#985962
|
Resolves: rhbz#985962
|
||||||
|
|
||||||
|
Signed-off-by: Robert Marshall <rmarshall@redhat.com>
|
||||||
|
[pjones: fix the efidir in grub-setpassword and rename tool]
|
||||||
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
|
[luto: fix grub-setpassword -o's output path]
|
||||||
|
Signed-off-by: Andy Lutomirski <luto@kernel.org>
|
||||||
|
[rharwood: migrate man page to h2m, context]
|
||||||
|
Signed-off-by: Robbie Harwood <rharwood@redhat.com>
|
||||||
---
|
---
|
||||||
configure.ac | 1 +
|
configure.ac | 1 +
|
||||||
Makefile.util.def | 13 +++++
|
Makefile.util.def | 13 +++++
|
||||||
.gitignore | 2 +
|
docs/man/grub-set-password.h2m | 2 +
|
||||||
util/grub-mkconfig.in | 2 +
|
util/grub-mkconfig.in | 2 +
|
||||||
util/grub-setpassword.8 | 28 +++++++++++
|
util/grub-set-password.in | 128 +++++++++++++++++++++++++++++++++++++++++
|
||||||
util/grub-setpassword.in | 123 +++++++++++++++++++++++++++++++++++++++++++++++
|
util/grub.d/01_users.in | 11 ++++
|
||||||
util/grub.d/01_users.in | 11 +++++
|
6 files changed, 157 insertions(+)
|
||||||
7 files changed, 180 insertions(+)
|
create mode 100644 docs/man/grub-set-password.h2m
|
||||||
create mode 100644 util/grub-setpassword.8
|
create mode 100644 util/grub-set-password.in
|
||||||
create mode 100644 util/grub-setpassword.in
|
|
||||||
create mode 100644 util/grub.d/01_users.in
|
create mode 100644 util/grub.d/01_users.in
|
||||||
|
|
||||||
diff --git a/configure.ac b/configure.ac
|
diff --git a/configure.ac b/configure.ac
|
||||||
index 056df1cba..679f634ce 100644
|
index 8331f95b64..7f59ad788f 100644
|
||||||
--- a/configure.ac
|
--- a/configure.ac
|
||||||
+++ b/configure.ac
|
+++ b/configure.ac
|
||||||
@@ -65,6 +65,7 @@ grub_TRANSFORM([grub-mkrelpath])
|
@@ -72,6 +72,7 @@ grub_TRANSFORM([grub-mkrelpath])
|
||||||
grub_TRANSFORM([grub-mkrescue])
|
grub_TRANSFORM([grub-mkrescue])
|
||||||
grub_TRANSFORM([grub-probe])
|
grub_TRANSFORM([grub-probe])
|
||||||
grub_TRANSFORM([grub-reboot])
|
grub_TRANSFORM([grub-reboot])
|
||||||
+grub_TRANSFORM([grub-setpassword])
|
+grub_TRANSFORM([grub-set-password])
|
||||||
grub_TRANSFORM([grub-rpm-sort])
|
|
||||||
grub_TRANSFORM([grub-script-check])
|
grub_TRANSFORM([grub-script-check])
|
||||||
grub_TRANSFORM([grub-set-default])
|
grub_TRANSFORM([grub-set-default])
|
||||||
|
grub_TRANSFORM([grub-sparc64-setup])
|
||||||
diff --git a/Makefile.util.def b/Makefile.util.def
|
diff --git a/Makefile.util.def b/Makefile.util.def
|
||||||
index 406d96861..fd91045bd 100644
|
index 2c9b283a23..4ee22c5daa 100644
|
||||||
--- a/Makefile.util.def
|
--- a/Makefile.util.def
|
||||||
+++ b/Makefile.util.def
|
+++ b/Makefile.util.def
|
||||||
@@ -440,6 +440,12 @@ script = {
|
@@ -452,6 +452,12 @@ script = {
|
||||||
installdir = grubconf;
|
installdir = grubconf;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -50,13 +57,13 @@ index 406d96861..fd91045bd 100644
|
|||||||
script = {
|
script = {
|
||||||
name = '10_windows';
|
name = '10_windows';
|
||||||
common = util/grub.d/10_windows.in;
|
common = util/grub.d/10_windows.in;
|
||||||
@@ -722,6 +728,13 @@ script = {
|
@@ -724,6 +730,13 @@ script = {
|
||||||
installdir = sbin;
|
installdir = sbin;
|
||||||
};
|
};
|
||||||
|
|
||||||
+script = {
|
+script = {
|
||||||
+ name = grub-setpassword;
|
+ name = grub-set-password;
|
||||||
+ common = util/grub-setpassword.in;
|
+ common = util/grub-set-password.in;
|
||||||
+ mansection = 8;
|
+ mansection = 8;
|
||||||
+ installdir = sbin;
|
+ installdir = sbin;
|
||||||
+};
|
+};
|
||||||
@ -64,24 +71,19 @@ index 406d96861..fd91045bd 100644
|
|||||||
script = {
|
script = {
|
||||||
name = grub-mkconfig_lib;
|
name = grub-mkconfig_lib;
|
||||||
common = util/grub-mkconfig_lib.in;
|
common = util/grub-mkconfig_lib.in;
|
||||||
diff --git a/.gitignore b/.gitignore
|
diff --git a/docs/man/grub-set-password.h2m b/docs/man/grub-set-password.h2m
|
||||||
index fa2e5b609..5066689bc 100644
|
new file mode 100644
|
||||||
--- a/.gitignore
|
index 0000000000..10ee82f4d5
|
||||||
+++ b/.gitignore
|
--- /dev/null
|
||||||
@@ -111,6 +111,8 @@ grub-*.tar.*
|
+++ b/docs/man/grub-set-password.h2m
|
||||||
/grub*-script-check.1
|
@@ -0,0 +1,2 @@
|
||||||
/grub*-set-default
|
+[NAME]
|
||||||
/grub*-set-default.8
|
+grub-set-password \- generate the user.cfg file containing the hashed grub bootloader password
|
||||||
+/grub*-setsetpassword
|
|
||||||
+/grub*-setsetpassword.8
|
|
||||||
/grub*-shell
|
|
||||||
/grub*-shell-tester
|
|
||||||
/grub*-sparc64-setup
|
|
||||||
diff --git a/util/grub-mkconfig.in b/util/grub-mkconfig.in
|
diff --git a/util/grub-mkconfig.in b/util/grub-mkconfig.in
|
||||||
index f68d4925e..bdb9982ae 100644
|
index 8ea2315ebc..ba14cf6261 100644
|
||||||
--- a/util/grub-mkconfig.in
|
--- a/util/grub-mkconfig.in
|
||||||
+++ b/util/grub-mkconfig.in
|
+++ b/util/grub-mkconfig.in
|
||||||
@@ -282,6 +282,8 @@ for i in "${grub_mkconfig_dir}"/* ; do
|
@@ -276,6 +276,8 @@ for i in "${grub_mkconfig_dir}"/* ; do
|
||||||
*~) ;;
|
*~) ;;
|
||||||
# emacsen autosave files. FIXME: support other editors
|
# emacsen autosave files. FIXME: support other editors
|
||||||
*/\#*\#) ;;
|
*/\#*\#) ;;
|
||||||
@ -90,50 +92,17 @@ index f68d4925e..bdb9982ae 100644
|
|||||||
*)
|
*)
|
||||||
if grub_file_is_not_garbage "$i" && test -x "$i" ; then
|
if grub_file_is_not_garbage "$i" && test -x "$i" ; then
|
||||||
echo
|
echo
|
||||||
diff --git a/util/grub-setpassword.8 b/util/grub-setpassword.8
|
diff --git a/util/grub-set-password.in b/util/grub-set-password.in
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..49200a848
|
index 0000000000..5ebf50576d
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/util/grub-setpassword.8
|
+++ b/util/grub-set-password.in
|
||||||
@@ -0,0 +1,28 @@
|
@@ -0,0 +1,128 @@
|
||||||
+.TH GRUB-SETPASSWORD 3 "Thu Jun 25 2015"
|
|
||||||
+.SH NAME
|
|
||||||
+\fBgrub-setpassword\fR \(em Generate the user.cfg file containing the hashed grub bootloader password.
|
|
||||||
+
|
|
||||||
+.SH SYNOPSIS
|
|
||||||
+\fBgrub-setpassword\fR [OPTION]
|
|
||||||
+
|
|
||||||
+.SH DESCRIPTION
|
|
||||||
+\fBgrub-setpassword\fR outputs the user.cfg file which contains the hashed GRUB bootloader password. This utility only supports configurations where there is a single root user.
|
|
||||||
+
|
|
||||||
+The file has the format:
|
|
||||||
+GRUB2_PASSWORD=<\fIhashed password\fR>.
|
|
||||||
+
|
|
||||||
+.SH OPTIONS
|
|
||||||
+.TP
|
|
||||||
+-h, --help
|
|
||||||
+Display program usage and exit.
|
|
||||||
+.TP
|
|
||||||
+-v, --version
|
|
||||||
+Display the current version.
|
|
||||||
+.TP
|
|
||||||
+-o, --output[=\fIDIRECTORY PATH\fR]
|
|
||||||
+Choose the file path to which user.cfg will be written.
|
|
||||||
+
|
|
||||||
+.SH SEE ALSO
|
|
||||||
+.BR "info grub"
|
|
||||||
+
|
|
||||||
+.BR "info grub2-mkpasswd-pbkdf2"
|
|
||||||
diff --git a/util/grub-setpassword.in b/util/grub-setpassword.in
|
|
||||||
new file mode 100644
|
|
||||||
index 000000000..dd76f00fc
|
|
||||||
--- /dev/null
|
|
||||||
+++ b/util/grub-setpassword.in
|
|
||||||
@@ -0,0 +1,123 @@
|
|
||||||
+#!/bin/sh -e
|
+#!/bin/sh -e
|
||||||
+
|
+
|
||||||
|
+EFIDIR=$(grep ^ID= /etc/os-release | sed -e 's/^ID=//' -e 's/rhel/redhat/')
|
||||||
+if [ -d /sys/firmware/efi/efivars/ ]; then
|
+if [ -d /sys/firmware/efi/efivars/ ]; then
|
||||||
+ grubdir=`echo "/@bootdirname@/efi/EFI/redhat/" | sed 's,//*,/,g'`
|
+ grubdir=`echo "/@bootdirname@/efi/EFI/${EFIDIR}/" | sed 's,//*,/,g'`
|
||||||
+else
|
+else
|
||||||
+ grubdir=`echo "/@bootdirname@/@grubdirname@" | sed 's,//*,/,g'`
|
+ grubdir=`echo "/@bootdirname@/@grubdirname@" | sed 's,//*,/,g'`
|
||||||
+fi
|
+fi
|
||||||
@ -148,15 +117,14 @@ index 000000000..dd76f00fc
|
|||||||
+# Print the usage.
|
+# Print the usage.
|
||||||
+usage () {
|
+usage () {
|
||||||
+ cat <<EOF
|
+ cat <<EOF
|
||||||
+Usage: $0 [OPTION] [SOURCE]
|
+Usage: $0 [OPTION]
|
||||||
+Run GRUB script in a Qemu instance.
|
+$0 prompts the user to set a password on the grub bootloader. The password
|
||||||
|
+is written to a file named user.cfg which lives in the GRUB directory
|
||||||
|
+located by default at ${grubdir}.
|
||||||
+
|
+
|
||||||
+ -h, --help print this message and exit
|
+ -h, --help print this message and exit
|
||||||
+ -v, --version print the version information and exit
|
+ -v, --version print the version information and exit
|
||||||
+ -o, --output_path choose a custom output path for user.cfg
|
+ -o, --output_path <DIRECTORY> put user.cfg in a user-selected directory
|
||||||
+
|
|
||||||
+$0 prompts the user to set a password on the grub bootloader. The password
|
|
||||||
+is written to a file named user.cfg.
|
|
||||||
+
|
+
|
||||||
+Report bugs at https://bugzilla.redhat.com.
|
+Report bugs at https://bugzilla.redhat.com.
|
||||||
+EOF
|
+EOF
|
||||||
@ -237,7 +205,7 @@ index 000000000..dd76f00fc
|
|||||||
+ P1="$1" && shift
|
+ P1="$1" && shift
|
||||||
+
|
+
|
||||||
+ ( echo ${P0} ; echo ${P1} ) | \
|
+ ( echo ${P0} ; echo ${P1} ) | \
|
||||||
+ ${grub_mkpasswd} | \
|
+ LC_ALL=C ${grub_mkpasswd} | \
|
||||||
+ grep -v '[eE]nter password:' | \
|
+ grep -v '[eE]nter password:' | \
|
||||||
+ sed -e "s/PBKDF2 hash of your password is //"
|
+ sed -e "s/PBKDF2 hash of your password is //"
|
||||||
+}
|
+}
|
||||||
@ -250,12 +218,17 @@ index 000000000..dd76f00fc
|
|||||||
+
|
+
|
||||||
+# on the ESP, these will fail to set the permissions, but it's okay because
|
+# on the ESP, these will fail to set the permissions, but it's okay because
|
||||||
+# the directory is protected.
|
+# the directory is protected.
|
||||||
+install -m 0600 /dev/null "${grubdir}/user.cfg" 2>/dev/null || :
|
+install -m 0600 /dev/null "${OUTPUT_PATH}/user.cfg" 2>/dev/null || :
|
||||||
+chmod 0600 "${grubdir}/user.cfg" 2>/dev/null || :
|
+chmod 0600 "${OUTPUT_PATH}/user.cfg" 2>/dev/null || :
|
||||||
+echo "GRUB2_PASSWORD=${MYPASS}" > "${grubdir}/user.cfg"
|
+echo "GRUB2_PASSWORD=${MYPASS}" > "${OUTPUT_PATH}/user.cfg"
|
||||||
|
+
|
||||||
|
+if ! grep -q "^### BEGIN /etc/grub.d/01_users ###$" "${OUTPUT_PATH}/grub.cfg"; then
|
||||||
|
+ echo "WARNING: The current configuration lacks password support!"
|
||||||
|
+ echo "Update your configuration with @grub_mkconfig@ to support this feature."
|
||||||
|
+fi
|
||||||
diff --git a/util/grub.d/01_users.in b/util/grub.d/01_users.in
|
diff --git a/util/grub.d/01_users.in b/util/grub.d/01_users.in
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..db2f44bfb
|
index 0000000000..db2f44bfb7
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/util/grub.d/01_users.in
|
+++ b/util/grub.d/01_users.in
|
||||||
@@ -0,0 +1,11 @@
|
@@ -0,0 +1,11 @@
|
@ -17,7 +17,7 @@ Signed-off-by: Josef Bacik <jbacik@fb.com>
|
|||||||
1 file changed, 29 insertions(+), 13 deletions(-)
|
1 file changed, 29 insertions(+), 13 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/net/tcp.c b/grub-core/net/tcp.c
|
diff --git a/grub-core/net/tcp.c b/grub-core/net/tcp.c
|
||||||
index e8ad34b84..7d4b82262 100644
|
index e8ad34b84d..7d4b822626 100644
|
||||||
--- a/grub-core/net/tcp.c
|
--- a/grub-core/net/tcp.c
|
||||||
+++ b/grub-core/net/tcp.c
|
+++ b/grub-core/net/tcp.c
|
||||||
@@ -106,6 +106,18 @@ struct tcphdr
|
@@ -106,6 +106,18 @@ struct tcphdr
|
@ -1,33 +1,25 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
From: Peter Jones <pjones@redhat.com>
|
From: Peter Jones <pjones@redhat.com>
|
||||||
Date: Wed, 8 Jun 2016 21:03:37 -0400
|
Date: Tue, 9 Jul 2019 11:47:37 +0200
|
||||||
Subject: [PATCH] efinet and bootp: add support for dhcpv6
|
Subject: [PATCH] efinet and bootp: add support for dhcpv6
|
||||||
|
|
||||||
Signed-off-by: Peter Jones <pjones@redhat.com>
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
---
|
---
|
||||||
grub-core/net/bootp.c | 174 +++++++++++++++++++++++++++++++++++++
|
grub-core/net/bootp.c | 173 +++++++++++++++++++++++++++++++++++++
|
||||||
grub-core/net/drivers/efi/efinet.c | 53 +++++++++--
|
grub-core/net/drivers/efi/efinet.c | 53 ++++++++++--
|
||||||
grub-core/net/net.c | 72 +++++++++++++++
|
grub-core/net/net.c | 72 +++++++++++++++
|
||||||
grub-core/net/tftp.c | 4 +
|
grub-core/net/tftp.c | 4 +
|
||||||
include/grub/efi/api.h | 129 +++++++++++++++++++++++++--
|
include/grub/efi/api.h | 129 +++++++++++++++++++++++++--
|
||||||
include/grub/net.h | 60 +++++++++++++
|
include/grub/net.h | 60 +++++++++++++
|
||||||
6 files changed, 478 insertions(+), 14 deletions(-)
|
6 files changed, 477 insertions(+), 14 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/net/bootp.c b/grub-core/net/bootp.c
|
diff --git a/grub-core/net/bootp.c b/grub-core/net/bootp.c
|
||||||
index f03eeab2f..da3e45446 100644
|
index 6fb5627025..e28fb6a09f 100644
|
||||||
--- a/grub-core/net/bootp.c
|
--- a/grub-core/net/bootp.c
|
||||||
+++ b/grub-core/net/bootp.c
|
+++ b/grub-core/net/bootp.c
|
||||||
@@ -23,6 +23,7 @@
|
@@ -902,6 +902,179 @@ grub_cmd_bootp (struct grub_command *cmd __attribute__ ((unused)),
|
||||||
#include <grub/net/ip.h>
|
|
||||||
#include <grub/net/netbuff.h>
|
|
||||||
#include <grub/net/udp.h>
|
|
||||||
+#include <grub/net/url.h>
|
|
||||||
#include <grub/datetime.h>
|
|
||||||
|
|
||||||
static char *
|
static grub_command_t cmd_getdhcp, cmd_bootp, cmd_dhcp;
|
||||||
@@ -349,6 +350,179 @@ grub_net_configure_by_dhcp_ack (const char *name,
|
|
||||||
return inter;
|
|
||||||
}
|
|
||||||
|
|
||||||
+struct grub_net_network_level_interface *
|
+struct grub_net_network_level_interface *
|
||||||
+grub_net_configure_by_dhcpv6_ack (const char *name,
|
+grub_net_configure_by_dhcpv6_ack (const char *name,
|
||||||
@ -203,19 +195,18 @@ index f03eeab2f..da3e45446 100644
|
|||||||
+
|
+
|
||||||
+
|
+
|
||||||
void
|
void
|
||||||
grub_net_process_dhcp (struct grub_net_buff *nb,
|
grub_bootp_init (void)
|
||||||
struct grub_net_card *card)
|
{
|
||||||
diff --git a/grub-core/net/drivers/efi/efinet.c b/grub-core/net/drivers/efi/efinet.c
|
diff --git a/grub-core/net/drivers/efi/efinet.c b/grub-core/net/drivers/efi/efinet.c
|
||||||
index 5388f952b..a4daaa460 100644
|
index 5388f952ba..173fb63153 100644
|
||||||
--- a/grub-core/net/drivers/efi/efinet.c
|
--- a/grub-core/net/drivers/efi/efinet.c
|
||||||
+++ b/grub-core/net/drivers/efi/efinet.c
|
+++ b/grub-core/net/drivers/efi/efinet.c
|
||||||
@@ -18,11 +18,15 @@
|
@@ -18,11 +18,14 @@
|
||||||
|
|
||||||
#include <grub/net/netbuff.h>
|
#include <grub/net/netbuff.h>
|
||||||
#include <grub/dl.h>
|
#include <grub/dl.h>
|
||||||
+#include <grub/env.h>
|
+#include <grub/env.h>
|
||||||
#include <grub/net.h>
|
#include <grub/net.h>
|
||||||
+#include <grub/net/url.h>
|
|
||||||
#include <grub/time.h>
|
#include <grub/time.h>
|
||||||
#include <grub/efi/api.h>
|
#include <grub/efi/api.h>
|
||||||
#include <grub/efi/efi.h>
|
#include <grub/efi/efi.h>
|
||||||
@ -225,7 +216,7 @@ index 5388f952b..a4daaa460 100644
|
|||||||
|
|
||||||
GRUB_MOD_LICENSE ("GPLv3+");
|
GRUB_MOD_LICENSE ("GPLv3+");
|
||||||
|
|
||||||
@@ -329,7 +333,7 @@ grub_efi_net_config_real (grub_efi_handle_t hnd, char **device,
|
@@ -329,7 +332,7 @@ grub_efi_net_config_real (grub_efi_handle_t hnd, char **device,
|
||||||
char **path)
|
char **path)
|
||||||
{
|
{
|
||||||
struct grub_net_card *card;
|
struct grub_net_card *card;
|
||||||
@ -234,13 +225,14 @@ index 5388f952b..a4daaa460 100644
|
|||||||
|
|
||||||
dp = grub_efi_get_device_path (hnd);
|
dp = grub_efi_get_device_path (hnd);
|
||||||
if (! dp)
|
if (! dp)
|
||||||
@@ -340,14 +344,18 @@ grub_efi_net_config_real (grub_efi_handle_t hnd, char **device,
|
@@ -340,14 +343,19 @@ grub_efi_net_config_real (grub_efi_handle_t hnd, char **device,
|
||||||
grub_efi_device_path_t *cdp;
|
grub_efi_device_path_t *cdp;
|
||||||
struct grub_efi_pxe *pxe;
|
struct grub_efi_pxe *pxe;
|
||||||
struct grub_efi_pxe_mode *pxe_mode;
|
struct grub_efi_pxe_mode *pxe_mode;
|
||||||
+
|
+
|
||||||
if (card->driver != &efidriver)
|
if (card->driver != &efidriver)
|
||||||
continue;
|
continue;
|
||||||
|
+
|
||||||
cdp = grub_efi_get_device_path (card->efi_handle);
|
cdp = grub_efi_get_device_path (card->efi_handle);
|
||||||
if (! cdp)
|
if (! cdp)
|
||||||
continue;
|
continue;
|
||||||
@ -315,10 +307,10 @@ index 5388f952b..a4daaa460 100644
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
diff --git a/grub-core/net/net.c b/grub-core/net/net.c
|
diff --git a/grub-core/net/net.c b/grub-core/net/net.c
|
||||||
index 16d2ce06d..4be228d95 100644
|
index 0ef148f4ad..22f2689aae 100644
|
||||||
--- a/grub-core/net/net.c
|
--- a/grub-core/net/net.c
|
||||||
+++ b/grub-core/net/net.c
|
+++ b/grub-core/net/net.c
|
||||||
@@ -955,6 +955,78 @@ grub_net_network_level_interface_register (struct grub_net_network_level_interfa
|
@@ -960,6 +960,78 @@ grub_net_network_level_interface_register (struct grub_net_network_level_interfa
|
||||||
grub_net_network_level_interfaces = inter;
|
grub_net_network_level_interfaces = inter;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -398,19 +390,18 @@ index 16d2ce06d..4be228d95 100644
|
|||||||
grub_err_t
|
grub_err_t
|
||||||
grub_net_add_ipv4_local (struct grub_net_network_level_interface *inter,
|
grub_net_add_ipv4_local (struct grub_net_network_level_interface *inter,
|
||||||
diff --git a/grub-core/net/tftp.c b/grub-core/net/tftp.c
|
diff --git a/grub-core/net/tftp.c b/grub-core/net/tftp.c
|
||||||
index 7d90bf66e..1157524fc 100644
|
index 7f44b30f52..4ab2f5c735 100644
|
||||||
--- a/grub-core/net/tftp.c
|
--- a/grub-core/net/tftp.c
|
||||||
+++ b/grub-core/net/tftp.c
|
+++ b/grub-core/net/tftp.c
|
||||||
@@ -379,19 +379,23 @@ tftp_open (struct grub_file *file, const char *filename)
|
@@ -358,18 +358,22 @@ tftp_open (struct grub_file *file, const char *filename)
|
||||||
return grub_errno;
|
file->not_easily_seekable = 1;
|
||||||
}
|
file->data = data;
|
||||||
|
|
||||||
+ grub_dprintf("tftp", "resolving address for %s\n", file->device->net->server);
|
+ grub_dprintf("tftp", "resolving address for %s\n", file->device->net->server);
|
||||||
err = grub_net_resolve_address (file->device->net->server, &addr);
|
err = grub_net_resolve_address (file->device->net->server, &addr);
|
||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
+ grub_dprintf("tftp", "Address resolution failed: %d\n", err);
|
+ grub_dprintf("tftp", "Address resolution failed: %d\n", err);
|
||||||
destroy_pq (data);
|
|
||||||
grub_free (data);
|
grub_free (data);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
@ -422,14 +413,14 @@ index 7d90bf66e..1157524fc 100644
|
|||||||
if (!data->sock)
|
if (!data->sock)
|
||||||
{
|
{
|
||||||
+ grub_dprintf("tftp", "connection failed\n");
|
+ grub_dprintf("tftp", "connection failed\n");
|
||||||
destroy_pq (data);
|
|
||||||
grub_free (data);
|
grub_free (data);
|
||||||
return grub_errno;
|
return grub_errno;
|
||||||
|
}
|
||||||
diff --git a/include/grub/efi/api.h b/include/grub/efi/api.h
|
diff --git a/include/grub/efi/api.h b/include/grub/efi/api.h
|
||||||
index c7c9f0e1d..28b6adf76 100644
|
index f1a52210c0..117469450d 100644
|
||||||
--- a/include/grub/efi/api.h
|
--- a/include/grub/efi/api.h
|
||||||
+++ b/include/grub/efi/api.h
|
+++ b/include/grub/efi/api.h
|
||||||
@@ -572,10 +572,16 @@ typedef void *grub_efi_handle_t;
|
@@ -592,10 +592,16 @@ typedef void *grub_efi_handle_t;
|
||||||
typedef void *grub_efi_event_t;
|
typedef void *grub_efi_event_t;
|
||||||
typedef grub_efi_uint64_t grub_efi_lba_t;
|
typedef grub_efi_uint64_t grub_efi_lba_t;
|
||||||
typedef grub_efi_uintn_t grub_efi_tpl_t;
|
typedef grub_efi_uintn_t grub_efi_tpl_t;
|
||||||
@ -450,7 +441,7 @@ index c7c9f0e1d..28b6adf76 100644
|
|||||||
typedef grub_efi_uint64_t grub_efi_physical_address_t;
|
typedef grub_efi_uint64_t grub_efi_physical_address_t;
|
||||||
typedef grub_efi_uint64_t grub_efi_virtual_address_t;
|
typedef grub_efi_uint64_t grub_efi_virtual_address_t;
|
||||||
|
|
||||||
@@ -1450,16 +1456,127 @@ struct grub_efi_simple_text_output_interface
|
@@ -1474,16 +1480,127 @@ struct grub_efi_simple_text_output_interface
|
||||||
};
|
};
|
||||||
typedef struct grub_efi_simple_text_output_interface grub_efi_simple_text_output_interface_t;
|
typedef struct grub_efi_simple_text_output_interface grub_efi_simple_text_output_interface_t;
|
||||||
|
|
||||||
@ -581,10 +572,10 @@ index c7c9f0e1d..28b6adf76 100644
|
|||||||
|
|
||||||
typedef struct grub_efi_pxe
|
typedef struct grub_efi_pxe
|
||||||
diff --git a/include/grub/net.h b/include/grub/net.h
|
diff --git a/include/grub/net.h b/include/grub/net.h
|
||||||
index 50d62ab0c..f8f3ec13a 100644
|
index 7ae4b6bd80..8a05ec4fe7 100644
|
||||||
--- a/include/grub/net.h
|
--- a/include/grub/net.h
|
||||||
+++ b/include/grub/net.h
|
+++ b/include/grub/net.h
|
||||||
@@ -442,6 +442,51 @@ struct grub_net_bootp_packet
|
@@ -447,6 +447,51 @@ struct grub_net_bootp_packet
|
||||||
grub_uint8_t vendor[0];
|
grub_uint8_t vendor[0];
|
||||||
} GRUB_PACKED;
|
} GRUB_PACKED;
|
||||||
|
|
||||||
@ -636,7 +627,7 @@ index 50d62ab0c..f8f3ec13a 100644
|
|||||||
#define GRUB_NET_BOOTP_RFC1048_MAGIC_0 0x63
|
#define GRUB_NET_BOOTP_RFC1048_MAGIC_0 0x63
|
||||||
#define GRUB_NET_BOOTP_RFC1048_MAGIC_1 0x82
|
#define GRUB_NET_BOOTP_RFC1048_MAGIC_1 0x82
|
||||||
#define GRUB_NET_BOOTP_RFC1048_MAGIC_2 0x53
|
#define GRUB_NET_BOOTP_RFC1048_MAGIC_2 0x53
|
||||||
@@ -470,6 +515,21 @@ grub_net_configure_by_dhcp_ack (const char *name,
|
@@ -482,6 +527,21 @@ grub_net_configure_by_dhcp_ack (const char *name,
|
||||||
grub_size_t size,
|
grub_size_t size,
|
||||||
int is_def, char **device, char **path);
|
int is_def, char **device, char **path);
|
||||||
|
|
@ -10,24 +10,24 @@ variables are then used by 10_linux to choose whether or not to create
|
|||||||
debug stanzas.
|
debug stanzas.
|
||||||
|
|
||||||
Resolves: rhbz#1226325
|
Resolves: rhbz#1226325
|
||||||
|
[rharwood: migrate man page to h2m]
|
||||||
---
|
---
|
||||||
configure.ac | 2 +
|
configure.ac | 1 +
|
||||||
Makefile.util.def | 7 +++
|
Makefile.util.def | 7 ++
|
||||||
.gitignore | 2 +
|
docs/man/grub-get-kernel-settings.h2m | 2 +
|
||||||
util/bash-completion.d/grub-completion.bash.in | 22 ++++++++
|
util/bash-completion.d/grub-completion.bash.in | 22 +++++++
|
||||||
util/grub-get-kernel-settings.3 | 20 +++++++
|
util/grub-get-kernel-settings.in | 88 ++++++++++++++++++++++++++
|
||||||
util/grub-get-kernel-settings.in | 78 ++++++++++++++++++++++++++
|
|
||||||
util/grub-mkconfig.in | 3 +
|
util/grub-mkconfig.in | 3 +
|
||||||
util/grub.d/10_linux.in | 23 ++++++--
|
util/grub.d/10_linux.in | 23 +++++--
|
||||||
8 files changed, 152 insertions(+), 5 deletions(-)
|
7 files changed, 141 insertions(+), 5 deletions(-)
|
||||||
create mode 100644 util/grub-get-kernel-settings.3
|
create mode 100644 docs/man/grub-get-kernel-settings.h2m
|
||||||
create mode 100644 util/grub-get-kernel-settings.in
|
create mode 100644 util/grub-get-kernel-settings.in
|
||||||
|
|
||||||
diff --git a/configure.ac b/configure.ac
|
diff --git a/configure.ac b/configure.ac
|
||||||
index 71d105696..aa06ed59c 100644
|
index 7f59ad788f..0d0e6782a1 100644
|
||||||
--- a/configure.ac
|
--- a/configure.ac
|
||||||
+++ b/configure.ac
|
+++ b/configure.ac
|
||||||
@@ -58,6 +58,7 @@ grub_TRANSFORM([grub-install])
|
@@ -65,6 +65,7 @@ grub_TRANSFORM([grub-install])
|
||||||
grub_TRANSFORM([grub-mkconfig])
|
grub_TRANSFORM([grub-mkconfig])
|
||||||
grub_TRANSFORM([grub-mkfont])
|
grub_TRANSFORM([grub-mkfont])
|
||||||
grub_TRANSFORM([grub-mkimage])
|
grub_TRANSFORM([grub-mkimage])
|
||||||
@ -35,19 +35,11 @@ index 71d105696..aa06ed59c 100644
|
|||||||
grub_TRANSFORM([grub-glue-efi])
|
grub_TRANSFORM([grub-glue-efi])
|
||||||
grub_TRANSFORM([grub-mklayout])
|
grub_TRANSFORM([grub-mklayout])
|
||||||
grub_TRANSFORM([grub-mkpasswd-pbkdf2])
|
grub_TRANSFORM([grub-mkpasswd-pbkdf2])
|
||||||
@@ -75,6 +76,7 @@ grub_TRANSFORM([grub-file])
|
|
||||||
grub_TRANSFORM([grub-bios-setup.3])
|
|
||||||
grub_TRANSFORM([grub-editenv.1])
|
|
||||||
grub_TRANSFORM([grub-fstest.3])
|
|
||||||
+grub_TRANSFORM([grub-get-kernel-settings.3])
|
|
||||||
grub_TRANSFORM([grub-glue-efi.3])
|
|
||||||
grub_TRANSFORM([grub-install.1])
|
|
||||||
grub_TRANSFORM([grub-kbdcomp.3])
|
|
||||||
diff --git a/Makefile.util.def b/Makefile.util.def
|
diff --git a/Makefile.util.def b/Makefile.util.def
|
||||||
index fd91045bd..2d032643d 100644
|
index 4ee22c5daa..18a9242776 100644
|
||||||
--- a/Makefile.util.def
|
--- a/Makefile.util.def
|
||||||
+++ b/Makefile.util.def
|
+++ b/Makefile.util.def
|
||||||
@@ -714,6 +714,13 @@ script = {
|
@@ -716,6 +716,13 @@ script = {
|
||||||
installdir = sbin;
|
installdir = sbin;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -61,21 +53,16 @@ index fd91045bd..2d032643d 100644
|
|||||||
script = {
|
script = {
|
||||||
name = grub-set-default;
|
name = grub-set-default;
|
||||||
common = util/grub-set-default.in;
|
common = util/grub-set-default.in;
|
||||||
diff --git a/.gitignore b/.gitignore
|
diff --git a/docs/man/grub-get-kernel-settings.h2m b/docs/man/grub-get-kernel-settings.h2m
|
||||||
index 5066689bc..54795fa60 100644
|
new file mode 100644
|
||||||
--- a/.gitignore
|
index 0000000000..b8051f01f3
|
||||||
+++ b/.gitignore
|
--- /dev/null
|
||||||
@@ -68,6 +68,8 @@ grub-*.tar.*
|
+++ b/docs/man/grub-get-kernel-settings.h2m
|
||||||
/grub*-fs-tester
|
@@ -0,0 +1,2 @@
|
||||||
/grub*-fstest
|
+[NAME]
|
||||||
/grub*-fstest.1
|
+grub-get-kernel-settings \- Evaluate the system's kernel installation settings for use while making a grub configuration file
|
||||||
+/grub*-get-kernel-settings
|
|
||||||
+/grub*-get-kernel-settings.3
|
|
||||||
/grub*-glue-efi
|
|
||||||
/grub*-glue-efi.1
|
|
||||||
/grub*-install
|
|
||||||
diff --git a/util/bash-completion.d/grub-completion.bash.in b/util/bash-completion.d/grub-completion.bash.in
|
diff --git a/util/bash-completion.d/grub-completion.bash.in b/util/bash-completion.d/grub-completion.bash.in
|
||||||
index 44bf135b9..5c4acd496 100644
|
index 44bf135b9f..5c4acd496d 100644
|
||||||
--- a/util/bash-completion.d/grub-completion.bash.in
|
--- a/util/bash-completion.d/grub-completion.bash.in
|
||||||
+++ b/util/bash-completion.d/grub-completion.bash.in
|
+++ b/util/bash-completion.d/grub-completion.bash.in
|
||||||
@@ -264,6 +264,28 @@ have ${__grub_sparc64_setup_program} && \
|
@@ -264,6 +264,28 @@ have ${__grub_sparc64_setup_program} && \
|
||||||
@ -107,38 +94,12 @@ index 44bf135b9..5c4acd496 100644
|
|||||||
#
|
#
|
||||||
# grub-install
|
# grub-install
|
||||||
#
|
#
|
||||||
diff --git a/util/grub-get-kernel-settings.3 b/util/grub-get-kernel-settings.3
|
|
||||||
new file mode 100644
|
|
||||||
index 000000000..ba33330e2
|
|
||||||
--- /dev/null
|
|
||||||
+++ b/util/grub-get-kernel-settings.3
|
|
||||||
@@ -0,0 +1,20 @@
|
|
||||||
+.TH GRUB-GET-KERNEL-SETTINGS 3 "Thu Jun 25 2015"
|
|
||||||
+.SH NAME
|
|
||||||
+\fBgrub-get-kernel-settings\fR \(em Evaluate the system's kernel installation settings for use while making a grub configuration file.
|
|
||||||
+
|
|
||||||
+.SH SYNOPSIS
|
|
||||||
+\fBgrub-get-kernel-settings\fR [OPTION]
|
|
||||||
+
|
|
||||||
+.SH DESCRIPTION
|
|
||||||
+\fBgrub-get-kernel-settings\fR reads the kernel installation settings on the host system, and emits a set of grub settings suitable for use when creating a grub configuration file.
|
|
||||||
+
|
|
||||||
+.SH OPTIONS
|
|
||||||
+.TP
|
|
||||||
+-h, --help
|
|
||||||
+Display program usage and exit.
|
|
||||||
+.TP
|
|
||||||
+-v, --version
|
|
||||||
+Display the current version.
|
|
||||||
+
|
|
||||||
+.SH SEE ALSO
|
|
||||||
+.BR "info grub"
|
|
||||||
diff --git a/util/grub-get-kernel-settings.in b/util/grub-get-kernel-settings.in
|
diff --git a/util/grub-get-kernel-settings.in b/util/grub-get-kernel-settings.in
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..120462198
|
index 0000000000..7e87dfccc0
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/util/grub-get-kernel-settings.in
|
+++ b/util/grub-get-kernel-settings.in
|
||||||
@@ -0,0 +1,78 @@
|
@@ -0,0 +1,88 @@
|
||||||
+#!/bin/sh
|
+#!/bin/sh
|
||||||
+set -e
|
+set -e
|
||||||
+
|
+
|
||||||
@ -217,8 +178,18 @@ index 000000000..120462198
|
|||||||
+ echo GRUB_LINUX_DEBUG_TITLE_POSTFIX=\" with debugging\"
|
+ echo GRUB_LINUX_DEBUG_TITLE_POSTFIX=\" with debugging\"
|
||||||
+ echo export GRUB_LINUX_DEBUG_TITLE_POSTFIX
|
+ echo export GRUB_LINUX_DEBUG_TITLE_POSTFIX
|
||||||
+fi
|
+fi
|
||||||
|
+if [ "$DEFAULTDEBUG" = "yes" ]; then
|
||||||
|
+ echo GRUB_DEFAULT_TO_DEBUG=true
|
||||||
|
+else
|
||||||
|
+ echo GRUB_DEFAULT_TO_DEBUG=false
|
||||||
|
+fi
|
||||||
|
+echo export GRUB_DEFAULT_TO_DEBUG
|
||||||
|
+if [ "$UPDATEDEFAULT" = "yes" ]; then
|
||||||
|
+ echo GRUB_UPDATE_DEFAULT_KERNEL=true
|
||||||
|
+ echo export GRUB_UPDATE_DEFAULT_KERNEL
|
||||||
|
+fi
|
||||||
diff --git a/util/grub-mkconfig.in b/util/grub-mkconfig.in
|
diff --git a/util/grub-mkconfig.in b/util/grub-mkconfig.in
|
||||||
index bdb9982ae..8218f3d47 100644
|
index ba14cf6261..005f093809 100644
|
||||||
--- a/util/grub-mkconfig.in
|
--- a/util/grub-mkconfig.in
|
||||||
+++ b/util/grub-mkconfig.in
|
+++ b/util/grub-mkconfig.in
|
||||||
@@ -45,6 +45,7 @@ grub_probe="${sbindir}/@grub_probe@"
|
@@ -45,6 +45,7 @@ grub_probe="${sbindir}/@grub_probe@"
|
||||||
@ -235,11 +206,11 @@ index bdb9982ae..8218f3d47 100644
|
|||||||
|
|
||||||
+eval "$("${grub_get_kernel_settings}")" || true
|
+eval "$("${grub_get_kernel_settings}")" || true
|
||||||
+
|
+
|
||||||
if [ "x$GRUB_DISABLE_UUID" != "xtrue" ]; then
|
if [ "x${GRUB_DISABLE_UUID}" = "xtrue" ]; then
|
||||||
if [ -z "$GRUB_DEVICE_UUID" ]; then
|
if [ -z "${GRUB_DISABLE_LINUX_UUID}" ]; then
|
||||||
GRUB_DEVICE_UUID="$GRUB_DEVICE_UUID_GENERATED"
|
GRUB_DISABLE_LINUX_UUID="true"
|
||||||
diff --git a/util/grub.d/10_linux.in b/util/grub.d/10_linux.in
|
diff --git a/util/grub.d/10_linux.in b/util/grub.d/10_linux.in
|
||||||
index a8a8e2cf3..4e49ccdf7 100644
|
index 786dbabb4a..292e333324 100644
|
||||||
--- a/util/grub.d/10_linux.in
|
--- a/util/grub.d/10_linux.in
|
||||||
+++ b/util/grub.d/10_linux.in
|
+++ b/util/grub.d/10_linux.in
|
||||||
@@ -111,7 +111,8 @@ linux_entry ()
|
@@ -111,7 +111,8 @@ linux_entry ()
|
||||||
@ -262,7 +233,7 @@ index a8a8e2cf3..4e49ccdf7 100644
|
|||||||
echo "menuentry '$(echo "$title" | grub_quote)' ${CLASS} \$menuentry_id_option 'gnulinux-$version-$type-$boot_device_id' {" | sed "s/^/$submenu_indentation/"
|
echo "menuentry '$(echo "$title" | grub_quote)' ${CLASS} \$menuentry_id_option 'gnulinux-$version-$type-$boot_device_id' {" | sed "s/^/$submenu_indentation/"
|
||||||
else
|
else
|
||||||
echo "menuentry '$(echo "$os" | grub_quote)' ${CLASS} \$menuentry_id_option 'gnulinux-simple-$boot_device_id' {" | sed "s/^/$submenu_indentation/"
|
echo "menuentry '$(echo "$os" | grub_quote)' ${CLASS} \$menuentry_id_option 'gnulinux-simple-$boot_device_id' {" | sed "s/^/$submenu_indentation/"
|
||||||
@@ -295,11 +299,15 @@ while [ "x$list" != "x" ] ; do
|
@@ -306,11 +310,15 @@ while [ "x$list" != "x" ] ; do
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "x$is_top_level" = xtrue ] && [ "x${GRUB_DISABLE_SUBMENU}" != xtrue ]; then
|
if [ "x$is_top_level" = xtrue ] && [ "x${GRUB_DISABLE_SUBMENU}" != xtrue ]; then
|
||||||
@ -280,7 +251,7 @@ index a8a8e2cf3..4e49ccdf7 100644
|
|||||||
if [ -z "$boot_device_id" ]; then
|
if [ -z "$boot_device_id" ]; then
|
||||||
boot_device_id="$(grub_get_device_id "${GRUB_DEVICE}")"
|
boot_device_id="$(grub_get_device_id "${GRUB_DEVICE}")"
|
||||||
fi
|
fi
|
||||||
@@ -308,10 +316,15 @@ while [ "x$list" != "x" ] ; do
|
@@ -319,10 +327,15 @@ while [ "x$list" != "x" ] ; do
|
||||||
is_top_level=false
|
is_top_level=false
|
||||||
fi
|
fi
|
||||||
|
|
@ -25,12 +25,15 @@ This patch changes it as below.
|
|||||||
0000 0000 0000 0000 0000 0011 1111 1111 # ~grub_swap_bytes32(grub_le_to_cpu32 (subnet_mask.ipv4))
|
0000 0000 0000 0000 0000 0011 1111 1111 # ~grub_swap_bytes32(grub_le_to_cpu32 (subnet_mask.ipv4))
|
||||||
|
|
||||||
The count of zero with __builtin_clz can be 22. (clz counts the number of one bits preceding the most significant zero bit)
|
The count of zero with __builtin_clz can be 22. (clz counts the number of one bits preceding the most significant zero bit)
|
||||||
|
|
||||||
|
Signed-off-by: Masahiro Matsuya <mmatsuya@redhat.com>
|
||||||
|
Signed-off-by: Robbie Harwood <rharwood@redhat.com>
|
||||||
---
|
---
|
||||||
grub-core/net/drivers/ieee1275/ofnet.c | 3 +--
|
grub-core/net/drivers/ieee1275/ofnet.c | 3 +--
|
||||||
1 file changed, 1 insertion(+), 2 deletions(-)
|
1 file changed, 1 insertion(+), 2 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/net/drivers/ieee1275/ofnet.c b/grub-core/net/drivers/ieee1275/ofnet.c
|
diff --git a/grub-core/net/drivers/ieee1275/ofnet.c b/grub-core/net/drivers/ieee1275/ofnet.c
|
||||||
index 002446be1..3df75357a 100644
|
index ac4e62a95c..3860b6f78d 100644
|
||||||
--- a/grub-core/net/drivers/ieee1275/ofnet.c
|
--- a/grub-core/net/drivers/ieee1275/ofnet.c
|
||||||
+++ b/grub-core/net/drivers/ieee1275/ofnet.c
|
+++ b/grub-core/net/drivers/ieee1275/ofnet.c
|
||||||
@@ -220,8 +220,7 @@ grub_ieee1275_parse_bootpath (const char *devpath, char *bootpath,
|
@@ -220,8 +220,7 @@ grub_ieee1275_parse_bootpath (const char *devpath, char *bootpath,
|
@ -13,10 +13,10 @@ Subject: [PATCH] Make grub_fatal() also backtrace.
|
|||||||
create mode 100644 grub-core/lib/arm64/backtrace.c
|
create mode 100644 grub-core/lib/arm64/backtrace.c
|
||||||
|
|
||||||
diff --git a/grub-core/Makefile.core.def b/grub-core/Makefile.core.def
|
diff --git a/grub-core/Makefile.core.def b/grub-core/Makefile.core.def
|
||||||
index 991891a6e..27563743b 100644
|
index c15e91943b..058c88ac3a 100644
|
||||||
--- a/grub-core/Makefile.core.def
|
--- a/grub-core/Makefile.core.def
|
||||||
+++ b/grub-core/Makefile.core.def
|
+++ b/grub-core/Makefile.core.def
|
||||||
@@ -175,6 +175,9 @@ kernel = {
|
@@ -188,6 +188,9 @@ kernel = {
|
||||||
|
|
||||||
softdiv = lib/division.c;
|
softdiv = lib/division.c;
|
||||||
|
|
||||||
@ -25,9 +25,9 @@ index 991891a6e..27563743b 100644
|
|||||||
+
|
+
|
||||||
i386 = kern/i386/dl.c;
|
i386 = kern/i386/dl.c;
|
||||||
i386_xen = kern/i386/dl.c;
|
i386_xen = kern/i386/dl.c;
|
||||||
|
i386_xen_pvh = kern/i386/dl.c;
|
||||||
diff --git a/grub-core/kern/misc.c b/grub-core/kern/misc.c
|
diff --git a/grub-core/kern/misc.c b/grub-core/kern/misc.c
|
||||||
index f1fab7000..5ce89a40c 100644
|
index 63b586d09c..a3e215155b 100644
|
||||||
--- a/grub-core/kern/misc.c
|
--- a/grub-core/kern/misc.c
|
||||||
+++ b/grub-core/kern/misc.c
|
+++ b/grub-core/kern/misc.c
|
||||||
@@ -24,6 +24,7 @@
|
@@ -24,6 +24,7 @@
|
||||||
@ -38,7 +38,7 @@ index f1fab7000..5ce89a40c 100644
|
|||||||
|
|
||||||
union printf_arg
|
union printf_arg
|
||||||
{
|
{
|
||||||
@@ -1101,8 +1102,13 @@ grub_xasprintf (const char *fmt, ...)
|
@@ -1199,8 +1200,13 @@ grub_printf_fmt_check (const char *fmt, const char *fmt_expected)
|
||||||
static void __attribute__ ((noreturn))
|
static void __attribute__ ((noreturn))
|
||||||
grub_abort (void)
|
grub_abort (void)
|
||||||
{
|
{
|
||||||
@ -55,7 +55,7 @@ index f1fab7000..5ce89a40c 100644
|
|||||||
#endif
|
#endif
|
||||||
diff --git a/grub-core/lib/arm64/backtrace.c b/grub-core/lib/arm64/backtrace.c
|
diff --git a/grub-core/lib/arm64/backtrace.c b/grub-core/lib/arm64/backtrace.c
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..1079b5380
|
index 0000000000..1079b5380e
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/grub-core/lib/arm64/backtrace.c
|
+++ b/grub-core/lib/arm64/backtrace.c
|
||||||
@@ -0,0 +1,62 @@
|
@@ -0,0 +1,62 @@
|
||||||
@ -122,7 +122,7 @@ index 000000000..1079b5380
|
|||||||
+}
|
+}
|
||||||
+
|
+
|
||||||
diff --git a/grub-core/lib/backtrace.c b/grub-core/lib/backtrace.c
|
diff --git a/grub-core/lib/backtrace.c b/grub-core/lib/backtrace.c
|
||||||
index 825a8800e..c0ad6ab8b 100644
|
index 825a8800e2..c0ad6ab8be 100644
|
||||||
--- a/grub-core/lib/backtrace.c
|
--- a/grub-core/lib/backtrace.c
|
||||||
+++ b/grub-core/lib/backtrace.c
|
+++ b/grub-core/lib/backtrace.c
|
||||||
@@ -29,6 +29,7 @@ GRUB_MOD_LICENSE ("GPLv3+");
|
@@ -29,6 +29,7 @@ GRUB_MOD_LICENSE ("GPLv3+");
|
||||||
@ -142,7 +142,7 @@ index 825a8800e..c0ad6ab8b 100644
|
|||||||
}
|
}
|
||||||
|
|
||||||
diff --git a/grub-core/lib/i386/backtrace.c b/grub-core/lib/i386/backtrace.c
|
diff --git a/grub-core/lib/i386/backtrace.c b/grub-core/lib/i386/backtrace.c
|
||||||
index c3e03c727..c67273db3 100644
|
index c3e03c7275..c67273db3a 100644
|
||||||
--- a/grub-core/lib/i386/backtrace.c
|
--- a/grub-core/lib/i386/backtrace.c
|
||||||
+++ b/grub-core/lib/i386/backtrace.c
|
+++ b/grub-core/lib/i386/backtrace.c
|
||||||
@@ -15,11 +15,23 @@
|
@@ -15,11 +15,23 @@
|
@ -1,6 +1,6 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
From: Peter Jones <pjones@redhat.com>
|
From: Peter Jones <pjones@redhat.com>
|
||||||
Date: Fri, 6 May 2016 18:43:08 -0400
|
Date: Tue, 9 Jul 2019 12:59:58 +0200
|
||||||
Subject: [PATCH] Make our info pages say "grub2" where appropriate.
|
Subject: [PATCH] Make our info pages say "grub2" where appropriate.
|
||||||
|
|
||||||
This needs to be hooked up to --program-transform=, but I haven't had
|
This needs to be hooked up to --program-transform=, but I haven't had
|
||||||
@ -9,11 +9,11 @@ time.
|
|||||||
Signed-off-by: Peter Jones <pjones@redhat.com>
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
---
|
---
|
||||||
docs/grub-dev.texi | 4 +-
|
docs/grub-dev.texi | 4 +-
|
||||||
docs/grub.texi | 318 ++++++++++++++++++++++++++---------------------------
|
docs/grub.texi | 321 ++++++++++++++++++++++++++++-------------------------
|
||||||
2 files changed, 161 insertions(+), 161 deletions(-)
|
2 files changed, 171 insertions(+), 154 deletions(-)
|
||||||
|
|
||||||
diff --git a/docs/grub-dev.texi b/docs/grub-dev.texi
|
diff --git a/docs/grub-dev.texi b/docs/grub-dev.texi
|
||||||
index a9f4de631..3ce827ab7 100644
|
index 6c629a23e2..19f708ee66 100644
|
||||||
--- a/docs/grub-dev.texi
|
--- a/docs/grub-dev.texi
|
||||||
+++ b/docs/grub-dev.texi
|
+++ b/docs/grub-dev.texi
|
||||||
@@ -1,7 +1,7 @@
|
@@ -1,7 +1,7 @@
|
||||||
@ -35,7 +35,7 @@ index a9f4de631..3ce827ab7 100644
|
|||||||
|
|
||||||
@setchapternewpage odd
|
@setchapternewpage odd
|
||||||
diff --git a/docs/grub.texi b/docs/grub.texi
|
diff --git a/docs/grub.texi b/docs/grub.texi
|
||||||
index a7155c22f..2b7b7faf8 100644
|
index 69f08d289f..0615d0ed97 100644
|
||||||
--- a/docs/grub.texi
|
--- a/docs/grub.texi
|
||||||
+++ b/docs/grub.texi
|
+++ b/docs/grub.texi
|
||||||
@@ -1,7 +1,7 @@
|
@@ -1,7 +1,7 @@
|
||||||
@ -212,7 +212,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
# @kbd{umount /mnt}
|
# @kbd{umount /mnt}
|
||||||
@end group
|
@end group
|
||||||
@end example
|
@end example
|
||||||
@@ -689,16 +689,16 @@ floppy instead of exposing the USB drive as a hard disk (they call it
|
@@ -689,30 +689,37 @@ floppy instead of exposing the USB drive as a hard disk (they call it
|
||||||
@example
|
@example
|
||||||
# @kbd{losetup /dev/loop0 /dev/sdb1}
|
# @kbd{losetup /dev/loop0 /dev/sdb1}
|
||||||
# @kbd{mount /dev/loop0 /mnt/usb}
|
# @kbd{mount /dev/loop0 /mnt/usb}
|
||||||
@ -223,17 +223,14 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
This install doesn't conflict with standard install as long as they are in
|
This install doesn't conflict with standard install as long as they are in
|
||||||
separate directories.
|
separate directories.
|
||||||
|
|
||||||
-Note that @command{grub-install} is actually just a shell script and the
|
|
||||||
-real task is done by other tools such as @command{grub-mkimage}. Therefore,
|
|
||||||
+Note that @command{grub2-install} is actually just a shell script and the
|
+Note that @command{grub2-install} is actually just a shell script and the
|
||||||
+real task is done by other tools such as @command{grub2-mkimage}. Therefore,
|
+real task is done by other tools such as @command{grub2-mkimage}. Therefore,
|
||||||
you may run those commands directly to install GRUB, without using
|
+you may run those commands directly to install GRUB, without using
|
||||||
-@command{grub-install}. Don't do that, however, unless you are very familiar
|
|
||||||
+@command{grub2-install}. Don't do that, however, unless you are very familiar
|
+@command{grub2-install}. Don't do that, however, unless you are very familiar
|
||||||
with the internals of GRUB. Installing a boot loader on a running OS may be
|
+with the internals of GRUB. Installing a boot loader on a running OS may be
|
||||||
extremely dangerous.
|
+extremely dangerous.
|
||||||
|
+
|
||||||
@@ -706,20 +706,20 @@ On EFI systems for fixed disk install you have to mount EFI System Partition.
|
On EFI systems for fixed disk install you have to mount EFI System Partition.
|
||||||
If you mount it at @file{/boot/efi} then you don't need any special arguments:
|
If you mount it at @file{/boot/efi} then you don't need any special arguments:
|
||||||
|
|
||||||
@example
|
@example
|
||||||
@ -257,7 +254,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
@end example
|
@end example
|
||||||
|
|
||||||
@node Making a GRUB bootable CD-ROM
|
@node Making a GRUB bootable CD-ROM
|
||||||
@@ -739,10 +739,10 @@ usually also need to include a configuration file @file{grub.cfg} and some
|
@@ -732,10 +739,10 @@ usually also need to include a configuration file @file{grub.cfg} and some
|
||||||
other GRUB modules.
|
other GRUB modules.
|
||||||
|
|
||||||
To make a simple generic GRUB rescue CD, you can use the
|
To make a simple generic GRUB rescue CD, you can use the
|
||||||
@ -270,7 +267,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
@end example
|
@end example
|
||||||
|
|
||||||
You will often need to include other files in your image. To do this, first
|
You will often need to include other files in your image. To do this, first
|
||||||
@@ -765,7 +765,7 @@ directory @file{iso/}.
|
@@ -758,7 +765,7 @@ directory @file{iso/}.
|
||||||
Finally, make the image:
|
Finally, make the image:
|
||||||
|
|
||||||
@example
|
@example
|
||||||
@ -279,7 +276,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
@end example
|
@end example
|
||||||
|
|
||||||
This produces a file named @file{grub.iso}, which then can be burned
|
This produces a file named @file{grub.iso}, which then can be burned
|
||||||
@@ -781,7 +781,7 @@ storage devices.
|
@@ -774,7 +781,7 @@ storage devices.
|
||||||
@node Device map
|
@node Device map
|
||||||
@section The map between BIOS drives and OS devices
|
@section The map between BIOS drives and OS devices
|
||||||
|
|
||||||
@ -288,7 +285,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
etc.) read it to map BIOS drives to OS devices. This file consists of lines
|
etc.) read it to map BIOS drives to OS devices. This file consists of lines
|
||||||
like this:
|
like this:
|
||||||
|
|
||||||
@@ -1225,23 +1225,23 @@ need to write the whole thing by hand.
|
@@ -1254,23 +1261,23 @@ need to write the whole thing by hand.
|
||||||
@node Simple configuration
|
@node Simple configuration
|
||||||
@section Simple configuration handling
|
@section Simple configuration handling
|
||||||
|
|
||||||
@ -317,7 +314,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
valid POSIX shell input; normally, it will just be a sequence of
|
valid POSIX shell input; normally, it will just be a sequence of
|
||||||
@samp{KEY=value} lines, but if the value contains spaces or other special
|
@samp{KEY=value} lines, but if the value contains spaces or other special
|
||||||
characters then it must be quoted. For example:
|
characters then it must be quoted. For example:
|
||||||
@@ -1279,7 +1279,7 @@ works it's not recommended since titles often contain unstable device names
|
@@ -1308,7 +1315,7 @@ works it's not recommended since titles often contain unstable device names
|
||||||
and may be translated
|
and may be translated
|
||||||
|
|
||||||
If you set this to @samp{saved}, then the default menu entry will be that
|
If you set this to @samp{saved}, then the default menu entry will be that
|
||||||
@ -326,7 +323,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
the environment block, which may not be available in all situations
|
the environment block, which may not be available in all situations
|
||||||
(@pxref{Environment block}).
|
(@pxref{Environment block}).
|
||||||
|
|
||||||
@@ -1290,7 +1290,7 @@ If this option is set to @samp{true}, then, when an entry is selected, save
|
@@ -1319,7 +1326,7 @@ If this option is set to @samp{true}, then, when an entry is selected, save
|
||||||
it as a new default entry for use by future runs of GRUB. This is only
|
it as a new default entry for use by future runs of GRUB. This is only
|
||||||
useful if @samp{GRUB_DEFAULT=saved}; it is a separate option because
|
useful if @samp{GRUB_DEFAULT=saved}; it is a separate option because
|
||||||
@samp{GRUB_DEFAULT=saved} is useful without this option, in conjunction with
|
@samp{GRUB_DEFAULT=saved} is useful without this option, in conjunction with
|
||||||
@ -335,7 +332,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
This option relies on the environment block, which may not be available in
|
This option relies on the environment block, which may not be available in
|
||||||
all situations (@pxref{Environment block}).
|
all situations (@pxref{Environment block}).
|
||||||
|
|
||||||
@@ -1420,7 +1420,7 @@ intel-uc.img intel-ucode.img amd-uc.img amd-ucode.img early_ucode.cpio microcode
|
@@ -1449,7 +1456,7 @@ intel-uc.img intel-ucode.img amd-uc.img amd-ucode.img early_ucode.cpio microcode
|
||||||
@end example
|
@end example
|
||||||
|
|
||||||
@item GRUB_DISABLE_LINUX_UUID
|
@item GRUB_DISABLE_LINUX_UUID
|
||||||
@ -344,7 +341,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
universally-unique identifiers (UUIDs) to identify the root filesystem to
|
universally-unique identifiers (UUIDs) to identify the root filesystem to
|
||||||
the Linux kernel, using a @samp{root=UUID=...} kernel parameter. This is
|
the Linux kernel, using a @samp{root=UUID=...} kernel parameter. This is
|
||||||
usually more reliable, but in some cases it may not be appropriate. To
|
usually more reliable, but in some cases it may not be appropriate. To
|
||||||
@@ -1442,7 +1442,7 @@ If this option is set to @samp{true}, disable the generation of recovery
|
@@ -1471,7 +1478,7 @@ If this option is set to @samp{true}, disable the generation of recovery
|
||||||
mode menu entries.
|
mode menu entries.
|
||||||
|
|
||||||
@item GRUB_DISABLE_UUID
|
@item GRUB_DISABLE_UUID
|
||||||
@ -353,7 +350,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
universally-unique identifiers (UUIDs) to identify various filesystems to
|
universally-unique identifiers (UUIDs) to identify various filesystems to
|
||||||
search for files. This is usually more reliable, but in some cases it may
|
search for files. This is usually more reliable, but in some cases it may
|
||||||
not be appropriate. To disable this use of UUIDs, set this option to
|
not be appropriate. To disable this use of UUIDs, set this option to
|
||||||
@@ -1451,12 +1451,12 @@ not be appropriate. To disable this use of UUIDs, set this option to
|
@@ -1482,12 +1489,12 @@ not be appropriate. To disable this use of UUIDs, set this option to
|
||||||
@item GRUB_VIDEO_BACKEND
|
@item GRUB_VIDEO_BACKEND
|
||||||
If graphical video support is required, either because the @samp{gfxterm}
|
If graphical video support is required, either because the @samp{gfxterm}
|
||||||
graphical terminal is in use or because @samp{GRUB_GFXPAYLOAD_LINUX} is set,
|
graphical terminal is in use or because @samp{GRUB_GFXPAYLOAD_LINUX} is set,
|
||||||
@ -369,7 +366,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
|
|
||||||
@item GRUB_GFXMODE
|
@item GRUB_GFXMODE
|
||||||
Set the resolution used on the @samp{gfxterm} graphical terminal. Note that
|
Set the resolution used on the @samp{gfxterm} graphical terminal. Note that
|
||||||
@@ -1488,7 +1488,7 @@ boot sequence. If you have problems, set this option to @samp{text} and
|
@@ -1519,7 +1526,7 @@ boot sequence. If you have problems, set this option to @samp{text} and
|
||||||
GRUB will tell Linux to boot in normal text mode.
|
GRUB will tell Linux to boot in normal text mode.
|
||||||
|
|
||||||
@item GRUB_DISABLE_OS_PROBER
|
@item GRUB_DISABLE_OS_PROBER
|
||||||
@ -378,7 +375,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
@command{os-prober} program, if installed, to discover other operating
|
@command{os-prober} program, if installed, to discover other operating
|
||||||
systems installed on the same system and generate appropriate menu entries
|
systems installed on the same system and generate appropriate menu entries
|
||||||
for them. Set this option to @samp{true} to disable this.
|
for them. Set this option to @samp{true} to disable this.
|
||||||
@@ -1498,7 +1498,7 @@ List of space-separated FS UUIDs of filesystems to be ignored from os-prober
|
@@ -1529,7 +1536,7 @@ List of space-separated FS UUIDs of filesystems to be ignored from os-prober
|
||||||
output. For efi chainloaders it's <UUID>@@<EFI FILE>
|
output. For efi chainloaders it's <UUID>@@<EFI FILE>
|
||||||
|
|
||||||
@item GRUB_DISABLE_SUBMENU
|
@item GRUB_DISABLE_SUBMENU
|
||||||
@ -387,7 +384,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
the kernel with highest version number and put all other found kernels
|
the kernel with highest version number and put all other found kernels
|
||||||
or alternative menu entries for recovery mode in submenu. For entries returned
|
or alternative menu entries for recovery mode in submenu. For entries returned
|
||||||
by @command{os-prober} first entry will be put on top level and all others
|
by @command{os-prober} first entry will be put on top level and all others
|
||||||
@@ -1506,11 +1506,11 @@ in submenu. If this option is set to @samp{y}, flat menu with all entries
|
@@ -1537,11 +1544,11 @@ in submenu. If this option is set to @samp{true}, flat menu with all entries
|
||||||
on top level will be generated instead. Changing this option will require
|
on top level will be generated instead. Changing this option will require
|
||||||
changing existing values of @samp{GRUB_DEFAULT}, @samp{fallback} (@pxref{fallback})
|
changing existing values of @samp{GRUB_DEFAULT}, @samp{fallback} (@pxref{fallback})
|
||||||
and @samp{default} (@pxref{default}) environment variables as well as saved
|
and @samp{default} (@pxref{default}) environment variables as well as saved
|
||||||
@ -402,7 +399,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
check for encrypted disks and generate additional commands needed to access
|
check for encrypted disks and generate additional commands needed to access
|
||||||
them during boot. Note that in this case unattended boot is not possible
|
them during boot. Note that in this case unattended boot is not possible
|
||||||
because GRUB will wait for passphrase to unlock encrypted container.
|
because GRUB will wait for passphrase to unlock encrypted container.
|
||||||
@@ -1569,7 +1569,7 @@ confusing @samp{GRUB_TIMEOUT_STYLE=countdown} or
|
@@ -1600,7 +1607,7 @@ confusing @samp{GRUB_TIMEOUT_STYLE=countdown} or
|
||||||
|
|
||||||
@end table
|
@end table
|
||||||
|
|
||||||
@ -411,7 +408,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
edit the scripts in @file{/etc/grub.d} directly.
|
edit the scripts in @file{/etc/grub.d} directly.
|
||||||
@file{/etc/grub.d/40_custom} is particularly useful for adding entire custom
|
@file{/etc/grub.d/40_custom} is particularly useful for adding entire custom
|
||||||
menu entries; simply type the menu entries you want to add at the end of
|
menu entries; simply type the menu entries you want to add at the end of
|
||||||
@@ -1831,7 +1831,7 @@ images as well.
|
@@ -1862,7 +1869,7 @@ images as well.
|
||||||
Mount this partition on/mnt/boot and disable GRUB in all OSes and manually
|
Mount this partition on/mnt/boot and disable GRUB in all OSes and manually
|
||||||
install self-compiled latest GRUB with:
|
install self-compiled latest GRUB with:
|
||||||
|
|
||||||
@ -420,7 +417,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
|
|
||||||
In all the OSes install GRUB tools but disable installing GRUB in bootsector,
|
In all the OSes install GRUB tools but disable installing GRUB in bootsector,
|
||||||
so you'll have menu.lst and grub.cfg available for use. Also disable os-prober
|
so you'll have menu.lst and grub.cfg available for use. Also disable os-prober
|
||||||
@@ -1841,20 +1841,20 @@ use by setting:
|
@@ -1872,20 +1879,20 @@ use by setting:
|
||||||
|
|
||||||
in /etc/default/grub
|
in /etc/default/grub
|
||||||
|
|
||||||
@ -444,7 +441,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
@}
|
@}
|
||||||
|
|
||||||
menuentry "Windows XP" @{
|
menuentry "Windows XP" @{
|
||||||
@@ -1917,15 +1917,15 @@ GRUB supports embedding a configuration file directly into the core image,
|
@@ -1948,15 +1955,15 @@ GRUB supports embedding a configuration file directly into the core image,
|
||||||
so that it is loaded before entering normal mode. This is useful, for
|
so that it is loaded before entering normal mode. This is useful, for
|
||||||
example, when it is not straightforward to find the real configuration file,
|
example, when it is not straightforward to find the real configuration file,
|
||||||
or when you need to debug problems with loading that file.
|
or when you need to debug problems with loading that file.
|
||||||
@ -463,7 +460,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
|
|
||||||
After the embedded configuration file (if any) is executed, GRUB will load
|
After the embedded configuration file (if any) is executed, GRUB will load
|
||||||
the @samp{normal} module (@pxref{normal}), which will then read the real
|
the @samp{normal} module (@pxref{normal}), which will then read the real
|
||||||
@@ -1960,13 +1960,13 @@ included in the core image:
|
@@ -1991,13 +1998,13 @@ included in the core image:
|
||||||
@example
|
@example
|
||||||
@group
|
@group
|
||||||
search.fs_label grub root
|
search.fs_label grub root
|
||||||
@ -481,7 +478,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
else
|
else
|
||||||
echo "Could not find an example configuration file!"
|
echo "Could not find an example configuration file!"
|
||||||
fi
|
fi
|
||||||
@@ -2490,7 +2490,7 @@ grub-mknetdir --net-directory=/srv/tftp --subdir=/boot/grub -d /usr/lib/grub/i38
|
@@ -2521,7 +2528,7 @@ grub-mknetdir --net-directory=/srv/tftp --subdir=/boot/grub -d /usr/lib/grub/i38
|
||||||
@end group
|
@end group
|
||||||
@end example
|
@end example
|
||||||
|
|
||||||
@ -490,7 +487,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
server.
|
server.
|
||||||
|
|
||||||
The grub.cfg file is placed in the same directory as the path output by
|
The grub.cfg file is placed in the same directory as the path output by
|
||||||
@@ -2675,7 +2675,7 @@ team are:
|
@@ -2715,7 +2722,7 @@ team are:
|
||||||
@end table
|
@end table
|
||||||
|
|
||||||
To take full advantage of this function, install GRUB into the MBR
|
To take full advantage of this function, install GRUB into the MBR
|
||||||
@ -499,7 +496,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
|
|
||||||
If you have a laptop which has a similar feature and not in the above list
|
If you have a laptop which has a similar feature and not in the above list
|
||||||
could you figure your address and contribute?
|
could you figure your address and contribute?
|
||||||
@@ -2736,7 +2736,7 @@ bytes.
|
@@ -2776,7 +2783,7 @@ bytes.
|
||||||
The sole function of @file{boot.img} is to read the first sector of the core
|
The sole function of @file{boot.img} is to read the first sector of the core
|
||||||
image from a local disk and jump to it. Because of the size restriction,
|
image from a local disk and jump to it. Because of the size restriction,
|
||||||
@file{boot.img} cannot understand any file system structure, so
|
@file{boot.img} cannot understand any file system structure, so
|
||||||
@ -508,7 +505,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
core image into @file{boot.img} when installing GRUB.
|
core image into @file{boot.img} when installing GRUB.
|
||||||
|
|
||||||
@item diskboot.img
|
@item diskboot.img
|
||||||
@@ -2766,7 +2766,7 @@ images.
|
@@ -2806,7 +2813,7 @@ images.
|
||||||
|
|
||||||
@item core.img
|
@item core.img
|
||||||
This is the core image of GRUB. It is built dynamically from the kernel
|
This is the core image of GRUB. It is built dynamically from the kernel
|
||||||
@ -517,7 +514,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
program. Usually, it contains enough modules to access @file{/boot/grub},
|
program. Usually, it contains enough modules to access @file{/boot/grub},
|
||||||
and loads everything else (including menu handling, the ability to load
|
and loads everything else (including menu handling, the ability to load
|
||||||
target operating systems, and so on) from the file system at run-time. The
|
target operating systems, and so on) from the file system at run-time. The
|
||||||
@@ -2818,7 +2818,7 @@ GRUB 2 has no single Stage 2 image. Instead, it loads modules from
|
@@ -2858,7 +2865,7 @@ GRUB 2 has no single Stage 2 image. Instead, it loads modules from
|
||||||
In GRUB 2, images for booting from CD-ROM drives are now constructed using
|
In GRUB 2, images for booting from CD-ROM drives are now constructed using
|
||||||
@file{cdboot.img} and @file{core.img}, making sure that the core image
|
@file{cdboot.img} and @file{core.img}, making sure that the core image
|
||||||
contains the @samp{iso9660} module. It is usually best to use the
|
contains the @samp{iso9660} module. It is usually best to use the
|
||||||
@ -526,7 +523,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
|
|
||||||
@item nbgrub
|
@item nbgrub
|
||||||
There is as yet no equivalent for @file{nbgrub} in GRUB 2; it was used by
|
There is as yet no equivalent for @file{nbgrub} in GRUB 2; it was used by
|
||||||
@@ -2974,8 +2974,8 @@ There are two ways to specify files, by @dfn{absolute file name} and by
|
@@ -3014,8 +3021,8 @@ There are two ways to specify files, by @dfn{absolute file name} and by
|
||||||
|
|
||||||
An absolute file name resembles a Unix absolute file name, using
|
An absolute file name resembles a Unix absolute file name, using
|
||||||
@samp{/} for the directory separator (not @samp{\} as in DOS). One
|
@samp{/} for the directory separator (not @samp{\} as in DOS). One
|
||||||
@ -537,7 +534,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
disk. If you omit the device name in an absolute file name, GRUB uses
|
disk. If you omit the device name in an absolute file name, GRUB uses
|
||||||
GRUB's @dfn{root device} implicitly. So if you set the root device to,
|
GRUB's @dfn{root device} implicitly. So if you set the root device to,
|
||||||
say, @samp{(hd1,1)} by the command @samp{set root=(hd1,1)} (@pxref{set}),
|
say, @samp{(hd1,1)} by the command @samp{set root=(hd1,1)} (@pxref{set}),
|
||||||
@@ -2983,8 +2983,8 @@ then @code{/boot/kernel} is the same as @code{(hd1,1)/boot/kernel}.
|
@@ -3023,8 +3030,8 @@ then @code{/boot/kernel} is the same as @code{(hd1,1)/boot/kernel}.
|
||||||
|
|
||||||
On ZFS filesystem the first path component must be
|
On ZFS filesystem the first path component must be
|
||||||
@var{volume}@samp{@@}[@var{snapshot}].
|
@var{volume}@samp{@@}[@var{snapshot}].
|
||||||
@ -548,7 +545,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
@samp{snap-129}. Trailing @samp{@@} after volume name is mandatory even if
|
@samp{snap-129}. Trailing @samp{@@} after volume name is mandatory even if
|
||||||
snapshot name is omitted.
|
snapshot name is omitted.
|
||||||
|
|
||||||
@@ -3387,7 +3387,7 @@ The more recent release of Minix would then be identified as
|
@@ -3427,7 +3434,7 @@ The more recent release of Minix would then be identified as
|
||||||
@samp{other>minix>minix-3.4.0}.
|
@samp{other>minix>minix-3.4.0}.
|
||||||
|
|
||||||
This variable is often set by @samp{GRUB_DEFAULT} (@pxref{Simple
|
This variable is often set by @samp{GRUB_DEFAULT} (@pxref{Simple
|
||||||
@ -557,7 +554,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
|
|
||||||
|
|
||||||
@node fallback
|
@node fallback
|
||||||
@@ -3477,7 +3477,7 @@ If this variable is set, it names the language code that the
|
@@ -3517,7 +3524,7 @@ If this variable is set, it names the language code that the
|
||||||
example, French would be named as @samp{fr}, and Simplified Chinese as
|
example, French would be named as @samp{fr}, and Simplified Chinese as
|
||||||
@samp{zh_CN}.
|
@samp{zh_CN}.
|
||||||
|
|
||||||
@ -566,7 +563,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
reasonable default for this variable based on the system locale.
|
reasonable default for this variable based on the system locale.
|
||||||
|
|
||||||
|
|
||||||
@@ -3485,10 +3485,10 @@ reasonable default for this variable based on the system locale.
|
@@ -3525,10 +3532,10 @@ reasonable default for this variable based on the system locale.
|
||||||
@subsection locale_dir
|
@subsection locale_dir
|
||||||
|
|
||||||
If this variable is set, it names the directory where translation files may
|
If this variable is set, it names the directory where translation files may
|
||||||
@ -579,7 +576,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
default for this variable if internationalization is needed and any
|
default for this variable if internationalization is needed and any
|
||||||
translation files are available.
|
translation files are available.
|
||||||
|
|
||||||
@@ -3606,7 +3606,7 @@ input. The default is not to pause output.
|
@@ -3646,7 +3653,7 @@ input. The default is not to pause output.
|
||||||
|
|
||||||
The location of the @samp{/boot/grub} directory as an absolute file name
|
The location of the @samp{/boot/grub} directory as an absolute file name
|
||||||
(@pxref{File name syntax}). This is normally set by GRUB at startup based
|
(@pxref{File name syntax}). This is normally set by GRUB at startup based
|
||||||
@ -588,7 +585,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
dynamically loaded from this directory, so it must be set correctly in order
|
dynamically loaded from this directory, so it must be set correctly in order
|
||||||
for many parts of GRUB to work.
|
for many parts of GRUB to work.
|
||||||
|
|
||||||
@@ -3697,17 +3697,17 @@ GRUB provides an ``environment block'' which can be used to save a small
|
@@ -3737,17 +3744,17 @@ GRUB provides an ``environment block'' which can be used to save a small
|
||||||
amount of state.
|
amount of state.
|
||||||
|
|
||||||
The environment block is a preallocated 1024-byte file, which normally lives
|
The environment block is a preallocated 1024-byte file, which normally lives
|
||||||
@ -609,7 +606,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
@samp{GRUB_SAVEDEFAULT} (@pxref{Simple configuration}).
|
@samp{GRUB_SAVEDEFAULT} (@pxref{Simple configuration}).
|
||||||
|
|
||||||
|
|
||||||
@@ -4396,7 +4396,7 @@ Translate @var{string} into the current language.
|
@@ -4476,7 +4483,7 @@ Translate @var{string} into the current language.
|
||||||
|
|
||||||
The current language code is stored in the @samp{lang} variable in GRUB's
|
The current language code is stored in the @samp{lang} variable in GRUB's
|
||||||
environment (@pxref{lang}). Translation files in MO format are read from
|
environment (@pxref{lang}). Translation files in MO format are read from
|
||||||
@ -618,7 +615,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
@end deffn
|
@end deffn
|
||||||
|
|
||||||
|
|
||||||
@@ -4791,7 +4791,7 @@ Define a user named @var{user} with password @var{clear-password}.
|
@@ -4871,7 +4878,7 @@ Define a user named @var{user} with password @var{clear-password}.
|
||||||
|
|
||||||
@deffn Command password_pbkdf2 user hashed-password
|
@deffn Command password_pbkdf2 user hashed-password
|
||||||
Define a user named @var{user} with password hash @var{hashed-password}.
|
Define a user named @var{user} with password hash @var{hashed-password}.
|
||||||
@ -627,7 +624,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
to generate password hashes. @xref{Security}.
|
to generate password hashes. @xref{Security}.
|
||||||
@end deffn
|
@end deffn
|
||||||
|
|
||||||
@@ -5614,8 +5614,8 @@ The @samp{password} (@pxref{password}) and @samp{password_pbkdf2}
|
@@ -5814,8 +5821,8 @@ The @samp{password} (@pxref{password}) and @samp{password_pbkdf2}
|
||||||
which has an associated password. @samp{password} sets the password in
|
which has an associated password. @samp{password} sets the password in
|
||||||
plain text, requiring @file{grub.cfg} to be secure; @samp{password_pbkdf2}
|
plain text, requiring @file{grub.cfg} to be secure; @samp{password_pbkdf2}
|
||||||
sets the password hashed using the Password-Based Key Derivation Function
|
sets the password hashed using the Password-Based Key Derivation Function
|
||||||
@ -638,7 +635,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
|
|
||||||
In order to enable authentication support, the @samp{superusers} environment
|
In order to enable authentication support, the @samp{superusers} environment
|
||||||
variable must be set to a list of usernames, separated by any of spaces,
|
variable must be set to a list of usernames, separated by any of spaces,
|
||||||
@@ -5659,7 +5659,7 @@ menuentry "May be run by user1 or a superuser" --users user1 @{
|
@@ -5860,7 +5867,7 @@ menuentry "May be run by user1 or a superuser" --users user1 @{
|
||||||
@end group
|
@end group
|
||||||
@end example
|
@end example
|
||||||
|
|
||||||
@ -647,28 +644,26 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
generating configuration files with authentication. You can use
|
generating configuration files with authentication. You can use
|
||||||
@file{/etc/grub.d/40_custom} to add simple superuser authentication, by
|
@file{/etc/grub.d/40_custom} to add simple superuser authentication, by
|
||||||
adding @kbd{set superusers=} and @kbd{password} or @kbd{password_pbkdf2}
|
adding @kbd{set superusers=} and @kbd{password} or @kbd{password_pbkdf2}
|
||||||
@@ -5684,15 +5684,15 @@ verified with a public key currently trusted by GRUB
|
@@ -5887,7 +5894,17 @@ may halt or otherwise impact the boot process.
|
||||||
validation fails, then file @file{foo} cannot be opened. This failure
|
|
||||||
may halt or otherwise impact the boot process.
|
|
||||||
|
|
||||||
-@comment Unfortunately --pubkey is not yet supported by grub-install,
|
An initial trusted public key can be embedded within the GRUB @file{core.img}
|
||||||
-@comment but we should not bring up internal detail grub-mkimage here
|
using the @code{--pubkey} option to @command{grub-install}
|
||||||
|
-(@pxref{Invoking grub-install}).
|
||||||
|
+(@pxref{Invoking grub2-install}).
|
||||||
|
+
|
||||||
+@comment Unfortunately --pubkey is not yet supported by grub2-install,
|
+@comment Unfortunately --pubkey is not yet supported by grub2-install,
|
||||||
+@comment but we should not bring up internal detail grub2-mkimage here
|
+@comment but we should not bring up internal detail grub2-mkimage here
|
||||||
@comment in the user guide (as opposed to developer's manual).
|
+@comment in the user guide (as opposed to developer's manual).
|
||||||
|
+
|
||||||
@comment An initial trusted public key can be embedded within the GRUB
|
+@comment An initial trusted public key can be embedded within the GRUB
|
||||||
@comment @file{core.img} using the @code{--pubkey} option to
|
+@comment @file{core.img} using the @code{--pubkey} option to
|
||||||
-@comment @command{grub-mkimage} (@pxref{Invoking grub-install}). Presently it
|
|
||||||
-@comment is necessary to write a custom wrapper around @command{grub-mkimage}
|
|
||||||
-@comment using the @code{--grub-mkimage} flag to @command{grub-install}.
|
|
||||||
+@comment @command{grub2-mkimage} (@pxref{Invoking grub2-install}). Presently it
|
+@comment @command{grub2-mkimage} (@pxref{Invoking grub2-install}). Presently it
|
||||||
+@comment is necessary to write a custom wrapper around @command{grub2-mkimage}
|
+@comment is necessary to write a custom wrapper around @command{grub2-mkimage}
|
||||||
+@comment using the @code{--grub-mkimage} flag to @command{grub2-install}.
|
+@comment using the @code{--grub-mkimage} flag to @command{grub2-install}.
|
||||||
|
|
||||||
GRUB uses GPG-style detached signatures (meaning that a file
|
GRUB uses GPG-style detached signatures (meaning that a file
|
||||||
@file{foo.sig} will be produced when file @file{foo} is signed), and
|
@file{foo.sig} will be produced when file @file{foo} is signed), and
|
||||||
@@ -5712,8 +5712,8 @@ gpg --detach-sign /path/to/file
|
@@ -5907,8 +5924,8 @@ gpg --detach-sign /path/to/file
|
||||||
For successful validation of all of GRUB's subcomponents and the
|
For successful validation of all of GRUB's subcomponents and the
|
||||||
loaded OS kernel, they must all be signed. One way to accomplish this
|
loaded OS kernel, they must all be signed. One way to accomplish this
|
||||||
is the following (after having already produced the desired
|
is the following (after having already produced the desired
|
||||||
@ -679,7 +674,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
|
|
||||||
@example
|
@example
|
||||||
@group
|
@group
|
||||||
@@ -5735,7 +5735,7 @@ See also: @ref{check_signatures}, @ref{verify_detached}, @ref{trust},
|
@@ -5930,7 +5947,7 @@ See also: @ref{check_signatures}, @ref{verify_detached}, @ref{trust},
|
||||||
Note that internally signature enforcement is controlled by setting
|
Note that internally signature enforcement is controlled by setting
|
||||||
the environment variable @code{check_signatures} equal to
|
the environment variable @code{check_signatures} equal to
|
||||||
@code{enforce}. Passing one or more @code{--pubkey} options to
|
@code{enforce}. Passing one or more @code{--pubkey} options to
|
||||||
@ -688,7 +683,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
equal to @code{enforce} in @file{core.img} prior to processing any
|
equal to @code{enforce} in @file{core.img} prior to processing any
|
||||||
configuration files.
|
configuration files.
|
||||||
|
|
||||||
@@ -6092,10 +6092,10 @@ Required files are:
|
@@ -6388,10 +6405,10 @@ Required files are:
|
||||||
|
|
||||||
GRUB's normal start-up procedure involves setting the @samp{prefix}
|
GRUB's normal start-up procedure involves setting the @samp{prefix}
|
||||||
environment variable to a value set in the core image by
|
environment variable to a value set in the core image by
|
||||||
@ -701,7 +696,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
things GRUB is supposed to do.
|
things GRUB is supposed to do.
|
||||||
|
|
||||||
If, instead, you only get a rescue shell, this usually means that GRUB
|
If, instead, you only get a rescue shell, this usually means that GRUB
|
||||||
@@ -6121,8 +6121,8 @@ normal
|
@@ -6417,8 +6434,8 @@ normal
|
||||||
|
|
||||||
However, any problem that leaves you in the rescue shell probably means that
|
However, any problem that leaves you in the rescue shell probably means that
|
||||||
GRUB was not correctly installed. It may be more useful to try to reinstall
|
GRUB was not correctly installed. It may be more useful to try to reinstall
|
||||||
@ -712,7 +707,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
|
|
||||||
@itemize @bullet{}
|
@itemize @bullet{}
|
||||||
@item
|
@item
|
||||||
@@ -6134,7 +6134,7 @@ is usually better to use UUIDs or file system labels and avoid depending on
|
@@ -6430,7 +6447,7 @@ is usually better to use UUIDs or file system labels and avoid depending on
|
||||||
drive ordering entirely.
|
drive ordering entirely.
|
||||||
|
|
||||||
@item
|
@item
|
||||||
@ -721,8 +716,8 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
to a partition but GRUB has already been installed in the master boot
|
to a partition but GRUB has already been installed in the master boot
|
||||||
record, then the GRUB installation in the partition will be ignored.
|
record, then the GRUB installation in the partition will be ignored.
|
||||||
|
|
||||||
@@ -6154,21 +6154,21 @@ support has not yet been added to GRUB.
|
@@ -6461,21 +6478,21 @@ entry which claims partition start at block 0. This change will not hamper
|
||||||
@end itemize
|
bootability on other machines.
|
||||||
|
|
||||||
|
|
||||||
-@node Invoking grub-install
|
-@node Invoking grub-install
|
||||||
@ -749,7 +744,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
|
|
||||||
@table @option
|
@table @option
|
||||||
@item --help
|
@item --help
|
||||||
@@ -6184,13 +6184,13 @@ separate partition or a removable disk.
|
@@ -6491,13 +6508,13 @@ separate partition or a removable disk.
|
||||||
If this option is not specified then it defaults to @file{/boot}, so
|
If this option is not specified then it defaults to @file{/boot}, so
|
||||||
|
|
||||||
@example
|
@example
|
||||||
@ -765,7 +760,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
@end example
|
@end example
|
||||||
|
|
||||||
Here is an example in which you have a separate @dfn{boot} partition which is
|
Here is an example in which you have a separate @dfn{boot} partition which is
|
||||||
@@ -6198,16 +6198,16 @@ mounted on
|
@@ -6505,16 +6522,16 @@ mounted on
|
||||||
@file{/mnt/boot}:
|
@file{/mnt/boot}:
|
||||||
|
|
||||||
@example
|
@example
|
||||||
@ -785,7 +780,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
extra space in the bootloader embedding area for Reed-Solomon
|
extra space in the bootloader embedding area for Reed-Solomon
|
||||||
error-correcting codes. This enables GRUB to still boot successfully
|
error-correcting codes. This enables GRUB to still boot successfully
|
||||||
if some blocks are corrupted. The exact amount of protection offered
|
if some blocks are corrupted. The exact amount of protection offered
|
||||||
@@ -6220,17 +6220,17 @@ installation}) where GRUB does not reside in any unpartitioned space
|
@@ -6527,17 +6544,17 @@ installation}) where GRUB does not reside in any unpartitioned space
|
||||||
outside of the MBR. Disable the Reed-Solomon codes with this option.
|
outside of the MBR. Disable the Reed-Solomon codes with this option.
|
||||||
@end table
|
@end table
|
||||||
|
|
||||||
@ -808,7 +803,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
|
|
||||||
@table @option
|
@table @option
|
||||||
@item --help
|
@item --help
|
||||||
@@ -6246,17 +6246,17 @@ it to standard output.
|
@@ -6553,17 +6570,17 @@ it to standard output.
|
||||||
@end table
|
@end table
|
||||||
|
|
||||||
|
|
||||||
@ -830,7 +825,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
|
|
||||||
@table @option
|
@table @option
|
||||||
@item -c @var{number}
|
@item -c @var{number}
|
||||||
@@ -6274,23 +6274,23 @@ Length of the salt. Defaults to 64.
|
@@ -6581,23 +6598,23 @@ Length of the salt. Defaults to 64.
|
||||||
@end table
|
@end table
|
||||||
|
|
||||||
|
|
||||||
@ -860,7 +855,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
|
|
||||||
@table @option
|
@table @option
|
||||||
@item --help
|
@item --help
|
||||||
@@ -6301,17 +6301,17 @@ Print the version number of GRUB and exit.
|
@@ -6608,17 +6625,17 @@ Print the version number of GRUB and exit.
|
||||||
@end table
|
@end table
|
||||||
|
|
||||||
|
|
||||||
@ -882,7 +877,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
passed on directly to @command{xorriso} in @command{mkisofs} emulation mode.
|
passed on directly to @command{xorriso} in @command{mkisofs} emulation mode.
|
||||||
Options passed to @command{xorriso} will normally be interpreted as
|
Options passed to @command{xorriso} will normally be interpreted as
|
||||||
@command{mkisofs} options; if the option @samp{--} is used, then anything
|
@command{mkisofs} options; if the option @samp{--} is used, then anything
|
||||||
@@ -6326,7 +6326,7 @@ mkdir -p disk/boot/grub
|
@@ -6633,7 +6650,7 @@ mkdir -p disk/boot/grub
|
||||||
grub-mkrescue -o grub.iso disk
|
grub-mkrescue -o grub.iso disk
|
||||||
@end example
|
@end example
|
||||||
|
|
||||||
@ -891,7 +886,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
|
|
||||||
@table @option
|
@table @option
|
||||||
@item --help
|
@item --help
|
||||||
@@ -6354,15 +6354,15 @@ Use @var{file} as the @command{xorriso} program, rather than the built-in
|
@@ -6661,15 +6678,15 @@ Use @var{file} as the @command{xorriso} program, rather than the built-in
|
||||||
default.
|
default.
|
||||||
|
|
||||||
@item --grub-mkimage=@var{file}
|
@item --grub-mkimage=@var{file}
|
||||||
@ -911,7 +906,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
system or file system image that GRUB understands, using GRUB's file system
|
system or file system image that GRUB understands, using GRUB's file system
|
||||||
drivers via FUSE. (It is only available if FUSE development files were
|
drivers via FUSE. (It is only available if FUSE development files were
|
||||||
present when GRUB was built.) This has a number of uses:
|
present when GRUB was built.) This has a number of uses:
|
||||||
@@ -6394,13 +6394,13 @@ even if nobody has yet written a FUSE module specifically for that file
|
@@ -6701,13 +6718,13 @@ even if nobody has yet written a FUSE module specifically for that file
|
||||||
system type.
|
system type.
|
||||||
@end itemize
|
@end itemize
|
||||||
|
|
||||||
@ -927,7 +922,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
non-option arguments (if it is given more than one image, it will treat them
|
non-option arguments (if it is given more than one image, it will treat them
|
||||||
as a RAID set), and also accepts the following options:
|
as a RAID set), and also accepts the following options:
|
||||||
|
|
||||||
@@ -6422,13 +6422,13 @@ Show debugging output for conditions matching @var{string}.
|
@@ -6729,13 +6746,13 @@ Show debugging output for conditions matching @var{string}.
|
||||||
@item -K prompt|@var{file}
|
@item -K prompt|@var{file}
|
||||||
@itemx --zfs-key=prompt|@var{file}
|
@itemx --zfs-key=prompt|@var{file}
|
||||||
Load a ZFS encryption key. If you use @samp{prompt} as the argument,
|
Load a ZFS encryption key. If you use @samp{prompt} as the argument,
|
||||||
@ -943,7 +938,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
root of the supplied file system.
|
root of the supplied file system.
|
||||||
|
|
||||||
If @var{device} is just a number, then it will be treated as a partition
|
If @var{device} is just a number, then it will be treated as a partition
|
||||||
@@ -6446,10 +6446,10 @@ Print verbose messages.
|
@@ -6753,10 +6770,10 @@ Print verbose messages.
|
||||||
@end table
|
@end table
|
||||||
|
|
||||||
|
|
||||||
@ -957,7 +952,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
or device.
|
or device.
|
||||||
|
|
||||||
@example
|
@example
|
||||||
@@ -6457,7 +6457,7 @@ grub-probe --target=fs /boot/grub
|
@@ -6764,7 +6781,7 @@ grub-probe --target=fs /boot/grub
|
||||||
grub-probe --target=drive --device /dev/sda1
|
grub-probe --target=drive --device /dev/sda1
|
||||||
@end example
|
@end example
|
||||||
|
|
||||||
@ -966,7 +961,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
argument, and also accepts the following options:
|
argument, and also accepts the following options:
|
||||||
|
|
||||||
@table @option
|
@table @option
|
||||||
@@ -6470,16 +6470,16 @@ Print the version number of GRUB and exit.
|
@@ -6777,16 +6794,16 @@ Print the version number of GRUB and exit.
|
||||||
@item -d
|
@item -d
|
||||||
@itemx --device
|
@itemx --device
|
||||||
If this option is given, then the non-option argument is a system device
|
If this option is given, then the non-option argument is a system device
|
||||||
@ -986,7 +981,7 @@ index a7155c22f..2b7b7faf8 100644
|
|||||||
|
|
||||||
@item -t @var{target}
|
@item -t @var{target}
|
||||||
@itemx --target=@var{target}
|
@itemx --target=@var{target}
|
||||||
@@ -6532,19 +6532,19 @@ Print verbose messages.
|
@@ -6839,19 +6856,19 @@ Print verbose messages.
|
||||||
@end table
|
@end table
|
||||||
|
|
||||||
|
|
@ -20,7 +20,7 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
1 file changed, 18 insertions(+), 60 deletions(-)
|
1 file changed, 18 insertions(+), 60 deletions(-)
|
||||||
|
|
||||||
diff --git a/util/grub.d/30_os-prober.in b/util/grub.d/30_os-prober.in
|
diff --git a/util/grub.d/30_os-prober.in b/util/grub.d/30_os-prober.in
|
||||||
index 9b8f5968e..13a3a6bc7 100644
|
index 1b91c102f3..4b27bd2015 100644
|
||||||
--- a/util/grub.d/30_os-prober.in
|
--- a/util/grub.d/30_os-prober.in
|
||||||
+++ b/util/grub.d/30_os-prober.in
|
+++ b/util/grub.d/30_os-prober.in
|
||||||
@@ -42,68 +42,25 @@ if [ -z "${OSPROBED}" ] ; then
|
@@ -42,68 +42,25 @@ if [ -z "${OSPROBED}" ] ; then
|
||||||
@ -104,7 +104,7 @@ index 9b8f5968e..13a3a6bc7 100644
|
|||||||
}
|
}
|
||||||
EOF
|
EOF
|
||||||
}
|
}
|
||||||
@@ -284,11 +241,12 @@ EOF
|
@@ -292,11 +249,12 @@ EOF
|
||||||
echo "$title_correction_code"
|
echo "$title_correction_code"
|
||||||
;;
|
;;
|
||||||
macosx)
|
macosx)
|
@ -1,6 +1,6 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
From: Jeff Mahoney <jeffm@suse.com>
|
From: Jeff Mahoney <jeffm@suse.com>
|
||||||
Date: Wed, 18 Dec 2013 09:57:04 +0000
|
Date: Tue, 9 Jul 2019 13:39:45 +0200
|
||||||
Subject: [PATCH] grub2/btrfs: Add ability to boot from subvolumes
|
Subject: [PATCH] grub2/btrfs: Add ability to boot from subvolumes
|
||||||
|
|
||||||
This patch adds the ability to specify a different root on a btrfs
|
This patch adds the ability to specify a different root on a btrfs
|
||||||
@ -24,20 +24,20 @@ Signed-off-by: Jeff Mahoney <jeffm@suse.com>
|
|||||||
2 files changed, 533 insertions(+), 20 deletions(-)
|
2 files changed, 533 insertions(+), 20 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/fs/btrfs.c b/grub-core/fs/btrfs.c
|
diff --git a/grub-core/fs/btrfs.c b/grub-core/fs/btrfs.c
|
||||||
index be195448d..51ed63d42 100644
|
index 63203034df..f1fff7385b 100644
|
||||||
--- a/grub-core/fs/btrfs.c
|
--- a/grub-core/fs/btrfs.c
|
||||||
+++ b/grub-core/fs/btrfs.c
|
+++ b/grub-core/fs/btrfs.c
|
||||||
@@ -29,6 +29,9 @@
|
@@ -38,6 +38,9 @@
|
||||||
#include <minilzo.h>
|
#include <zstd.h>
|
||||||
#include <grub/i18n.h>
|
#include <grub/i18n.h>
|
||||||
#include <grub/btrfs.h>
|
#include <grub/btrfs.h>
|
||||||
+#include <grub/command.h>
|
+#include <grub/command.h>
|
||||||
+#include <grub/env.h>
|
+#include <grub/env.h>
|
||||||
+#include <grub/extcmd.h>
|
+#include <grub/extcmd.h>
|
||||||
|
#include <grub/crypto.h>
|
||||||
GRUB_MOD_LICENSE ("GPLv3+");
|
#include <grub/diskfilter.h>
|
||||||
|
#include <grub/safemath.h>
|
||||||
@@ -64,9 +67,11 @@ struct grub_btrfs_superblock
|
@@ -79,9 +82,11 @@ struct grub_btrfs_superblock
|
||||||
grub_uint64_t generation;
|
grub_uint64_t generation;
|
||||||
grub_uint64_t root_tree;
|
grub_uint64_t root_tree;
|
||||||
grub_uint64_t chunk_tree;
|
grub_uint64_t chunk_tree;
|
||||||
@ -51,7 +51,7 @@ index be195448d..51ed63d42 100644
|
|||||||
struct grub_btrfs_device this_device;
|
struct grub_btrfs_device this_device;
|
||||||
char label[0x100];
|
char label[0x100];
|
||||||
grub_uint8_t dummy4[0x100];
|
grub_uint8_t dummy4[0x100];
|
||||||
@@ -105,6 +110,7 @@ struct grub_btrfs_data
|
@@ -121,6 +126,7 @@ struct grub_btrfs_data
|
||||||
grub_uint64_t exttree;
|
grub_uint64_t exttree;
|
||||||
grub_size_t extsize;
|
grub_size_t extsize;
|
||||||
struct grub_btrfs_extent_data *extent;
|
struct grub_btrfs_extent_data *extent;
|
||||||
@ -59,7 +59,7 @@ index be195448d..51ed63d42 100644
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct grub_btrfs_chunk_item
|
struct grub_btrfs_chunk_item
|
||||||
@@ -171,6 +177,14 @@ struct grub_btrfs_leaf_descriptor
|
@@ -191,6 +197,14 @@ struct grub_btrfs_leaf_descriptor
|
||||||
} *data;
|
} *data;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -74,7 +74,7 @@ index be195448d..51ed63d42 100644
|
|||||||
struct grub_btrfs_time
|
struct grub_btrfs_time
|
||||||
{
|
{
|
||||||
grub_int64_t sec;
|
grub_int64_t sec;
|
||||||
@@ -215,6 +229,14 @@ struct grub_btrfs_extent_data
|
@@ -236,6 +250,14 @@ struct grub_btrfs_extent_data
|
||||||
|
|
||||||
#define GRUB_BTRFS_OBJECT_ID_CHUNK 0x100
|
#define GRUB_BTRFS_OBJECT_ID_CHUNK 0x100
|
||||||
|
|
||||||
@ -89,7 +89,7 @@ index be195448d..51ed63d42 100644
|
|||||||
static grub_disk_addr_t superblock_sectors[] = { 64 * 2, 64 * 1024 * 2,
|
static grub_disk_addr_t superblock_sectors[] = { 64 * 2, 64 * 1024 * 2,
|
||||||
256 * 1048576 * 2, 1048576ULL * 1048576ULL * 2
|
256 * 1048576 * 2, 1048576ULL * 1048576ULL * 2
|
||||||
};
|
};
|
||||||
@@ -837,6 +859,62 @@ grub_btrfs_read_logical (struct grub_btrfs_data *data, grub_disk_addr_t addr,
|
@@ -1173,6 +1195,62 @@ grub_btrfs_read_logical (struct grub_btrfs_data *data, grub_disk_addr_t addr,
|
||||||
return GRUB_ERR_NONE;
|
return GRUB_ERR_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -152,7 +152,7 @@ index be195448d..51ed63d42 100644
|
|||||||
static struct grub_btrfs_data *
|
static struct grub_btrfs_data *
|
||||||
grub_btrfs_mount (grub_device_t dev)
|
grub_btrfs_mount (grub_device_t dev)
|
||||||
{
|
{
|
||||||
@@ -872,6 +950,13 @@ grub_btrfs_mount (grub_device_t dev)
|
@@ -1208,6 +1286,13 @@ grub_btrfs_mount (grub_device_t dev)
|
||||||
data->devices_attached[0].dev = dev;
|
data->devices_attached[0].dev = dev;
|
||||||
data->devices_attached[0].id = data->sblock.this_device.device_id;
|
data->devices_attached[0].id = data->sblock.this_device.device_id;
|
||||||
|
|
||||||
@ -166,7 +166,7 @@ index be195448d..51ed63d42 100644
|
|||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1232,6 +1317,91 @@ get_root (struct grub_btrfs_data *data, struct grub_btrfs_key *key,
|
@@ -1673,6 +1758,91 @@ get_root (struct grub_btrfs_data *data, struct grub_btrfs_key *key,
|
||||||
return GRUB_ERR_NONE;
|
return GRUB_ERR_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -258,7 +258,7 @@ index be195448d..51ed63d42 100644
|
|||||||
static grub_err_t
|
static grub_err_t
|
||||||
find_path (struct grub_btrfs_data *data,
|
find_path (struct grub_btrfs_data *data,
|
||||||
const char *path, struct grub_btrfs_key *key,
|
const char *path, struct grub_btrfs_key *key,
|
||||||
@@ -1250,14 +1420,26 @@ find_path (struct grub_btrfs_data *data,
|
@@ -1691,14 +1861,26 @@ find_path (struct grub_btrfs_data *data,
|
||||||
char *origpath = NULL;
|
char *origpath = NULL;
|
||||||
unsigned symlinks_max = 32;
|
unsigned symlinks_max = 32;
|
||||||
|
|
||||||
@ -289,7 +289,7 @@ index be195448d..51ed63d42 100644
|
|||||||
while (1)
|
while (1)
|
||||||
{
|
{
|
||||||
while (path[0] == '/')
|
while (path[0] == '/')
|
||||||
@@ -1430,9 +1612,21 @@ find_path (struct grub_btrfs_data *data,
|
@@ -1871,9 +2053,21 @@ find_path (struct grub_btrfs_data *data,
|
||||||
path = path_alloc = tmp;
|
path = path_alloc = tmp;
|
||||||
if (path[0] == '/')
|
if (path[0] == '/')
|
||||||
{
|
{
|
||||||
@ -314,7 +314,7 @@ index be195448d..51ed63d42 100644
|
|||||||
}
|
}
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@@ -1673,18 +1867,10 @@ grub_btrfs_read (grub_file_t file, char *buf, grub_size_t len)
|
@@ -2114,18 +2308,10 @@ grub_btrfs_read (grub_file_t file, char *buf, grub_size_t len)
|
||||||
data->tree, file->offset, buf, len);
|
data->tree, file->offset, buf, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -336,7 +336,7 @@ index be195448d..51ed63d42 100644
|
|||||||
grub_be_to_cpu16 (data->sblock.uuid[0]),
|
grub_be_to_cpu16 (data->sblock.uuid[0]),
|
||||||
grub_be_to_cpu16 (data->sblock.uuid[1]),
|
grub_be_to_cpu16 (data->sblock.uuid[1]),
|
||||||
grub_be_to_cpu16 (data->sblock.uuid[2]),
|
grub_be_to_cpu16 (data->sblock.uuid[2]),
|
||||||
@@ -1693,6 +1879,20 @@ grub_btrfs_uuid (grub_device_t device, char **uuid)
|
@@ -2134,6 +2320,20 @@ grub_btrfs_uuid (grub_device_t device, char **uuid)
|
||||||
grub_be_to_cpu16 (data->sblock.uuid[5]),
|
grub_be_to_cpu16 (data->sblock.uuid[5]),
|
||||||
grub_be_to_cpu16 (data->sblock.uuid[6]),
|
grub_be_to_cpu16 (data->sblock.uuid[6]),
|
||||||
grub_be_to_cpu16 (data->sblock.uuid[7]));
|
grub_be_to_cpu16 (data->sblock.uuid[7]));
|
||||||
@ -357,7 +357,7 @@ index be195448d..51ed63d42 100644
|
|||||||
|
|
||||||
grub_btrfs_unmount (data);
|
grub_btrfs_unmount (data);
|
||||||
|
|
||||||
@@ -1749,6 +1949,242 @@ grub_btrfs_embed (grub_device_t device __attribute__ ((unused)),
|
@@ -2190,6 +2390,242 @@ grub_btrfs_embed (grub_device_t device __attribute__ ((unused)),
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -599,8 +599,8 @@ index be195448d..51ed63d42 100644
|
|||||||
+
|
+
|
||||||
static struct grub_fs grub_btrfs_fs = {
|
static struct grub_fs grub_btrfs_fs = {
|
||||||
.name = "btrfs",
|
.name = "btrfs",
|
||||||
.dir = grub_btrfs_dir,
|
.fs_dir = grub_btrfs_dir,
|
||||||
@@ -1764,12 +2200,88 @@ static struct grub_fs grub_btrfs_fs = {
|
@@ -2205,12 +2641,88 @@ static struct grub_fs grub_btrfs_fs = {
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -690,7 +690,7 @@ index be195448d..51ed63d42 100644
|
|||||||
+
|
+
|
||||||
+// vim: si et sw=2:
|
+// vim: si et sw=2:
|
||||||
diff --git a/include/grub/btrfs.h b/include/grub/btrfs.h
|
diff --git a/include/grub/btrfs.h b/include/grub/btrfs.h
|
||||||
index 9d93fb6c1..234ad9767 100644
|
index 9d93fb6c18..234ad97677 100644
|
||||||
--- a/include/grub/btrfs.h
|
--- a/include/grub/btrfs.h
|
||||||
+++ b/include/grub/btrfs.h
|
+++ b/include/grub/btrfs.h
|
||||||
@@ -29,6 +29,7 @@ enum
|
@@ -29,6 +29,7 @@ enum
|
@ -12,10 +12,10 @@ Signed-off-by: Michael Chang <mchang@suse.com>
|
|||||||
1 file changed, 2 insertions(+)
|
1 file changed, 2 insertions(+)
|
||||||
|
|
||||||
diff --git a/grub-core/fs/btrfs.c b/grub-core/fs/btrfs.c
|
diff --git a/grub-core/fs/btrfs.c b/grub-core/fs/btrfs.c
|
||||||
index 51ed63d42..88d727d16 100644
|
index f1fff7385b..ad1b56b716 100644
|
||||||
--- a/grub-core/fs/btrfs.c
|
--- a/grub-core/fs/btrfs.c
|
||||||
+++ b/grub-core/fs/btrfs.c
|
+++ b/grub-core/fs/btrfs.c
|
||||||
@@ -2273,6 +2273,8 @@ GRUB_MOD_INIT (btrfs)
|
@@ -2714,6 +2714,8 @@ GRUB_MOD_INIT (btrfs)
|
||||||
subvol_set_env);
|
subvol_set_env);
|
||||||
grub_register_variable_hook ("btrfs_subvolid", subvolid_get_env,
|
grub_register_variable_hook ("btrfs_subvolid", subvolid_get_env,
|
||||||
subvolid_set_env);
|
subvolid_set_env);
|
@ -3,15 +3,17 @@ From: Michael Chang <mchang@suse.com>
|
|||||||
Date: Thu, 21 Aug 2014 03:39:11 +0000
|
Date: Thu, 21 Aug 2014 03:39:11 +0000
|
||||||
Subject: [PATCH] grub2-btrfs-03-follow_default
|
Subject: [PATCH] grub2-btrfs-03-follow_default
|
||||||
|
|
||||||
|
Signed-off-by: Michael Chang <mchang@suse.com>
|
||||||
|
Signed-off-by: Robbie Harwood <rharwood@redhat.com>
|
||||||
---
|
---
|
||||||
grub-core/fs/btrfs.c | 107 ++++++++++++++++++++++++++++++++++++---------------
|
grub-core/fs/btrfs.c | 107 ++++++++++++++++++++++++++++++++++++---------------
|
||||||
1 file changed, 76 insertions(+), 31 deletions(-)
|
1 file changed, 76 insertions(+), 31 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/fs/btrfs.c b/grub-core/fs/btrfs.c
|
diff --git a/grub-core/fs/btrfs.c b/grub-core/fs/btrfs.c
|
||||||
index 88d727d16..a47d29756 100644
|
index ad1b56b716..113c1f746c 100644
|
||||||
--- a/grub-core/fs/btrfs.c
|
--- a/grub-core/fs/btrfs.c
|
||||||
+++ b/grub-core/fs/btrfs.c
|
+++ b/grub-core/fs/btrfs.c
|
||||||
@@ -920,6 +920,7 @@ grub_btrfs_mount (grub_device_t dev)
|
@@ -1256,6 +1256,7 @@ grub_btrfs_mount (grub_device_t dev)
|
||||||
{
|
{
|
||||||
struct grub_btrfs_data *data;
|
struct grub_btrfs_data *data;
|
||||||
grub_err_t err;
|
grub_err_t err;
|
||||||
@ -19,7 +21,7 @@ index 88d727d16..a47d29756 100644
|
|||||||
|
|
||||||
if (!dev->disk)
|
if (!dev->disk)
|
||||||
{
|
{
|
||||||
@@ -950,11 +951,14 @@ grub_btrfs_mount (grub_device_t dev)
|
@@ -1286,11 +1287,14 @@ grub_btrfs_mount (grub_device_t dev)
|
||||||
data->devices_attached[0].dev = dev;
|
data->devices_attached[0].dev = dev;
|
||||||
data->devices_attached[0].id = data->sblock.this_device.device_id;
|
data->devices_attached[0].id = data->sblock.this_device.device_id;
|
||||||
|
|
||||||
@ -38,7 +40,7 @@ index 88d727d16..a47d29756 100644
|
|||||||
}
|
}
|
||||||
|
|
||||||
return data;
|
return data;
|
||||||
@@ -1414,24 +1418,39 @@ find_path (struct grub_btrfs_data *data,
|
@@ -1855,24 +1859,39 @@ find_path (struct grub_btrfs_data *data,
|
||||||
grub_size_t allocated = 0;
|
grub_size_t allocated = 0;
|
||||||
struct grub_btrfs_dir_item *direl = NULL;
|
struct grub_btrfs_dir_item *direl = NULL;
|
||||||
struct grub_btrfs_key key_out;
|
struct grub_btrfs_key key_out;
|
||||||
@ -85,7 +87,7 @@ index 88d727d16..a47d29756 100644
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -1442,15 +1461,23 @@ find_path (struct grub_btrfs_data *data,
|
@@ -1883,15 +1902,23 @@ find_path (struct grub_btrfs_data *data,
|
||||||
|
|
||||||
while (1)
|
while (1)
|
||||||
{
|
{
|
||||||
@ -118,7 +120,7 @@ index 88d727d16..a47d29756 100644
|
|||||||
|
|
||||||
if (*type != GRUB_BTRFS_DIR_ITEM_TYPE_DIRECTORY)
|
if (*type != GRUB_BTRFS_DIR_ITEM_TYPE_DIRECTORY)
|
||||||
{
|
{
|
||||||
@@ -1461,7 +1488,9 @@ find_path (struct grub_btrfs_data *data,
|
@@ -1902,7 +1929,9 @@ find_path (struct grub_btrfs_data *data,
|
||||||
|
|
||||||
if (ctokenlen == 1 && ctoken[0] == '.')
|
if (ctokenlen == 1 && ctoken[0] == '.')
|
||||||
{
|
{
|
||||||
@ -129,7 +131,7 @@ index 88d727d16..a47d29756 100644
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (ctokenlen == 2 && ctoken[0] == '.' && ctoken[1] == '.')
|
if (ctokenlen == 2 && ctoken[0] == '.' && ctoken[1] == '.')
|
||||||
@@ -1492,8 +1521,9 @@ find_path (struct grub_btrfs_data *data,
|
@@ -1933,8 +1962,9 @@ find_path (struct grub_btrfs_data *data,
|
||||||
*type = GRUB_BTRFS_DIR_ITEM_TYPE_DIRECTORY;
|
*type = GRUB_BTRFS_DIR_ITEM_TYPE_DIRECTORY;
|
||||||
key->object_id = key_out.offset;
|
key->object_id = key_out.offset;
|
||||||
|
|
||||||
@ -141,7 +143,7 @@ index 88d727d16..a47d29756 100644
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1562,7 +1592,9 @@ find_path (struct grub_btrfs_data *data,
|
@@ -2003,7 +2033,9 @@ find_path (struct grub_btrfs_data *data,
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -152,7 +154,7 @@ index 88d727d16..a47d29756 100644
|
|||||||
if (cdirel->type == GRUB_BTRFS_DIR_ITEM_TYPE_SYMLINK)
|
if (cdirel->type == GRUB_BTRFS_DIR_ITEM_TYPE_SYMLINK)
|
||||||
{
|
{
|
||||||
struct grub_btrfs_inode inode;
|
struct grub_btrfs_inode inode;
|
||||||
@@ -1612,14 +1644,26 @@ find_path (struct grub_btrfs_data *data,
|
@@ -2053,14 +2085,26 @@ find_path (struct grub_btrfs_data *data,
|
||||||
path = path_alloc = tmp;
|
path = path_alloc = tmp;
|
||||||
if (path[0] == '/')
|
if (path[0] == '/')
|
||||||
{
|
{
|
||||||
@ -186,7 +188,7 @@ index 88d727d16..a47d29756 100644
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -2275,6 +2319,7 @@ GRUB_MOD_INIT (btrfs)
|
@@ -2716,6 +2760,7 @@ GRUB_MOD_INIT (btrfs)
|
||||||
subvolid_set_env);
|
subvolid_set_env);
|
||||||
grub_env_export ("btrfs_subvol");
|
grub_env_export ("btrfs_subvol");
|
||||||
grub_env_export ("btrfs_subvolid");
|
grub_env_export ("btrfs_subvolid");
|
@ -3,6 +3,8 @@ From: Michael Chang <mchang@suse.com>
|
|||||||
Date: Thu, 21 Aug 2014 03:39:11 +0000
|
Date: Thu, 21 Aug 2014 03:39:11 +0000
|
||||||
Subject: [PATCH] grub2-btrfs-04-grub2-install
|
Subject: [PATCH] grub2-btrfs-04-grub2-install
|
||||||
|
|
||||||
|
Signed-off-by: Michael Chang <mchang@suse.com>
|
||||||
|
Signed-off-by: Robbie Harwood <rharwood@redhat.com>
|
||||||
---
|
---
|
||||||
grub-core/osdep/linux/getroot.c | 7 +++++++
|
grub-core/osdep/linux/getroot.c | 7 +++++++
|
||||||
grub-core/osdep/unix/config.c | 17 +++++++++++++++--
|
grub-core/osdep/unix/config.c | 17 +++++++++++++++--
|
||||||
@ -13,7 +15,7 @@ Subject: [PATCH] grub2-btrfs-04-grub2-install
|
|||||||
6 files changed, 54 insertions(+), 2 deletions(-)
|
6 files changed, 54 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/osdep/linux/getroot.c b/grub-core/osdep/linux/getroot.c
|
diff --git a/grub-core/osdep/linux/getroot.c b/grub-core/osdep/linux/getroot.c
|
||||||
index 6d9f4e5fa..5d50dd6f8 100644
|
index 001b818fe5..caf9b1ccd3 100644
|
||||||
--- a/grub-core/osdep/linux/getroot.c
|
--- a/grub-core/osdep/linux/getroot.c
|
||||||
+++ b/grub-core/osdep/linux/getroot.c
|
+++ b/grub-core/osdep/linux/getroot.c
|
||||||
@@ -376,6 +376,7 @@ get_btrfs_fs_prefix (const char *mount_path)
|
@@ -376,6 +376,7 @@ get_btrfs_fs_prefix (const char *mount_path)
|
||||||
@ -38,7 +40,7 @@ index 6d9f4e5fa..5d50dd6f8 100644
|
|||||||
else if (!retry && grub_strcmp (entries[i].fstype, "autofs") == 0)
|
else if (!retry && grub_strcmp (entries[i].fstype, "autofs") == 0)
|
||||||
{
|
{
|
||||||
diff --git a/grub-core/osdep/unix/config.c b/grub-core/osdep/unix/config.c
|
diff --git a/grub-core/osdep/unix/config.c b/grub-core/osdep/unix/config.c
|
||||||
index 65effa9f3..b637c58ef 100644
|
index 7d6325138c..46a881530c 100644
|
||||||
--- a/grub-core/osdep/unix/config.c
|
--- a/grub-core/osdep/unix/config.c
|
||||||
+++ b/grub-core/osdep/unix/config.c
|
+++ b/grub-core/osdep/unix/config.c
|
||||||
@@ -82,6 +82,19 @@ grub_util_load_config (struct grub_util_config *cfg)
|
@@ -82,6 +82,19 @@ grub_util_load_config (struct grub_util_config *cfg)
|
||||||
@ -73,7 +75,7 @@ index 65effa9f3..b637c58ef 100644
|
|||||||
argv[2] = script;
|
argv[2] = script;
|
||||||
argv[3] = '\0';
|
argv[3] = '\0';
|
||||||
diff --git a/util/config.c b/util/config.c
|
diff --git a/util/config.c b/util/config.c
|
||||||
index ebcdd8f5e..f044a880a 100644
|
index ebcdd8f5e2..f044a880a7 100644
|
||||||
--- a/util/config.c
|
--- a/util/config.c
|
||||||
+++ b/util/config.c
|
+++ b/util/config.c
|
||||||
@@ -42,6 +42,16 @@ grub_util_parse_config (FILE *f, struct grub_util_config *cfg, int simple)
|
@@ -42,6 +42,16 @@ grub_util_parse_config (FILE *f, struct grub_util_config *cfg, int simple)
|
||||||
@ -94,10 +96,10 @@ index ebcdd8f5e..f044a880a 100644
|
|||||||
sizeof ("GRUB_DISTRIBUTOR=") - 1) == 0)
|
sizeof ("GRUB_DISTRIBUTOR=") - 1) == 0)
|
||||||
{
|
{
|
||||||
diff --git a/util/grub-install.c b/util/grub-install.c
|
diff --git a/util/grub-install.c b/util/grub-install.c
|
||||||
index 78d0138cb..4375c1619 100644
|
index 0fbe7f78c6..0f66f36d23 100644
|
||||||
--- a/util/grub-install.c
|
--- a/util/grub-install.c
|
||||||
+++ b/util/grub-install.c
|
+++ b/util/grub-install.c
|
||||||
@@ -816,6 +816,8 @@ fill_core_services (const char *core_services)
|
@@ -827,6 +827,8 @@ fill_core_services (const char *core_services)
|
||||||
free (sysv_plist);
|
free (sysv_plist);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -106,7 +108,7 @@ index 78d0138cb..4375c1619 100644
|
|||||||
int
|
int
|
||||||
main (int argc, char *argv[])
|
main (int argc, char *argv[])
|
||||||
{
|
{
|
||||||
@@ -849,6 +851,9 @@ main (int argc, char *argv[])
|
@@ -860,6 +862,9 @@ main (int argc, char *argv[])
|
||||||
|
|
||||||
grub_util_load_config (&config);
|
grub_util_load_config (&config);
|
||||||
|
|
||||||
@ -116,7 +118,7 @@ index 78d0138cb..4375c1619 100644
|
|||||||
if (!bootloader_id && config.grub_distributor)
|
if (!bootloader_id && config.grub_distributor)
|
||||||
{
|
{
|
||||||
char *ptr;
|
char *ptr;
|
||||||
@@ -1321,6 +1326,16 @@ main (int argc, char *argv[])
|
@@ -1352,6 +1357,16 @@ main (int argc, char *argv[])
|
||||||
fprintf (load_cfg_f, "set debug='%s'\n",
|
fprintf (load_cfg_f, "set debug='%s'\n",
|
||||||
debug_image);
|
debug_image);
|
||||||
}
|
}
|
||||||
@ -134,7 +136,7 @@ index 78d0138cb..4375c1619 100644
|
|||||||
char *install_drive = NULL;
|
char *install_drive = NULL;
|
||||||
|
|
||||||
diff --git a/util/grub-mkrelpath.c b/util/grub-mkrelpath.c
|
diff --git a/util/grub-mkrelpath.c b/util/grub-mkrelpath.c
|
||||||
index 47a241a39..5db7a9a7d 100644
|
index 47a241a391..5db7a9a7d9 100644
|
||||||
--- a/util/grub-mkrelpath.c
|
--- a/util/grub-mkrelpath.c
|
||||||
+++ b/util/grub-mkrelpath.c
|
+++ b/util/grub-mkrelpath.c
|
||||||
@@ -40,9 +40,12 @@ struct arguments
|
@@ -40,9 +40,12 @@ struct arguments
|
||||||
@ -161,7 +163,7 @@ index 47a241a39..5db7a9a7d 100644
|
|||||||
if (state->arg_num == 0)
|
if (state->arg_num == 0)
|
||||||
arguments->pathname = xstrdup (arg);
|
arguments->pathname = xstrdup (arg);
|
||||||
diff --git a/include/grub/emu/config.h b/include/grub/emu/config.h
|
diff --git a/include/grub/emu/config.h b/include/grub/emu/config.h
|
||||||
index 875d5896c..c9a7e5f4a 100644
|
index 875d5896ce..c9a7e5f4ad 100644
|
||||||
--- a/include/grub/emu/config.h
|
--- a/include/grub/emu/config.h
|
||||||
+++ b/include/grub/emu/config.h
|
+++ b/include/grub/emu/config.h
|
||||||
@@ -37,6 +37,7 @@ struct grub_util_config
|
@@ -37,6 +37,7 @@ struct grub_util_config
|
@ -3,19 +3,20 @@ From: Michael Chang <mchang@suse.com>
|
|||||||
Date: Thu, 21 Aug 2014 03:39:11 +0000
|
Date: Thu, 21 Aug 2014 03:39:11 +0000
|
||||||
Subject: [PATCH] grub2-btrfs-05-grub2-mkconfig
|
Subject: [PATCH] grub2-btrfs-05-grub2-mkconfig
|
||||||
|
|
||||||
|
Signed-off-by: Michael Chang <mchang@suse.com>
|
||||||
---
|
---
|
||||||
util/grub-mkconfig.in | 3 ++-
|
util/grub-mkconfig.in | 3 ++-
|
||||||
util/grub-mkconfig_lib.in | 4 ++++
|
util/grub-mkconfig_lib.in | 4 ++++
|
||||||
util/grub.d/00_header.in | 24 +++++++++++++++++++++++-
|
util/grub.d/00_header.in | 25 ++++++++++++++++++++++++-
|
||||||
util/grub.d/10_linux.in | 4 ++++
|
util/grub.d/10_linux.in | 4 ++++
|
||||||
util/grub.d/20_linux_xen.in | 4 ++++
|
util/grub.d/20_linux_xen.in | 4 ++++
|
||||||
5 files changed, 37 insertions(+), 2 deletions(-)
|
5 files changed, 38 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
diff --git a/util/grub-mkconfig.in b/util/grub-mkconfig.in
|
diff --git a/util/grub-mkconfig.in b/util/grub-mkconfig.in
|
||||||
index 8218f3d47..4248b9341 100644
|
index 005f093809..535c0f0249 100644
|
||||||
--- a/util/grub-mkconfig.in
|
--- a/util/grub-mkconfig.in
|
||||||
+++ b/util/grub-mkconfig.in
|
+++ b/util/grub-mkconfig.in
|
||||||
@@ -258,7 +258,8 @@ export GRUB_DEFAULT \
|
@@ -252,7 +252,8 @@ export GRUB_DEFAULT \
|
||||||
GRUB_BADRAM \
|
GRUB_BADRAM \
|
||||||
GRUB_OS_PROBER_SKIP_LIST \
|
GRUB_OS_PROBER_SKIP_LIST \
|
||||||
GRUB_DISABLE_SUBMENU \
|
GRUB_DISABLE_SUBMENU \
|
||||||
@ -26,10 +27,10 @@ index 8218f3d47..4248b9341 100644
|
|||||||
if test "x${grub_cfg}" != "x"; then
|
if test "x${grub_cfg}" != "x"; then
|
||||||
rm -f "${grub_cfg}.new"
|
rm -f "${grub_cfg}.new"
|
||||||
diff --git a/util/grub-mkconfig_lib.in b/util/grub-mkconfig_lib.in
|
diff --git a/util/grub-mkconfig_lib.in b/util/grub-mkconfig_lib.in
|
||||||
index 113a41f94..b3aae534d 100644
|
index 0f6505bf3b..5e96f6cc5d 100644
|
||||||
--- a/util/grub-mkconfig_lib.in
|
--- a/util/grub-mkconfig_lib.in
|
||||||
+++ b/util/grub-mkconfig_lib.in
|
+++ b/util/grub-mkconfig_lib.in
|
||||||
@@ -52,7 +52,11 @@ grub_warn ()
|
@@ -49,7 +49,11 @@ grub_warn ()
|
||||||
|
|
||||||
make_system_path_relative_to_its_root ()
|
make_system_path_relative_to_its_root ()
|
||||||
{
|
{
|
||||||
@ -42,7 +43,7 @@ index 113a41f94..b3aae534d 100644
|
|||||||
|
|
||||||
is_path_readable_by_grub ()
|
is_path_readable_by_grub ()
|
||||||
diff --git a/util/grub.d/00_header.in b/util/grub.d/00_header.in
|
diff --git a/util/grub.d/00_header.in b/util/grub.d/00_header.in
|
||||||
index 858b526c9..e2a533001 100644
|
index 858b526c92..de727e6ee6 100644
|
||||||
--- a/util/grub.d/00_header.in
|
--- a/util/grub.d/00_header.in
|
||||||
+++ b/util/grub.d/00_header.in
|
+++ b/util/grub.d/00_header.in
|
||||||
@@ -27,6 +27,14 @@ export TEXTDOMAINDIR="@localedir@"
|
@@ -27,6 +27,14 @@ export TEXTDOMAINDIR="@localedir@"
|
||||||
@ -71,12 +72,13 @@ index 858b526c9..e2a533001 100644
|
|||||||
load_env
|
load_env
|
||||||
fi
|
fi
|
||||||
EOF
|
EOF
|
||||||
@@ -356,3 +366,15 @@ fi
|
@@ -356,3 +366,16 @@ fi
|
||||||
if [ "x${GRUB_BADRAM}" != "x" ] ; then
|
if [ "x${GRUB_BADRAM}" != "x" ] ; then
|
||||||
echo "badram ${GRUB_BADRAM}"
|
echo "badram ${GRUB_BADRAM}"
|
||||||
fi
|
fi
|
||||||
+
|
+
|
||||||
+if [ "x${SUSE_BTRFS_SNAPSHOT_BOOTING}" = "xtrue" ] &&
|
+if [ "x${SUSE_BTRFS_SNAPSHOT_BOOTING}" = "xtrue" ] &&
|
||||||
|
+ [ "x${GRUB_ENABLE_BLSCFG}" = "xtrue" ] &&
|
||||||
+ [ "x${GRUB_FS}" = "xbtrfs" ] ; then
|
+ [ "x${GRUB_FS}" = "xbtrfs" ] ; then
|
||||||
+ # Note: No $snapshot_num on *read-only* rollback! (bsc#901487)
|
+ # Note: No $snapshot_num on *read-only* rollback! (bsc#901487)
|
||||||
+ cat <<EOF
|
+ cat <<EOF
|
||||||
@ -88,7 +90,7 @@ index 858b526c9..e2a533001 100644
|
|||||||
+EOF
|
+EOF
|
||||||
+fi
|
+fi
|
||||||
diff --git a/util/grub.d/10_linux.in b/util/grub.d/10_linux.in
|
diff --git a/util/grub.d/10_linux.in b/util/grub.d/10_linux.in
|
||||||
index 4e49ccdf7..d9a05937e 100644
|
index 292e333324..7bb3a211a7 100644
|
||||||
--- a/util/grub.d/10_linux.in
|
--- a/util/grub.d/10_linux.in
|
||||||
+++ b/util/grub.d/10_linux.in
|
+++ b/util/grub.d/10_linux.in
|
||||||
@@ -66,10 +66,14 @@ fi
|
@@ -66,10 +66,14 @@ fi
|
||||||
@ -107,7 +109,7 @@ index 4e49ccdf7..d9a05937e 100644
|
|||||||
xzfs)
|
xzfs)
|
||||||
rpool=`${grub_probe} --device ${GRUB_DEVICE} --target=fs_label 2>/dev/null || true`
|
rpool=`${grub_probe} --device ${GRUB_DEVICE} --target=fs_label 2>/dev/null || true`
|
||||||
diff --git a/util/grub.d/20_linux_xen.in b/util/grub.d/20_linux_xen.in
|
diff --git a/util/grub.d/20_linux_xen.in b/util/grub.d/20_linux_xen.in
|
||||||
index 972a4b5a0..bcdc3ceac 100644
|
index ada20775a1..e9e73b815f 100644
|
||||||
--- a/util/grub.d/20_linux_xen.in
|
--- a/util/grub.d/20_linux_xen.in
|
||||||
+++ b/util/grub.d/20_linux_xen.in
|
+++ b/util/grub.d/20_linux_xen.in
|
||||||
@@ -73,10 +73,14 @@ fi
|
@@ -73,10 +73,14 @@ fi
|
@ -1,8 +1,10 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
From: Michael Chang <mchang@suse.com>
|
From: Michael Chang <mchang@suse.com>
|
||||||
Date: Fri, 22 May 2015 11:45:25 +0000
|
Date: Tue, 9 Jul 2019 13:56:16 +0200
|
||||||
Subject: [PATCH] grub2-btrfs-06-subvol-mount
|
Subject: [PATCH] grub2-btrfs-06-subvol-mount
|
||||||
|
|
||||||
|
Signed-off-by: Michael Chang <mchang@suse.com>
|
||||||
|
Signed-off-by: Robbie Harwood <rharwood@redhat.com>
|
||||||
---
|
---
|
||||||
grub-core/fs/btrfs.c | 195 +++++++++++++++++++++++++++++++++++++++-
|
grub-core/fs/btrfs.c | 195 +++++++++++++++++++++++++++++++++++++++-
|
||||||
grub-core/osdep/linux/getroot.c | 148 +++++++++++++++++++++++++++++-
|
grub-core/osdep/linux/getroot.c | 148 +++++++++++++++++++++++++++++-
|
||||||
@ -11,18 +13,18 @@ Subject: [PATCH] grub2-btrfs-06-subvol-mount
|
|||||||
4 files changed, 392 insertions(+), 5 deletions(-)
|
4 files changed, 392 insertions(+), 5 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/fs/btrfs.c b/grub-core/fs/btrfs.c
|
diff --git a/grub-core/fs/btrfs.c b/grub-core/fs/btrfs.c
|
||||||
index a47d29756..2e36ac47e 100644
|
index 113c1f746c..d323746ecf 100644
|
||||||
--- a/grub-core/fs/btrfs.c
|
--- a/grub-core/fs/btrfs.c
|
||||||
+++ b/grub-core/fs/btrfs.c
|
+++ b/grub-core/fs/btrfs.c
|
||||||
@@ -32,6 +32,7 @@
|
@@ -41,6 +41,7 @@
|
||||||
#include <grub/command.h>
|
#include <grub/command.h>
|
||||||
#include <grub/env.h>
|
#include <grub/env.h>
|
||||||
#include <grub/extcmd.h>
|
#include <grub/extcmd.h>
|
||||||
+#include <grub/list.h>
|
+#include <grub/list.h>
|
||||||
|
#include <grub/crypto.h>
|
||||||
GRUB_MOD_LICENSE ("GPLv3+");
|
#include <grub/diskfilter.h>
|
||||||
|
#include <grub/safemath.h>
|
||||||
@@ -245,6 +246,12 @@ static grub_err_t
|
@@ -266,6 +267,12 @@ static grub_err_t
|
||||||
grub_btrfs_read_logical (struct grub_btrfs_data *data,
|
grub_btrfs_read_logical (struct grub_btrfs_data *data,
|
||||||
grub_disk_addr_t addr, void *buf, grub_size_t size,
|
grub_disk_addr_t addr, void *buf, grub_size_t size,
|
||||||
int recursion_depth);
|
int recursion_depth);
|
||||||
@ -35,7 +37,7 @@ index a47d29756..2e36ac47e 100644
|
|||||||
|
|
||||||
static grub_err_t
|
static grub_err_t
|
||||||
read_sblock (grub_disk_t disk, struct grub_btrfs_superblock *sb)
|
read_sblock (grub_disk_t disk, struct grub_btrfs_superblock *sb)
|
||||||
@@ -887,9 +894,26 @@ lookup_root_by_name(struct grub_btrfs_data *data, const char *path)
|
@@ -1223,9 +1230,26 @@ lookup_root_by_name(struct grub_btrfs_data *data, const char *path)
|
||||||
grub_err_t err;
|
grub_err_t err;
|
||||||
grub_uint64_t tree = 0;
|
grub_uint64_t tree = 0;
|
||||||
grub_uint8_t type;
|
grub_uint8_t type;
|
||||||
@ -62,7 +64,7 @@ index a47d29756..2e36ac47e 100644
|
|||||||
if (err)
|
if (err)
|
||||||
return grub_error(GRUB_ERR_FILE_NOT_FOUND, "couldn't locate %s\n", path);
|
return grub_error(GRUB_ERR_FILE_NOT_FOUND, "couldn't locate %s\n", path);
|
||||||
|
|
||||||
@@ -1758,11 +1782,20 @@ grub_btrfs_dir (grub_device_t device, const char *path,
|
@@ -2199,11 +2223,20 @@ grub_btrfs_dir (grub_device_t device, const char *path,
|
||||||
int r = 0;
|
int r = 0;
|
||||||
grub_uint64_t tree;
|
grub_uint64_t tree;
|
||||||
grub_uint8_t type;
|
grub_uint8_t type;
|
||||||
@ -84,7 +86,7 @@ index a47d29756..2e36ac47e 100644
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
grub_btrfs_unmount (data);
|
grub_btrfs_unmount (data);
|
||||||
@@ -1864,11 +1897,21 @@ grub_btrfs_open (struct grub_file *file, const char *name)
|
@@ -2305,11 +2338,21 @@ grub_btrfs_open (struct grub_file *file, const char *name)
|
||||||
struct grub_btrfs_inode inode;
|
struct grub_btrfs_inode inode;
|
||||||
grub_uint8_t type;
|
grub_uint8_t type;
|
||||||
struct grub_btrfs_key key_in;
|
struct grub_btrfs_key key_in;
|
||||||
@ -107,7 +109,7 @@ index a47d29756..2e36ac47e 100644
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
grub_btrfs_unmount (data);
|
grub_btrfs_unmount (data);
|
||||||
@@ -2039,6 +2082,150 @@ grub_cmd_btrfs_info (grub_command_t cmd __attribute__ ((unused)), int argc,
|
@@ -2480,6 +2523,150 @@ grub_cmd_btrfs_info (grub_command_t cmd __attribute__ ((unused)), int argc,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -258,7 +260,7 @@ index a47d29756..2e36ac47e 100644
|
|||||||
static grub_err_t
|
static grub_err_t
|
||||||
get_fs_root(struct grub_btrfs_data *data, grub_uint64_t tree,
|
get_fs_root(struct grub_btrfs_data *data, grub_uint64_t tree,
|
||||||
grub_uint64_t objectid, grub_uint64_t offset,
|
grub_uint64_t objectid, grub_uint64_t offset,
|
||||||
@@ -2245,6 +2432,7 @@ static struct grub_fs grub_btrfs_fs = {
|
@@ -2686,6 +2873,7 @@ static struct grub_fs grub_btrfs_fs = {
|
||||||
};
|
};
|
||||||
|
|
||||||
static grub_command_t cmd_info;
|
static grub_command_t cmd_info;
|
||||||
@ -266,7 +268,7 @@ index a47d29756..2e36ac47e 100644
|
|||||||
static grub_extcmd_t cmd_list_subvols;
|
static grub_extcmd_t cmd_list_subvols;
|
||||||
|
|
||||||
static char *
|
static char *
|
||||||
@@ -2308,6 +2496,9 @@ GRUB_MOD_INIT (btrfs)
|
@@ -2749,6 +2937,9 @@ GRUB_MOD_INIT (btrfs)
|
||||||
cmd_info = grub_register_command("btrfs-info", grub_cmd_btrfs_info,
|
cmd_info = grub_register_command("btrfs-info", grub_cmd_btrfs_info,
|
||||||
"DEVICE",
|
"DEVICE",
|
||||||
"Print BtrFS info about DEVICE.");
|
"Print BtrFS info about DEVICE.");
|
||||||
@ -277,7 +279,7 @@ index a47d29756..2e36ac47e 100644
|
|||||||
grub_cmd_btrfs_list_subvols, 0,
|
grub_cmd_btrfs_list_subvols, 0,
|
||||||
"[-p|-n] [-o var] DEVICE",
|
"[-p|-n] [-o var] DEVICE",
|
||||||
diff --git a/grub-core/osdep/linux/getroot.c b/grub-core/osdep/linux/getroot.c
|
diff --git a/grub-core/osdep/linux/getroot.c b/grub-core/osdep/linux/getroot.c
|
||||||
index 5d50dd6f8..4c5a13022 100644
|
index caf9b1ccd3..28790307e0 100644
|
||||||
--- a/grub-core/osdep/linux/getroot.c
|
--- a/grub-core/osdep/linux/getroot.c
|
||||||
+++ b/grub-core/osdep/linux/getroot.c
|
+++ b/grub-core/osdep/linux/getroot.c
|
||||||
@@ -107,6 +107,14 @@ struct btrfs_ioctl_search_key
|
@@ -107,6 +107,14 @@ struct btrfs_ioctl_search_key
|
||||||
@ -460,10 +462,10 @@ index 5d50dd6f8..4c5a13022 100644
|
|||||||
grub_make_system_path_relative_to_its_root_os (const char *path)
|
grub_make_system_path_relative_to_its_root_os (const char *path)
|
||||||
{
|
{
|
||||||
diff --git a/util/grub-install.c b/util/grub-install.c
|
diff --git a/util/grub-install.c b/util/grub-install.c
|
||||||
index 4375c1619..a0ad99729 100644
|
index 0f66f36d23..84ed6e88ec 100644
|
||||||
--- a/util/grub-install.c
|
--- a/util/grub-install.c
|
||||||
+++ b/util/grub-install.c
|
+++ b/util/grub-install.c
|
||||||
@@ -1535,6 +1535,55 @@ main (int argc, char *argv[])
|
@@ -1569,6 +1569,55 @@ main (int argc, char *argv[])
|
||||||
prefix_drive = xasprintf ("(%s)", grub_drives[0]);
|
prefix_drive = xasprintf ("(%s)", grub_drives[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -520,7 +522,7 @@ index 4375c1619..a0ad99729 100644
|
|||||||
const char *core_name = NULL;
|
const char *core_name = NULL;
|
||||||
|
|
||||||
diff --git a/include/grub/emu/getroot.h b/include/grub/emu/getroot.h
|
diff --git a/include/grub/emu/getroot.h b/include/grub/emu/getroot.h
|
||||||
index 73fa2d34a..9c642ae3f 100644
|
index 73fa2d34ab..9c642ae3fe 100644
|
||||||
--- a/include/grub/emu/getroot.h
|
--- a/include/grub/emu/getroot.h
|
||||||
+++ b/include/grub/emu/getroot.h
|
+++ b/include/grub/emu/getroot.h
|
||||||
@@ -53,6 +53,11 @@ char **
|
@@ -53,6 +53,11 @@ char **
|
@ -10,10 +10,10 @@ Ref: bsc#953538
|
|||||||
1 file changed, 31 insertions(+), 1 deletion(-)
|
1 file changed, 31 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
diff --git a/grub-core/fs/btrfs.c b/grub-core/fs/btrfs.c
|
diff --git a/grub-core/fs/btrfs.c b/grub-core/fs/btrfs.c
|
||||||
index 2e36ac47e..4a31d39ee 100644
|
index d323746ecf..673ded0352 100644
|
||||||
--- a/grub-core/fs/btrfs.c
|
--- a/grub-core/fs/btrfs.c
|
||||||
+++ b/grub-core/fs/btrfs.c
|
+++ b/grub-core/fs/btrfs.c
|
||||||
@@ -924,11 +924,41 @@ lookup_root_by_name(struct grub_btrfs_data *data, const char *path)
|
@@ -1260,11 +1260,41 @@ lookup_root_by_name(struct grub_btrfs_data *data, const char *path)
|
||||||
return GRUB_ERR_NONE;
|
return GRUB_ERR_NONE;
|
||||||
}
|
}
|
||||||
|
|
@ -3,15 +3,17 @@ From: Michael Chang <mchang@suse.com>
|
|||||||
Date: Thu, 11 May 2017 08:56:57 +0000
|
Date: Thu, 11 May 2017 08:56:57 +0000
|
||||||
Subject: [PATCH] Grub not working correctly with btrfs snapshots (bsc#1026511)
|
Subject: [PATCH] Grub not working correctly with btrfs snapshots (bsc#1026511)
|
||||||
|
|
||||||
|
Signed-off-by: Michael Chang <mchang@suse.com>
|
||||||
|
Signed-off-by: Robbie Harwood <rharwood@redhat.com>
|
||||||
---
|
---
|
||||||
grub-core/fs/btrfs.c | 238 +++++++++++++++++++++++++++++++++++++++++++++++++++
|
grub-core/fs/btrfs.c | 238 +++++++++++++++++++++++++++++++++++++++++++++++++++
|
||||||
1 file changed, 238 insertions(+)
|
1 file changed, 238 insertions(+)
|
||||||
|
|
||||||
diff --git a/grub-core/fs/btrfs.c b/grub-core/fs/btrfs.c
|
diff --git a/grub-core/fs/btrfs.c b/grub-core/fs/btrfs.c
|
||||||
index 4a31d39ee..7002ad81b 100644
|
index 673ded0352..2b21cbaa67 100644
|
||||||
--- a/grub-core/fs/btrfs.c
|
--- a/grub-core/fs/btrfs.c
|
||||||
+++ b/grub-core/fs/btrfs.c
|
+++ b/grub-core/fs/btrfs.c
|
||||||
@@ -2446,6 +2446,238 @@ out:
|
@@ -2887,6 +2887,238 @@ out:
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -249,8 +251,8 @@ index 4a31d39ee..7002ad81b 100644
|
|||||||
+
|
+
|
||||||
static struct grub_fs grub_btrfs_fs = {
|
static struct grub_fs grub_btrfs_fs = {
|
||||||
.name = "btrfs",
|
.name = "btrfs",
|
||||||
.dir = grub_btrfs_dir,
|
.fs_dir = grub_btrfs_dir,
|
||||||
@@ -2464,6 +2696,7 @@ static struct grub_fs grub_btrfs_fs = {
|
@@ -2905,6 +3137,7 @@ static struct grub_fs grub_btrfs_fs = {
|
||||||
static grub_command_t cmd_info;
|
static grub_command_t cmd_info;
|
||||||
static grub_command_t cmd_mount_subvol;
|
static grub_command_t cmd_mount_subvol;
|
||||||
static grub_extcmd_t cmd_list_subvols;
|
static grub_extcmd_t cmd_list_subvols;
|
||||||
@ -258,7 +260,7 @@ index 4a31d39ee..7002ad81b 100644
|
|||||||
|
|
||||||
static char *
|
static char *
|
||||||
subvolid_set_env (struct grub_env_var *var __attribute__ ((unused)),
|
subvolid_set_env (struct grub_env_var *var __attribute__ ((unused)),
|
||||||
@@ -2534,6 +2767,11 @@ GRUB_MOD_INIT (btrfs)
|
@@ -2975,6 +3208,11 @@ GRUB_MOD_INIT (btrfs)
|
||||||
"[-p|-n] [-o var] DEVICE",
|
"[-p|-n] [-o var] DEVICE",
|
||||||
"Print list of BtrFS subvolumes on "
|
"Print list of BtrFS subvolumes on "
|
||||||
"DEVICE.", options);
|
"DEVICE.", options);
|
@ -10,7 +10,7 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
1 file changed, 32 insertions(+), 4 deletions(-)
|
1 file changed, 32 insertions(+), 4 deletions(-)
|
||||||
|
|
||||||
diff --git a/include/grub/efi/efi.h b/include/grub/efi/efi.h
|
diff --git a/include/grub/efi/efi.h b/include/grub/efi/efi.h
|
||||||
index 39480b386..09a18e563 100644
|
index 585fa6662b..03f9a9d011 100644
|
||||||
--- a/include/grub/efi/efi.h
|
--- a/include/grub/efi/efi.h
|
||||||
+++ b/include/grub/efi/efi.h
|
+++ b/include/grub/efi/efi.h
|
||||||
@@ -24,6 +24,10 @@
|
@@ -24,6 +24,10 @@
|
||||||
@ -58,7 +58,7 @@ index 39480b386..09a18e563 100644
|
|||||||
grub_efi_loaded_image_t *EXPORT_FUNC(grub_efi_get_loaded_image) (grub_efi_handle_t image_handle);
|
grub_efi_loaded_image_t *EXPORT_FUNC(grub_efi_get_loaded_image) (grub_efi_handle_t image_handle);
|
||||||
void EXPORT_FUNC(grub_efi_print_device_path) (grub_efi_device_path_t *dp);
|
void EXPORT_FUNC(grub_efi_print_device_path) (grub_efi_device_path_t *dp);
|
||||||
char *EXPORT_FUNC(grub_efi_get_filename) (grub_efi_device_path_t *dp);
|
char *EXPORT_FUNC(grub_efi_get_filename) (grub_efi_device_path_t *dp);
|
||||||
@@ -109,10 +140,7 @@ void grub_efi_init (void);
|
@@ -115,10 +146,7 @@ void grub_efi_init (void);
|
||||||
void grub_efi_fini (void);
|
void grub_efi_fini (void);
|
||||||
void grub_efi_set_prefix (void);
|
void grub_efi_set_prefix (void);
|
||||||
|
|
@ -13,7 +13,7 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
1 file changed, 9 insertions(+), 15 deletions(-)
|
1 file changed, 9 insertions(+), 15 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/loader/efi/chainloader.c b/grub-core/loader/efi/chainloader.c
|
diff --git a/grub-core/loader/efi/chainloader.c b/grub-core/loader/efi/chainloader.c
|
||||||
index 5cd9b6e08..106eb10a3 100644
|
index 07c4937898..89ac84cc66 100644
|
||||||
--- a/grub-core/loader/efi/chainloader.c
|
--- a/grub-core/loader/efi/chainloader.c
|
||||||
+++ b/grub-core/loader/efi/chainloader.c
|
+++ b/grub-core/loader/efi/chainloader.c
|
||||||
@@ -65,7 +65,7 @@ grub_chainloader_unload (void)
|
@@ -65,7 +65,7 @@ grub_chainloader_unload (void)
|
||||||
@ -34,7 +34,7 @@ index 5cd9b6e08..106eb10a3 100644
|
|||||||
|
|
||||||
grub_loader_unset ();
|
grub_loader_unset ();
|
||||||
|
|
||||||
@@ -500,10 +500,9 @@ grub_efi_get_media_file_path (grub_efi_device_path_t *dp)
|
@@ -527,10 +527,9 @@ grub_efi_get_media_file_path (grub_efi_device_path_t *dp)
|
||||||
static grub_efi_boolean_t
|
static grub_efi_boolean_t
|
||||||
handle_image (void *data, grub_efi_uint32_t datasize)
|
handle_image (void *data, grub_efi_uint32_t datasize)
|
||||||
{
|
{
|
||||||
@ -46,7 +46,7 @@ index 5cd9b6e08..106eb10a3 100644
|
|||||||
char *buffer_aligned = NULL;
|
char *buffer_aligned = NULL;
|
||||||
grub_efi_uint32_t i;
|
grub_efi_uint32_t i;
|
||||||
struct grub_pe32_section_table *section;
|
struct grub_pe32_section_table *section;
|
||||||
@@ -514,8 +513,6 @@ handle_image (void *data, grub_efi_uint32_t datasize)
|
@@ -541,8 +540,6 @@ handle_image (void *data, grub_efi_uint32_t datasize)
|
||||||
int found_entry_point = 0;
|
int found_entry_point = 0;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
@ -55,7 +55,7 @@ index 5cd9b6e08..106eb10a3 100644
|
|||||||
rc = read_header (data, datasize, &context);
|
rc = read_header (data, datasize, &context);
|
||||||
if (rc < 0)
|
if (rc < 0)
|
||||||
{
|
{
|
||||||
@@ -555,8 +552,8 @@ handle_image (void *data, grub_efi_uint32_t datasize)
|
@@ -582,8 +579,8 @@ handle_image (void *data, grub_efi_uint32_t datasize)
|
||||||
grub_dprintf ("chain", "image size is %08"PRIxGRUB_UINT64_T", datasize is %08x\n",
|
grub_dprintf ("chain", "image size is %08"PRIxGRUB_UINT64_T", datasize is %08x\n",
|
||||||
context.image_size, datasize);
|
context.image_size, datasize);
|
||||||
|
|
||||||
@ -66,7 +66,7 @@ index 5cd9b6e08..106eb10a3 100644
|
|||||||
|
|
||||||
if (efi_status != GRUB_EFI_SUCCESS)
|
if (efi_status != GRUB_EFI_SUCCESS)
|
||||||
{
|
{
|
||||||
@@ -788,14 +785,14 @@ handle_image (void *data, grub_efi_uint32_t datasize)
|
@@ -815,14 +812,14 @@ handle_image (void *data, grub_efi_uint32_t datasize)
|
||||||
|
|
||||||
grub_dprintf ("chain", "entry_point returned %ld\n", efi_status);
|
grub_dprintf ("chain", "entry_point returned %ld\n", efi_status);
|
||||||
grub_memcpy (li, &li_bak, sizeof (grub_efi_loaded_image_t));
|
grub_memcpy (li, &li_bak, sizeof (grub_efi_loaded_image_t));
|
||||||
@ -83,7 +83,7 @@ index 5cd9b6e08..106eb10a3 100644
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@@ -803,10 +800,7 @@ error_exit:
|
@@ -830,10 +827,7 @@ error_exit:
|
||||||
static grub_err_t
|
static grub_err_t
|
||||||
grub_secureboot_chainloader_unload (void)
|
grub_secureboot_chainloader_unload (void)
|
||||||
{
|
{
|
||||||
@ -95,7 +95,7 @@ index 5cd9b6e08..106eb10a3 100644
|
|||||||
grub_free (file_path);
|
grub_free (file_path);
|
||||||
grub_free (cmdline);
|
grub_free (cmdline);
|
||||||
cmdline = 0;
|
cmdline = 0;
|
||||||
@@ -1073,7 +1067,7 @@ fail:
|
@@ -1100,7 +1094,7 @@ fail:
|
||||||
grub_free (file_path);
|
grub_free (file_path);
|
||||||
|
|
||||||
if (address)
|
if (address)
|
@ -8,14 +8,14 @@ This avoids syntax checkers getting confused about if it's llx or lx.
|
|||||||
Signed-off-by: Peter Jones <pjones@redhat.com>
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
---
|
---
|
||||||
grub-core/loader/efi/chainloader.c | 3 ++-
|
grub-core/loader/efi/chainloader.c | 3 ++-
|
||||||
include/grub/efi/api.h | 8 ++++++++
|
include/grub/efi/api.h | 9 +++++++++
|
||||||
2 files changed, 10 insertions(+), 1 deletion(-)
|
2 files changed, 11 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
diff --git a/grub-core/loader/efi/chainloader.c b/grub-core/loader/efi/chainloader.c
|
diff --git a/grub-core/loader/efi/chainloader.c b/grub-core/loader/efi/chainloader.c
|
||||||
index 106eb10a3..3630b0cbf 100644
|
index 89ac84cc66..ac8dfd40c6 100644
|
||||||
--- a/grub-core/loader/efi/chainloader.c
|
--- a/grub-core/loader/efi/chainloader.c
|
||||||
+++ b/grub-core/loader/efi/chainloader.c
|
+++ b/grub-core/loader/efi/chainloader.c
|
||||||
@@ -783,7 +783,8 @@ handle_image (void *data, grub_efi_uint32_t datasize)
|
@@ -810,7 +810,8 @@ handle_image (void *data, grub_efi_uint32_t datasize)
|
||||||
efi_status = efi_call_2 (entry_point, grub_efi_image_handle,
|
efi_status = efi_call_2 (entry_point, grub_efi_image_handle,
|
||||||
grub_efi_system_table);
|
grub_efi_system_table);
|
||||||
|
|
||||||
@ -26,13 +26,15 @@ index 106eb10a3..3630b0cbf 100644
|
|||||||
efi_status = grub_efi_free_pool (buffer);
|
efi_status = grub_efi_free_pool (buffer);
|
||||||
|
|
||||||
diff --git a/include/grub/efi/api.h b/include/grub/efi/api.h
|
diff --git a/include/grub/efi/api.h b/include/grub/efi/api.h
|
||||||
index 28b6adf76..e5b521bd9 100644
|
index 117469450d..9962880147 100644
|
||||||
--- a/include/grub/efi/api.h
|
--- a/include/grub/efi/api.h
|
||||||
+++ b/include/grub/efi/api.h
|
+++ b/include/grub/efi/api.h
|
||||||
@@ -527,6 +527,14 @@ typedef grub_uint8_t grub_efi_char8_t;
|
@@ -546,7 +546,16 @@ typedef grub_uint64_t grub_efi_uint64_t;
|
||||||
|
typedef grub_uint8_t grub_efi_char8_t;
|
||||||
typedef grub_uint16_t grub_efi_char16_t;
|
typedef grub_uint16_t grub_efi_char16_t;
|
||||||
|
|
||||||
typedef grub_efi_intn_t grub_efi_status_t;
|
+
|
||||||
|
typedef grub_efi_uintn_t grub_efi_status_t;
|
||||||
+/* Make grub_efi_status_t reasonably printable. */
|
+/* Make grub_efi_status_t reasonably printable. */
|
||||||
+#if GRUB_CPU_SIZEOF_VOID_P == 8
|
+#if GRUB_CPU_SIZEOF_VOID_P == 8
|
||||||
+#define PRIxGRUB_EFI_STATUS "lx"
|
+#define PRIxGRUB_EFI_STATUS "lx"
|
@ -8,10 +8,10 @@ Subject: [PATCH] don't use int for efi status
|
|||||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
diff --git a/grub-core/kern/efi/efi.c b/grub-core/kern/efi/efi.c
|
diff --git a/grub-core/kern/efi/efi.c b/grub-core/kern/efi/efi.c
|
||||||
index 562d6887e..bcae7f469 100644
|
index 05d8237a9b..ae9885edb8 100644
|
||||||
--- a/grub-core/kern/efi/efi.c
|
--- a/grub-core/kern/efi/efi.c
|
||||||
+++ b/grub-core/kern/efi/efi.c
|
+++ b/grub-core/kern/efi/efi.c
|
||||||
@@ -166,7 +166,7 @@ grub_reboot (void)
|
@@ -167,7 +167,7 @@ grub_reboot (void)
|
||||||
void
|
void
|
||||||
grub_exit (int retval)
|
grub_exit (int retval)
|
||||||
{
|
{
|
@ -8,7 +8,7 @@ Subject: [PATCH] make GRUB_MOD_INIT() declare its function prototypes.
|
|||||||
1 file changed, 2 insertions(+)
|
1 file changed, 2 insertions(+)
|
||||||
|
|
||||||
diff --git a/include/grub/dl.h b/include/grub/dl.h
|
diff --git a/include/grub/dl.h b/include/grub/dl.h
|
||||||
index 2bca56ce0..b1ed3c333 100644
|
index b3753c9ca2..91933b85f2 100644
|
||||||
--- a/include/grub/dl.h
|
--- a/include/grub/dl.h
|
||||||
+++ b/include/grub/dl.h
|
+++ b/include/grub/dl.h
|
||||||
@@ -54,6 +54,7 @@ grub_mod_fini (void)
|
@@ -54,6 +54,7 @@ grub_mod_fini (void)
|
@ -16,10 +16,10 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
1 file changed, 1 insertion(+), 11 deletions(-)
|
1 file changed, 1 insertion(+), 11 deletions(-)
|
||||||
|
|
||||||
diff --git a/util/grub-install.c b/util/grub-install.c
|
diff --git a/util/grub-install.c b/util/grub-install.c
|
||||||
index a0ad99729..16f137ca8 100644
|
index 84ed6e88ec..a2bec7446c 100644
|
||||||
--- a/util/grub-install.c
|
--- a/util/grub-install.c
|
||||||
+++ b/util/grub-install.c
|
+++ b/util/grub-install.c
|
||||||
@@ -1159,18 +1159,8 @@ main (int argc, char *argv[])
|
@@ -1190,18 +1190,8 @@ main (int argc, char *argv[])
|
||||||
char *d;
|
char *d;
|
||||||
|
|
||||||
is_guess = 1;
|
is_guess = 1;
|
@ -0,0 +1,47 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Peter Jones <pjones@redhat.com>
|
||||||
|
Date: Tue, 9 Jul 2019 14:31:19 +0200
|
||||||
|
Subject: [PATCH] 20_linux_xen: load xen or multiboot{,2} modules as needed.
|
||||||
|
|
||||||
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
|
---
|
||||||
|
util/grub.d/20_linux_xen.in | 5 +++++
|
||||||
|
1 file changed, 5 insertions(+)
|
||||||
|
|
||||||
|
diff --git a/util/grub.d/20_linux_xen.in b/util/grub.d/20_linux_xen.in
|
||||||
|
index e9e73b815f..c23b064be6 100644
|
||||||
|
--- a/util/grub.d/20_linux_xen.in
|
||||||
|
+++ b/util/grub.d/20_linux_xen.in
|
||||||
|
@@ -153,6 +153,7 @@ linux_entry_xsm ()
|
||||||
|
else
|
||||||
|
xen_rm_opts="no-real-mode edd=off"
|
||||||
|
fi
|
||||||
|
+ insmod ${xen_module}
|
||||||
|
${xen_loader} ${rel_xen_dirname}/${xen_basename} placeholder ${xen_args} \${xen_rm_opts}
|
||||||
|
echo '$(echo "$lmessage" | grub_quote)'
|
||||||
|
${module_loader} ${rel_dirname}/${basename} placeholder root=${linux_root_device_thisversion} ro ${args}
|
||||||
|
@@ -166,6 +167,7 @@ EOF
|
||||||
|
done
|
||||||
|
sed "s/^/$submenu_indentation/" << EOF
|
||||||
|
echo '$(echo "$message" | grub_quote)'
|
||||||
|
+ insmod ${xen_module}
|
||||||
|
${module_loader} --nounzip $(echo $initrd_path)
|
||||||
|
EOF
|
||||||
|
fi
|
||||||
|
@@ -253,13 +255,16 @@ while [ "x${xen_list}" != "x" ] ; do
|
||||||
|
echo " submenu '$(gettext_printf "Xen hypervisor, version %s" "${xen_version}" | grub_quote)' \$menuentry_id_option 'xen-hypervisor-$xen_version-$boot_device_id' {"
|
||||||
|
fi
|
||||||
|
if ($grub_file --is-arm64-efi $current_xen); then
|
||||||
|
+ xen_module="xen_boot"
|
||||||
|
xen_loader="xen_hypervisor"
|
||||||
|
module_loader="xen_module"
|
||||||
|
else
|
||||||
|
if ($grub_file --is-x86-multiboot2 $current_xen); then
|
||||||
|
+ xen_module="multiboot2"
|
||||||
|
xen_loader="multiboot2"
|
||||||
|
module_loader="module2"
|
||||||
|
else
|
||||||
|
+ xen_module="multiboot"
|
||||||
|
xen_loader="multiboot"
|
||||||
|
module_loader="module"
|
||||||
|
fi
|
@ -63,7 +63,7 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
1 file changed, 89 insertions(+), 20 deletions(-)
|
1 file changed, 89 insertions(+), 20 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/kern/i386/tsc_pmtimer.c b/grub-core/kern/i386/tsc_pmtimer.c
|
diff --git a/grub-core/kern/i386/tsc_pmtimer.c b/grub-core/kern/i386/tsc_pmtimer.c
|
||||||
index c9c361699..ca15c3aac 100644
|
index c9c3616997..ca15c3aacd 100644
|
||||||
--- a/grub-core/kern/i386/tsc_pmtimer.c
|
--- a/grub-core/kern/i386/tsc_pmtimer.c
|
||||||
+++ b/grub-core/kern/i386/tsc_pmtimer.c
|
+++ b/grub-core/kern/i386/tsc_pmtimer.c
|
||||||
@@ -28,40 +28,101 @@
|
@@ -28,40 +28,101 @@
|
@ -9,7 +9,7 @@ Subject: [PATCH] align struct efi_variable better...
|
|||||||
2 files changed, 2 insertions(+), 1 deletion(-)
|
2 files changed, 2 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
diff --git a/include/grub/efiemu/runtime.h b/include/grub/efiemu/runtime.h
|
diff --git a/include/grub/efiemu/runtime.h b/include/grub/efiemu/runtime.h
|
||||||
index 36d2dedf4..9d93ba88b 100644
|
index 36d2dedf47..9d93ba88ba 100644
|
||||||
--- a/include/grub/efiemu/runtime.h
|
--- a/include/grub/efiemu/runtime.h
|
||||||
+++ b/include/grub/efiemu/runtime.h
|
+++ b/include/grub/efiemu/runtime.h
|
||||||
@@ -33,5 +33,5 @@ struct efi_variable
|
@@ -33,5 +33,5 @@ struct efi_variable
|
||||||
@ -20,7 +20,7 @@ index 36d2dedf4..9d93ba88b 100644
|
|||||||
+} GRUB_PACKED GRUB_ALIGNED(8);
|
+} GRUB_PACKED GRUB_ALIGNED(8);
|
||||||
#endif /* ! GRUB_EFI_EMU_RUNTIME_HEADER */
|
#endif /* ! GRUB_EFI_EMU_RUNTIME_HEADER */
|
||||||
diff --git a/include/grub/types.h b/include/grub/types.h
|
diff --git a/include/grub/types.h b/include/grub/types.h
|
||||||
index b93e48201..f6a972397 100644
|
index 0a3ff15913..ba446d9904 100644
|
||||||
--- a/include/grub/types.h
|
--- a/include/grub/types.h
|
||||||
+++ b/include/grub/types.h
|
+++ b/include/grub/types.h
|
||||||
@@ -29,6 +29,7 @@
|
@@ -29,6 +29,7 @@
|
382
0058-Add-BLS-support-to-grub-mkconfig.patch
Normal file
382
0058-Add-BLS-support-to-grub-mkconfig.patch
Normal file
@ -0,0 +1,382 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Peter Jones <pjones@redhat.com>
|
||||||
|
Date: Fri, 9 Dec 2016 15:40:29 -0500
|
||||||
|
Subject: [PATCH] Add BLS support to grub-mkconfig
|
||||||
|
|
||||||
|
GRUB now has BootLoaderSpec support, the user can choose to use this by
|
||||||
|
setting GRUB_ENABLE_BLSCFG to true in /etc/default/grub. On this setup,
|
||||||
|
the boot menu entries are not added to the grub.cfg, instead BLS config
|
||||||
|
files are parsed by blscfg command and the entries created dynamically.
|
||||||
|
|
||||||
|
A 10_linux_bls grub.d snippet to generate menu entries from BLS files
|
||||||
|
is also added that can be used on platforms where the bootloader doesn't
|
||||||
|
have BLS support and only can parse a normal grub configuration file.
|
||||||
|
|
||||||
|
Portions of the 10_linux_bls were taken from the ostree-grub-generator
|
||||||
|
script that's included in the OSTree project.
|
||||||
|
|
||||||
|
Fixes to support multi-devices and generate a BLS section even if no
|
||||||
|
kernels are found in the boot directory were proposed by Yclept Nemo
|
||||||
|
and Tom Gundersen respectively.
|
||||||
|
|
||||||
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
|
[javierm: remove outdated URL for BLS document]
|
||||||
|
Signed-off-by: Javier Martinez Canillas <javierm@redhat.com>
|
||||||
|
[iwienand@redhat.com: skip machine ID check when updating entries]
|
||||||
|
Signed-off-by: Ian Wienand <iwienand@redhat.com>
|
||||||
|
[rharwood: use sort(1), commit message composits, drop man pages]
|
||||||
|
Signed-off-by: Robbie Harwood <rharwood@redhat.com>
|
||||||
|
---
|
||||||
|
util/grub-mkconfig.in | 9 +-
|
||||||
|
util/grub-mkconfig_lib.in | 22 ++++-
|
||||||
|
util/grub.d/10_linux.in | 218 +++++++++++++++++++++++++++++++++++++++++++++-
|
||||||
|
3 files changed, 243 insertions(+), 6 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/util/grub-mkconfig.in b/util/grub-mkconfig.in
|
||||||
|
index 535c0f0249..f55339a3f6 100644
|
||||||
|
--- a/util/grub-mkconfig.in
|
||||||
|
+++ b/util/grub-mkconfig.in
|
||||||
|
@@ -50,6 +50,8 @@ grub_get_kernel_settings="${sbindir}/@grub_get_kernel_settings@"
|
||||||
|
export TEXTDOMAIN=@PACKAGE@
|
||||||
|
export TEXTDOMAINDIR="@localedir@"
|
||||||
|
|
||||||
|
+export GRUB_GRUBENV_UPDATE="yes"
|
||||||
|
+
|
||||||
|
. "${pkgdatadir}/grub-mkconfig_lib"
|
||||||
|
|
||||||
|
# Usage: usage
|
||||||
|
@@ -59,6 +61,7 @@ usage () {
|
||||||
|
gettext "Generate a grub config file"; echo
|
||||||
|
echo
|
||||||
|
print_option_help "-o, --output=$(gettext FILE)" "$(gettext "output generated config to FILE [default=stdout]")"
|
||||||
|
+ print_option_help "--no-grubenv-update" "$(gettext "do not update variables in the grubenv file")"
|
||||||
|
print_option_help "-h, --help" "$(gettext "print this message and exit")"
|
||||||
|
print_option_help "-V, --version" "$(gettext "print the version information and exit")"
|
||||||
|
echo
|
||||||
|
@@ -94,6 +97,9 @@ do
|
||||||
|
--output=*)
|
||||||
|
grub_cfg=`echo "$option" | sed 's/--output=//'`
|
||||||
|
;;
|
||||||
|
+ --no-grubenv-update)
|
||||||
|
+ GRUB_GRUBENV_UPDATE="no"
|
||||||
|
+ ;;
|
||||||
|
-*)
|
||||||
|
gettext_printf "Unrecognized option \`%s'\n" "$option" 1>&2
|
||||||
|
usage
|
||||||
|
@@ -253,7 +259,8 @@ export GRUB_DEFAULT \
|
||||||
|
GRUB_OS_PROBER_SKIP_LIST \
|
||||||
|
GRUB_DISABLE_SUBMENU \
|
||||||
|
GRUB_DEFAULT_DTB \
|
||||||
|
- SUSE_BTRFS_SNAPSHOT_BOOTING
|
||||||
|
+ SUSE_BTRFS_SNAPSHOT_BOOTING \
|
||||||
|
+ GRUB_ENABLE_BLSCFG
|
||||||
|
|
||||||
|
if test "x${grub_cfg}" != "x"; then
|
||||||
|
rm -f "${grub_cfg}.new"
|
||||||
|
diff --git a/util/grub-mkconfig_lib.in b/util/grub-mkconfig_lib.in
|
||||||
|
index 5e96f6cc5d..301d8a8a1e 100644
|
||||||
|
--- a/util/grub-mkconfig_lib.in
|
||||||
|
+++ b/util/grub-mkconfig_lib.in
|
||||||
|
@@ -30,6 +30,9 @@ fi
|
||||||
|
if test "x$grub_file" = x; then
|
||||||
|
grub_file="${bindir}/@grub_file@"
|
||||||
|
fi
|
||||||
|
+if test "x$grub_editenv" = x; then
|
||||||
|
+ grub_editenv="${bindir}/@grub_editenv@"
|
||||||
|
+fi
|
||||||
|
if test "x$grub_mkrelpath" = x; then
|
||||||
|
grub_mkrelpath="${bindir}/@grub_mkrelpath@"
|
||||||
|
fi
|
||||||
|
@@ -122,8 +125,19 @@ EOF
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
+prepare_grub_to_access_device_with_variable ()
|
||||||
|
+{
|
||||||
|
+ device_variable="$1"
|
||||||
|
+ shift
|
||||||
|
+ prepare_grub_to_access_device "$@"
|
||||||
|
+ unset "device_variable"
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
prepare_grub_to_access_device ()
|
||||||
|
{
|
||||||
|
+ if [ -z "$device_variable" ]; then
|
||||||
|
+ device_variable="root"
|
||||||
|
+ fi
|
||||||
|
old_ifs="$IFS"
|
||||||
|
IFS='
|
||||||
|
'
|
||||||
|
@@ -158,18 +172,18 @@ prepare_grub_to_access_device ()
|
||||||
|
# otherwise set root as per value in device.map.
|
||||||
|
fs_hint="`"${grub_probe}" --device $@ --target=compatibility_hint`"
|
||||||
|
if [ "x$fs_hint" != x ]; then
|
||||||
|
- echo "set root='$fs_hint'"
|
||||||
|
+ echo "set ${device_variable}='$fs_hint'"
|
||||||
|
fi
|
||||||
|
if [ "x${GRUB_DISABLE_UUID}" != "xtrue" ] && fs_uuid="`"${grub_probe}" --device $@ --target=fs_uuid 2> /dev/null`" ; then
|
||||||
|
hints="`"${grub_probe}" --device $@ --target=hints_string 2> /dev/null`" || hints=
|
||||||
|
if [ "x$hints" != x ]; then
|
||||||
|
echo "if [ x\$feature_platform_search_hint = xy ]; then"
|
||||||
|
- echo " search --no-floppy --fs-uuid --set=root ${hints} ${fs_uuid}"
|
||||||
|
+ echo " search --no-floppy --fs-uuid --set=${device_variable} ${hints} ${fs_uuid}"
|
||||||
|
echo "else"
|
||||||
|
- echo " search --no-floppy --fs-uuid --set=root ${fs_uuid}"
|
||||||
|
+ echo " search --no-floppy --fs-uuid --set=${device_variable} ${fs_uuid}"
|
||||||
|
echo "fi"
|
||||||
|
else
|
||||||
|
- echo "search --no-floppy --fs-uuid --set=root ${fs_uuid}"
|
||||||
|
+ echo "search --no-floppy --fs-uuid --set=${device_variable} ${fs_uuid}"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
IFS="$old_ifs"
|
||||||
|
diff --git a/util/grub.d/10_linux.in b/util/grub.d/10_linux.in
|
||||||
|
index 7bb3a211a7..2851952659 100644
|
||||||
|
--- a/util/grub.d/10_linux.in
|
||||||
|
+++ b/util/grub.d/10_linux.in
|
||||||
|
@@ -82,6 +82,218 @@ case x"$GRUB_FS" in
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
+populate_header_warn()
|
||||||
|
+{
|
||||||
|
+if [ "x${BLS_POPULATE_MENU}" = "xtrue" ]; then
|
||||||
|
+ bls_parser="10_linux script"
|
||||||
|
+else
|
||||||
|
+ bls_parser="blscfg command"
|
||||||
|
+fi
|
||||||
|
+cat <<EOF
|
||||||
|
+
|
||||||
|
+# This section was generated by a script. Do not modify the generated file - all changes
|
||||||
|
+# will be lost the next time file is regenerated. Instead edit the BootLoaderSpec files.
|
||||||
|
+#
|
||||||
|
+# The $bls_parser parses the BootLoaderSpec files stored in /boot/loader/entries and
|
||||||
|
+# populates the boot menu. Please refer to the Boot Loader Specification documentation
|
||||||
|
+# for the files format: https://systemd.io/BOOT_LOADER_SPECIFICATION/.
|
||||||
|
+
|
||||||
|
+EOF
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+read_config()
|
||||||
|
+{
|
||||||
|
+ config_file=${1}
|
||||||
|
+ title=""
|
||||||
|
+ initrd=""
|
||||||
|
+ options=""
|
||||||
|
+ linux=""
|
||||||
|
+ grub_arg=""
|
||||||
|
+
|
||||||
|
+ while read -r line
|
||||||
|
+ do
|
||||||
|
+ record=$(echo ${line} | cut -f 1 -d ' ')
|
||||||
|
+ value=$(echo ${line} | cut -s -f2- -d ' ')
|
||||||
|
+ case "${record}" in
|
||||||
|
+ "title")
|
||||||
|
+ title=${value}
|
||||||
|
+ ;;
|
||||||
|
+ "initrd")
|
||||||
|
+ initrd=${value}
|
||||||
|
+ ;;
|
||||||
|
+ "linux")
|
||||||
|
+ linux=${value}
|
||||||
|
+ ;;
|
||||||
|
+ "options")
|
||||||
|
+ options=${value}
|
||||||
|
+ ;;
|
||||||
|
+ "grub_arg")
|
||||||
|
+ grub_arg=${value}
|
||||||
|
+ ;;
|
||||||
|
+ esac
|
||||||
|
+ done < ${config_file}
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+blsdir="/boot/loader/entries"
|
||||||
|
+
|
||||||
|
+get_sorted_bls()
|
||||||
|
+{
|
||||||
|
+ if ! [ -d "${blsdir}" ]; then
|
||||||
|
+ return
|
||||||
|
+ fi
|
||||||
|
+
|
||||||
|
+ local IFS=$'\n'
|
||||||
|
+
|
||||||
|
+ files=($(for bls in ${blsdir}/*.conf; do
|
||||||
|
+ if ! [[ -e "${bls}" ]] ; then
|
||||||
|
+ continue
|
||||||
|
+ fi
|
||||||
|
+ bls="${bls%.conf}"
|
||||||
|
+ bls="${bls##*/}"
|
||||||
|
+ echo "${bls}"
|
||||||
|
+ done | sort -Vr 2>/dev/null)) || :
|
||||||
|
+
|
||||||
|
+ echo "${files[@]}"
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+update_bls_cmdline()
|
||||||
|
+{
|
||||||
|
+ local cmdline="root=${LINUX_ROOT_DEVICE} ro ${GRUB_CMDLINE_LINUX} ${GRUB_CMDLINE_LINUX_DEFAULT}"
|
||||||
|
+ local -a files=($(get_sorted_bls))
|
||||||
|
+
|
||||||
|
+ for bls in "${files[@]}"; do
|
||||||
|
+ local options="${cmdline}"
|
||||||
|
+ if [ -z "${bls##*debug*}" ]; then
|
||||||
|
+ options="${options} ${GRUB_CMDLINE_LINUX_DEBUG}"
|
||||||
|
+ fi
|
||||||
|
+ options="$(echo "${options}" | sed -e 's/\//\\\//g')"
|
||||||
|
+ sed -i -e "s/^options.*/options ${options}/" "${blsdir}/${bls}.conf"
|
||||||
|
+ done
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+populate_menu()
|
||||||
|
+{
|
||||||
|
+ local -a files=($(get_sorted_bls))
|
||||||
|
+
|
||||||
|
+ gettext_printf "Generating boot entries from BLS files...\n" >&2
|
||||||
|
+
|
||||||
|
+ for bls in "${files[@]}"; do
|
||||||
|
+ read_config "${blsdir}/${bls}.conf"
|
||||||
|
+
|
||||||
|
+ menu="${menu}menuentry '${title}' ${grub_arg} --id=${bls} {\n"
|
||||||
|
+ menu="${menu}\t linux ${linux} ${options}\n"
|
||||||
|
+ if [ -n "${initrd}" ] ; then
|
||||||
|
+ menu="${menu}\t initrd ${boot_prefix}${initrd}\n"
|
||||||
|
+ fi
|
||||||
|
+ menu="${menu}}\n\n"
|
||||||
|
+ done
|
||||||
|
+ # The printf command seems to be more reliable across shells for special character (\n, \t) evaluation
|
||||||
|
+ printf "$menu"
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Make BLS the default if GRUB_ENABLE_BLSCFG was not set and grubby is not installed.
|
||||||
|
+if [ -z "${GRUB_ENABLE_BLSCFG}" ] && ! command -v new-kernel-pkg >/dev/null; then
|
||||||
|
+ GRUB_ENABLE_BLSCFG="true"
|
||||||
|
+fi
|
||||||
|
+
|
||||||
|
+if [ "x${GRUB_ENABLE_BLSCFG}" = "xtrue" ]; then
|
||||||
|
+ if [ x$dirname = x/ ]; then
|
||||||
|
+ if [ -z "${prepare_root_cache}" ]; then
|
||||||
|
+ prepare_grub_to_access_device ${GRUB_DEVICE}
|
||||||
|
+ fi
|
||||||
|
+ else
|
||||||
|
+ if [ -z "${prepare_boot_cache}" ]; then
|
||||||
|
+ prepare_grub_to_access_device ${GRUB_DEVICE_BOOT}
|
||||||
|
+ fi
|
||||||
|
+ fi
|
||||||
|
+
|
||||||
|
+ if [ -d /sys/firmware/efi ]; then
|
||||||
|
+ bootefi_device="`${grub_probe} --target=device /boot/efi/`"
|
||||||
|
+ prepare_grub_to_access_device_with_variable boot ${bootefi_device}
|
||||||
|
+ else
|
||||||
|
+ boot_device="`${grub_probe} --target=device /boot/`"
|
||||||
|
+ prepare_grub_to_access_device_with_variable boot ${boot_device}
|
||||||
|
+ fi
|
||||||
|
+
|
||||||
|
+ arch="$(uname -m)"
|
||||||
|
+ if [ "x${arch}" = "xppc64le" ] && [ -d /sys/firmware/opal ]; then
|
||||||
|
+
|
||||||
|
+ BLS_POPULATE_MENU="true"
|
||||||
|
+ petitboot_path="/sys/firmware/devicetree/base/ibm,firmware-versions/petitboot"
|
||||||
|
+
|
||||||
|
+ if test -e ${petitboot_path}; then
|
||||||
|
+ read -r -d '' petitboot_version < ${petitboot_path}
|
||||||
|
+ petitboot_version="$(echo ${petitboot_version//v})"
|
||||||
|
+
|
||||||
|
+ if test -n ${petitboot_version}; then
|
||||||
|
+ major_version="$(echo ${petitboot_version} | cut -d . -f1)"
|
||||||
|
+ minor_version="$(echo ${petitboot_version} | cut -d . -f2)"
|
||||||
|
+
|
||||||
|
+ re='^[0-9]+$'
|
||||||
|
+ if [[ $major_version =~ $re ]] && [[ $minor_version =~ $re ]] &&
|
||||||
|
+ ([[ ${major_version} -gt 1 ]] ||
|
||||||
|
+ [[ ${major_version} -eq 1 &&
|
||||||
|
+ ${minor_version} -ge 8 ]]); then
|
||||||
|
+ BLS_POPULATE_MENU="false"
|
||||||
|
+ fi
|
||||||
|
+ fi
|
||||||
|
+ fi
|
||||||
|
+ fi
|
||||||
|
+
|
||||||
|
+ populate_header_warn
|
||||||
|
+
|
||||||
|
+ cat << EOF
|
||||||
|
+# The kernelopts variable should be defined in the grubenv file. But to ensure that menu
|
||||||
|
+# entries populated from BootLoaderSpec files that use this variable work correctly even
|
||||||
|
+# without a grubenv file, define a fallback kernelopts variable if this has not been set.
|
||||||
|
+#
|
||||||
|
+# The kernelopts variable in the grubenv file can be modified using the grubby tool or by
|
||||||
|
+# executing the grub2-mkconfig tool. For the latter, the values of the GRUB_CMDLINE_LINUX
|
||||||
|
+# and GRUB_CMDLINE_LINUX_DEFAULT options from /etc/default/grub file are used to set both
|
||||||
|
+# the kernelopts variable in the grubenv file and the fallback kernelopts variable.
|
||||||
|
+if [ -z "\${kernelopts}" ]; then
|
||||||
|
+ set kernelopts="root=${LINUX_ROOT_DEVICE} ro ${GRUB_CMDLINE_LINUX} ${GRUB_CMDLINE_LINUX_DEFAULT}"
|
||||||
|
+fi
|
||||||
|
+EOF
|
||||||
|
+
|
||||||
|
+ update_bls_cmdline
|
||||||
|
+
|
||||||
|
+ if [ "x${BLS_POPULATE_MENU}" = "xtrue" ]; then
|
||||||
|
+ populate_menu
|
||||||
|
+ else
|
||||||
|
+ cat << EOF
|
||||||
|
+
|
||||||
|
+insmod blscfg
|
||||||
|
+blscfg
|
||||||
|
+EOF
|
||||||
|
+ fi
|
||||||
|
+
|
||||||
|
+ if [ "x${GRUB_GRUBENV_UPDATE}" = "xyes" ]; then
|
||||||
|
+ blsdir="/boot/loader/entries"
|
||||||
|
+ [ -d "${blsdir}" ] && GRUB_BLS_FS="$(${grub_probe} --target=fs ${blsdir})"
|
||||||
|
+ if [ "x${GRUB_BLS_FS}" = "xbtrfs" ] || [ "x${GRUB_BLS_FS}" = "xzfs" ]; then
|
||||||
|
+ blsdir=$(make_system_path_relative_to_its_root "${blsdir}")
|
||||||
|
+ if [ "x${blsdir}" != "x/loader/entries" ] && [ "x${blsdir}" != "x/boot/loader/entries" ]; then
|
||||||
|
+ ${grub_editenv} - set blsdir="${blsdir}"
|
||||||
|
+ fi
|
||||||
|
+ fi
|
||||||
|
+
|
||||||
|
+ if [ -n "${GRUB_EARLY_INITRD_LINUX_CUSTOM}" ]; then
|
||||||
|
+ ${grub_editenv} - set early_initrd="${GRUB_EARLY_INITRD_LINUX_CUSTOM}"
|
||||||
|
+ fi
|
||||||
|
+
|
||||||
|
+ if [ -n "${GRUB_DEFAULT_DTB}" ]; then
|
||||||
|
+ ${grub_editenv} - set devicetree="${GRUB_DEFAULT_DTB}"
|
||||||
|
+ fi
|
||||||
|
+
|
||||||
|
+ if [ -n "${GRUB_SAVEDEFAULT}" ]; then
|
||||||
|
+ ${grub_editenv} - set save_default="${GRUB_SAVEDEFAULT}"
|
||||||
|
+ fi
|
||||||
|
+ fi
|
||||||
|
+
|
||||||
|
+ exit 0
|
||||||
|
+fi
|
||||||
|
+
|
||||||
|
mktitle ()
|
||||||
|
{
|
||||||
|
local title_type
|
||||||
|
@@ -121,6 +333,7 @@ linux_entry ()
|
||||||
|
if [ -z "$boot_device_id" ]; then
|
||||||
|
boot_device_id="$(grub_get_device_id "${GRUB_DEVICE}")"
|
||||||
|
fi
|
||||||
|
+
|
||||||
|
if [ x$type != xsimple ] ; then
|
||||||
|
title=$(mktitle "$type" "$version")
|
||||||
|
if [ x"$title" = x"$GRUB_ACTUAL_DEFAULT" ] || [ x"Previous Linux versions>$title" = x"$GRUB_ACTUAL_DEFAULT" ]; then
|
||||||
|
@@ -231,6 +444,7 @@ is_top_level=true
|
||||||
|
while [ "x$list" != "x" ] ; do
|
||||||
|
linux=`version_find_latest $list`
|
||||||
|
gettext_printf "Found linux image: %s\n" "$linux" >&2
|
||||||
|
+
|
||||||
|
basename=`basename $linux`
|
||||||
|
dirname=`dirname $linux`
|
||||||
|
rel_dirname=`make_system_path_relative_to_its_root $dirname`
|
||||||
|
@@ -269,7 +483,9 @@ while [ "x$list" != "x" ] ; do
|
||||||
|
for i in ${initrd}; do
|
||||||
|
initrd_display="${initrd_display} ${dirname}/${i}"
|
||||||
|
done
|
||||||
|
- gettext_printf "Found initrd image: %s\n" "$(echo $initrd_display)" >&2
|
||||||
|
+ if [ "x${GRUB_ENABLE_BLSCFG}" != "xtrue" ]; then
|
||||||
|
+ gettext_printf "Found initrd image: %s\n" "$(echo $initrd_display)" >&2
|
||||||
|
+ fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
fdt=
|
@ -12,10 +12,10 @@ Signed-off-by: Javier Martinez Canillas <javierm@redhat.com>
|
|||||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
diff --git a/grub-core/kern/misc.c b/grub-core/kern/misc.c
|
diff --git a/grub-core/kern/misc.c b/grub-core/kern/misc.c
|
||||||
index 04371ac49..636f97e1b 100644
|
index a3e215155b..c60601b699 100644
|
||||||
--- a/grub-core/kern/misc.c
|
--- a/grub-core/kern/misc.c
|
||||||
+++ b/grub-core/kern/misc.c
|
+++ b/grub-core/kern/misc.c
|
||||||
@@ -1103,7 +1103,7 @@ static void __attribute__ ((noreturn))
|
@@ -1201,7 +1201,7 @@ static void __attribute__ ((noreturn))
|
||||||
grub_abort (void)
|
grub_abort (void)
|
||||||
{
|
{
|
||||||
#ifndef GRUB_UTIL
|
#ifndef GRUB_UTIL
|
@ -4,17 +4,23 @@ Date: Thu, 15 Mar 2018 14:12:40 -0400
|
|||||||
Subject: [PATCH] Add grub2-switch-to-blscfg
|
Subject: [PATCH] Add grub2-switch-to-blscfg
|
||||||
|
|
||||||
Signed-off-by: Peter Jones <pjones@redhat.com>
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
|
Signed-off-by: Javier Martinez Canillas <javierm@redhat.com>
|
||||||
|
[jhlavac: Use ${etcdefaultgrub} instead of /etc/default/grub]
|
||||||
|
Signed-off-by: Jan Hlavac <jhlavac@redhat.com>
|
||||||
|
[rharwood: skip on ostree installations, migrate man to h2m]
|
||||||
|
Signed-off-by: Robbie Harwood <rharwood@redhat.com>
|
||||||
---
|
---
|
||||||
Makefile.util.def | 7 ++
|
Makefile.util.def | 7 +
|
||||||
.gitignore | 2 +
|
docs/man/grub-switch-to-blscfg.h2m | 2 +
|
||||||
util/grub-switch-to-blscfg.8 | 25 ++++
|
util/grub-set-password.in | 2 +-
|
||||||
util/grub-switch-to-blscfg.in | 262 ++++++++++++++++++++++++++++++++++++++++++
|
util/grub-switch-to-blscfg.in | 317 +++++++++++++++++++++++++++++++++++++
|
||||||
4 files changed, 296 insertions(+)
|
util/grub.d/10_linux.in | 2 +-
|
||||||
create mode 100644 util/grub-switch-to-blscfg.8
|
5 files changed, 328 insertions(+), 2 deletions(-)
|
||||||
|
create mode 100644 docs/man/grub-switch-to-blscfg.h2m
|
||||||
create mode 100644 util/grub-switch-to-blscfg.in
|
create mode 100644 util/grub-switch-to-blscfg.in
|
||||||
|
|
||||||
diff --git a/Makefile.util.def b/Makefile.util.def
|
diff --git a/Makefile.util.def b/Makefile.util.def
|
||||||
index 879e8eb98..f4fbd2506 100644
|
index 18a9242776..88f55e35c4 100644
|
||||||
--- a/Makefile.util.def
|
--- a/Makefile.util.def
|
||||||
+++ b/Makefile.util.def
|
+++ b/Makefile.util.def
|
||||||
@@ -1348,6 +1348,13 @@ program = {
|
@@ -1348,6 +1348,13 @@ program = {
|
||||||
@ -31,56 +37,32 @@ index 879e8eb98..f4fbd2506 100644
|
|||||||
program = {
|
program = {
|
||||||
name = grub-glue-efi;
|
name = grub-glue-efi;
|
||||||
mansection = 1;
|
mansection = 1;
|
||||||
diff --git a/.gitignore b/.gitignore
|
diff --git a/docs/man/grub-switch-to-blscfg.h2m b/docs/man/grub-switch-to-blscfg.h2m
|
||||||
index 54795fa60..424755921 100644
|
|
||||||
--- a/.gitignore
|
|
||||||
+++ b/.gitignore
|
|
||||||
@@ -121,6 +121,8 @@ grub-*.tar.*
|
|
||||||
/grub*-sparc64-setup.8
|
|
||||||
/grub*-syslinux2cfg
|
|
||||||
/grub*-syslinux2cfg.1
|
|
||||||
+/grub*-switch-to-blscfg
|
|
||||||
+/grub*-switch-to-blscfg.8
|
|
||||||
/grub_fstest.pp
|
|
||||||
/grub_fstest_init.c
|
|
||||||
/grub_fstest_init.lst
|
|
||||||
diff --git a/util/grub-switch-to-blscfg.8 b/util/grub-switch-to-blscfg.8
|
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..134dfc62a
|
index 0000000000..fa341426a5
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/util/grub-switch-to-blscfg.8
|
+++ b/docs/man/grub-switch-to-blscfg.h2m
|
||||||
@@ -0,0 +1,25 @@
|
@@ -0,0 +1,2 @@
|
||||||
+.TH GRUB-SWITCH-TO-BLSCFG 1 "Wed Feb 26 2014"
|
+[NAME]
|
||||||
+.SH NAME
|
+grub-switch-to-blscfg \- switch to using BLS config files
|
||||||
+\fBgrub-switch-to-blscfg\fR \(em Switch to using BLS config files.
|
diff --git a/util/grub-set-password.in b/util/grub-set-password.in
|
||||||
+
|
index 5ebf50576d..c0b5ebbfdc 100644
|
||||||
+.SH SYNOPSIS
|
--- a/util/grub-set-password.in
|
||||||
+\fBgrub-switch-to-blscfg\fR [--grub-directory=\fIDIR\fR] [--config-file=\fIFILE\fR] [--grub-defaults=\fIFILE\fR]
|
+++ b/util/grub-set-password.in
|
||||||
+
|
@@ -1,6 +1,6 @@
|
||||||
+.SH DESCRIPTION
|
#!/bin/sh -e
|
||||||
+\fBgrub-switch-to-blscfg\fR reconfigures grub-mkconfig to use BLS-style config files, and then regenerates the GRUB configuration.
|
|
||||||
+
|
-EFIDIR=$(grep ^ID= /etc/os-release | sed -e 's/^ID=//' -e 's/rhel/redhat/')
|
||||||
+.SH OPTIONS
|
+EFIDIR=$(grep ^ID= /etc/os-release | sed -e 's/^ID=//' -e 's/rhel/redhat/' -e 's/\"//g')
|
||||||
+.TP
|
if [ -d /sys/firmware/efi/efivars/ ]; then
|
||||||
+--grub-directory=\fIDIR\fR
|
grubdir=`echo "/@bootdirname@/efi/EFI/${EFIDIR}/" | sed 's,//*,/,g'`
|
||||||
+Search for grub.cfg under \fIDIR\fR. The default value is \fI/boot/efi/EFI/\fBVENDOR\fR on UEFI machines and \fI/boot/grub2\fR elsewhere.
|
else
|
||||||
+
|
|
||||||
+.TP
|
|
||||||
+--config-file=\fIFILE\fR
|
|
||||||
+The grub config file to use. The default value is \fI/etc/grub2-efi.cfg\fR on UEFI machines and \fI/etc/grub2.cfg\fR elsewhere. Symbolic links will be followed.
|
|
||||||
+
|
|
||||||
+.TP
|
|
||||||
+--grub-defaults=\fIFILE\fR
|
|
||||||
+The defaults file for grub-mkconfig. The default value is \fI/etc/default/grub\fR.
|
|
||||||
+
|
|
||||||
+.SH SEE ALSO
|
|
||||||
+.BR "info grub"
|
|
||||||
diff --git a/util/grub-switch-to-blscfg.in b/util/grub-switch-to-blscfg.in
|
diff --git a/util/grub-switch-to-blscfg.in b/util/grub-switch-to-blscfg.in
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..3ae5e4ea8
|
index 0000000000..a851424beb
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/util/grub-switch-to-blscfg.in
|
+++ b/util/grub-switch-to-blscfg.in
|
||||||
@@ -0,0 +1,262 @@
|
@@ -0,0 +1,317 @@
|
||||||
+#! /bin/sh
|
+#! /bin/sh
|
||||||
+#
|
+#
|
||||||
+# Set a default boot entry for GRUB.
|
+# Set a default boot entry for GRUB.
|
||||||
@ -104,6 +86,7 @@ index 000000000..3ae5e4ea8
|
|||||||
+# Initialize some variables.
|
+# Initialize some variables.
|
||||||
+prefix=@prefix@
|
+prefix=@prefix@
|
||||||
+exec_prefix=@exec_prefix@
|
+exec_prefix=@exec_prefix@
|
||||||
|
+sbindir=@sbindir@
|
||||||
+bindir=@bindir@
|
+bindir=@bindir@
|
||||||
+sysconfdir="@sysconfdir@"
|
+sysconfdir="@sysconfdir@"
|
||||||
+PACKAGE_NAME=@PACKAGE_NAME@
|
+PACKAGE_NAME=@PACKAGE_NAME@
|
||||||
@ -116,22 +99,27 @@ index 000000000..3ae5e4ea8
|
|||||||
+
|
+
|
||||||
+self=`basename $0`
|
+self=`basename $0`
|
||||||
+
|
+
|
||||||
|
+grub_get_kernel_settings="${sbindir}/@grub_get_kernel_settings@"
|
||||||
+grub_editenv=${bindir}/@grub_editenv@
|
+grub_editenv=${bindir}/@grub_editenv@
|
||||||
+etcdefaultgrub=/etc/default/grub
|
+etcdefaultgrub=/etc/default/grub
|
||||||
+
|
+
|
||||||
+EFIDIR=$(grep ^ID= /etc/os-release | sed -e 's/^ID=//' -e 's/rhel/redhat/')
|
+eval "$("${grub_get_kernel_settings}")" || true
|
||||||
|
+
|
||||||
|
+EFIDIR=$(grep ^ID= /etc/os-release | sed -e 's/^ID=//' -e 's/rhel/redhat/' -e 's/\"//g')
|
||||||
+if [ -d /sys/firmware/efi/efivars/ ]; then
|
+if [ -d /sys/firmware/efi/efivars/ ]; then
|
||||||
+ startlink=/etc/grub2-efi.cfg
|
+ startlink=/etc/grub2-efi.cfg
|
||||||
+ grubdir=`echo "/@bootdirname@/efi/EFI/${EFIDIR}/" | sed 's,//*,/,g'`
|
+ grubdir=`echo "/@bootdirname@/efi/EFI/${EFIDIR}/" | sed 's,//*,/,g'`
|
||||||
+ blsdir=`echo "/@bootdirname@/efi/EFI/${EFIDIR}/loader/entries" | sed 's,//*,/,g'`
|
|
||||||
+else
|
+else
|
||||||
+ startlink=/etc/grub2.cfg
|
+ startlink=/etc/grub2.cfg
|
||||||
+ grubdir=`echo "/@bootdirname@/@grubdirname@" | sed 's,//*,/,g'`
|
+ grubdir=`echo "/@bootdirname@/@grubdirname@" | sed 's,//*,/,g'`
|
||||||
+ blsdir=`echo "/@bootdirname@" | sed 's,//*,/,g'`
|
|
||||||
+fi
|
+fi
|
||||||
+
|
+
|
||||||
|
+blsdir=`echo "/@bootdirname@/loader/entries" | sed 's,//*,/,g'`
|
||||||
|
+
|
||||||
+backupsuffix=.bak
|
+backupsuffix=.bak
|
||||||
+
|
+
|
||||||
|
+arch="$(uname -m)"
|
||||||
|
+
|
||||||
+export TEXTDOMAIN=@PACKAGE@
|
+export TEXTDOMAIN=@PACKAGE@
|
||||||
+export TEXTDOMAINDIR="@localedir@"
|
+export TEXTDOMAINDIR="@localedir@"
|
||||||
+
|
+
|
||||||
@ -230,18 +218,18 @@ index 000000000..3ae5e4ea8
|
|||||||
+
|
+
|
||||||
+find_grub_cfg() {
|
+find_grub_cfg() {
|
||||||
+ local candidate=""
|
+ local candidate=""
|
||||||
+ while [[ -e "${candidate}" || $# -gt 0 ]]
|
+ while [ -e "${candidate}" -o $# -gt 0 ]
|
||||||
+ do
|
+ do
|
||||||
+ if [[ ! -e "${candidate}" ]] ; then
|
+ if [ ! -e "${candidate}" ] ; then
|
||||||
+ candidate="$1"
|
+ candidate="$1"
|
||||||
+ shift
|
+ shift
|
||||||
+ fi
|
+ fi
|
||||||
+
|
+
|
||||||
+ if [[ -L "${candidate}" ]]; then
|
+ if [ -L "${candidate}" ]; then
|
||||||
+ candidate="$(realpath "${candidate}")"
|
+ candidate="$(realpath "${candidate}")"
|
||||||
+ fi
|
+ fi
|
||||||
+
|
+
|
||||||
+ if [[ -f "${candidate}" ]]; then
|
+ if [ -f "${candidate}" ]; then
|
||||||
+ export GRUB_CONFIG_FILE="${candidate}"
|
+ export GRUB_CONFIG_FILE="${candidate}"
|
||||||
+ return 0
|
+ return 0
|
||||||
+ fi
|
+ fi
|
||||||
@ -254,11 +242,11 @@ index 000000000..3ae5e4ea8
|
|||||||
+ exit 1
|
+ exit 1
|
||||||
+fi
|
+fi
|
||||||
+
|
+
|
||||||
+if [[ ! -d "${blsdir}" ]]; then
|
+if [ ! -d "${blsdir}" ]; then
|
||||||
+ install -m 700 -d "${blsdir}"
|
+ install -m 700 -d "${blsdir}"
|
||||||
+fi
|
+fi
|
||||||
+
|
+
|
||||||
+if [[ -f /etc/machine-id ]]; then
|
+if [ -f /etc/machine-id ]; then
|
||||||
+ MACHINE_ID=$(cat /etc/machine-id)
|
+ MACHINE_ID=$(cat /etc/machine-id)
|
||||||
+else
|
+else
|
||||||
+ MACHINE_ID=$(dmesg | sha256sum)
|
+ MACHINE_ID=$(dmesg | sha256sum)
|
||||||
@ -267,14 +255,17 @@ index 000000000..3ae5e4ea8
|
|||||||
+mkbls() {
|
+mkbls() {
|
||||||
+ local kernelver=$1 && shift
|
+ local kernelver=$1 && shift
|
||||||
+ local datetime=$1 && shift
|
+ local datetime=$1 && shift
|
||||||
|
+ local kernelopts=$1 && shift
|
||||||
+
|
+
|
||||||
+ local debugname=""
|
+ local debugname=""
|
||||||
|
+ local debugid=""
|
||||||
+ local flavor=""
|
+ local flavor=""
|
||||||
+
|
+
|
||||||
+ if [[ "$kernelver" == *\+* ]] ; then
|
+ if [ "$kernelver" == *\+* ] ; then
|
||||||
+ local flavor=-"${kernelver##*+}"
|
+ local flavor=-"${kernelver##*+}"
|
||||||
+ if [[ "${flavor}" == "-debug" ]]; then
|
+ if [ "${flavor}" == "-debug" ]; then
|
||||||
+ local debugname=" with debugging"
|
+ local debugname=" with debugging"
|
||||||
|
+ local debugid="-debug"
|
||||||
+ fi
|
+ fi
|
||||||
+ fi
|
+ fi
|
||||||
+ (
|
+ (
|
||||||
@ -282,10 +273,10 @@ index 000000000..3ae5e4ea8
|
|||||||
+
|
+
|
||||||
+ cat <<EOF
|
+ cat <<EOF
|
||||||
+title ${NAME} (${kernelver}) ${VERSION}${debugname}
|
+title ${NAME} (${kernelver}) ${VERSION}${debugname}
|
||||||
|
+version ${kernelver}${debugid}
|
||||||
+linux /vmlinuz-${kernelver}
|
+linux /vmlinuz-${kernelver}
|
||||||
+initrd /initramfs-${kernelver}.img
|
+initrd /initramfs-${kernelver}.img
|
||||||
+options \$kernelopts
|
+options ${kernelopts}
|
||||||
+id ${ID}-${datetime}-${kernelver}
|
|
||||||
+grub_users \$grub_users
|
+grub_users \$grub_users
|
||||||
+grub_arg --unrestricted
|
+grub_arg --unrestricted
|
||||||
+grub_class kernel${flavor}
|
+grub_class kernel${flavor}
|
||||||
@ -293,23 +284,55 @@ index 000000000..3ae5e4ea8
|
|||||||
+ ) | cat
|
+ ) | cat
|
||||||
+}
|
+}
|
||||||
+
|
+
|
||||||
+for kernelver in $(cd /lib/modules/ ; ls -1) "" ; do
|
+copy_bls() {
|
||||||
+ if [[ ! -d "/lib/modules/${kernelver}" ]] ; then
|
+ for kernelver in $(cd /lib/modules/ ; ls -1) "" ; do
|
||||||
+ continue
|
|
||||||
+ fi
|
|
||||||
+ if [[ ! -f "/boot/vmlinuz-${kernelver}" ]]; then
|
|
||||||
+ continue
|
|
||||||
+ fi
|
|
||||||
+ bls_target="${blsdir}/${MACHINE_ID}-${kernelver}.conf"
|
+ bls_target="${blsdir}/${MACHINE_ID}-${kernelver}.conf"
|
||||||
|
+ linux="/vmlinuz-${kernelver}"
|
||||||
|
+ linux_path="/boot${linux}"
|
||||||
+ kernel_dir="/lib/modules/${kernelver}"
|
+ kernel_dir="/lib/modules/${kernelver}"
|
||||||
+ if [[ -f "${kernel_dir}/bls.conf" ]]; then
|
+
|
||||||
+ cp -af "${kernel_dir}/bls.conf" "${bls_target}"
|
+ if [ ! -d "${kernel_dir}" ] ; then
|
||||||
+ else
|
+ continue
|
||||||
|
+ fi
|
||||||
|
+ if [ ! -f "${linux_path}" ]; then
|
||||||
|
+ continue
|
||||||
|
+ fi
|
||||||
|
+
|
||||||
|
+ linux_relpath="$("${grub_mkrelpath}" "${linux_path}")"
|
||||||
|
+ bootprefix="${linux_relpath%%"${linux}"}"
|
||||||
|
+ cmdline="root=${LINUX_ROOT_DEVICE} ro ${GRUB_CMDLINE_LINUX} ${GRUB_CMDLINE_LINUX_DEFAULT}"
|
||||||
|
+
|
||||||
+ mkbls "${kernelver}" \
|
+ mkbls "${kernelver}" \
|
||||||
+ "$(date -u +%Y%m%d%H%M%S -d "$(stat -c '%y' "${kernel_dir}")")" \
|
+ "$(date -u +%Y%m%d%H%M%S -d "$(stat -c '%y' "${kernel_dir}")")" \
|
||||||
+ >"${bls_target}"
|
+ "${bootprefix}" "${cmdline}" >"${bls_target}"
|
||||||
|
+
|
||||||
|
+ if [ "x$GRUB_LINUX_MAKE_DEBUG" = "xtrue" ]; then
|
||||||
|
+ bls_debug="$(echo ${bls_target} | sed -e "s/${kernelver}/${kernelver}~debug/")"
|
||||||
|
+ cp -aT "${bls_target}" "${bls_debug}"
|
||||||
|
+ title="$(grep '^title[ \t]' "${bls_debug}" | sed -e 's/^title[ \t]*//')"
|
||||||
|
+ options="$(echo "${cmdline} ${GRUB_CMDLINE_LINUX_DEBUG}" | sed -e 's/\//\\\//g')"
|
||||||
|
+ sed -i -e "s/^title.*/title ${title}${GRUB_LINUX_DEBUG_TITLE_POSTFIX}/" "${bls_debug}"
|
||||||
|
+ sed -i -e "s/^options.*/options ${options}/" "${bls_debug}"
|
||||||
+ fi
|
+ fi
|
||||||
+done
|
+ done
|
||||||
|
+
|
||||||
|
+ if [ -f "/boot/vmlinuz-0-rescue-${MACHINE_ID}" ]; then
|
||||||
|
+ mkbls "0-rescue-${MACHINE_ID}" "0" "${bootprefix}" >"${blsdir}/${MACHINE_ID}-0-rescue.conf"
|
||||||
|
+ fi
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# The grub2 EFI binary is not copied to the ESP as a part of an ostree
|
||||||
|
+# transaction. Make sure a grub2 version with BLS support is installed
|
||||||
|
+# but only do this if the blsdir is not set, to make sure that the BLS
|
||||||
|
+# parsing module will search for the BLS snippets in the default path.
|
||||||
|
+if test -f /run/ostree-booted && test -d /sys/firmware/efi/efivars && \
|
||||||
|
+ ! ${grub_editenv} - list | grep -q blsdir && \
|
||||||
|
+ mountpoint -q /boot; then
|
||||||
|
+ grub_binary="$(find /usr/lib/ostree-boot/efi/EFI/${EFIDIR}/ -name grub*.efi)"
|
||||||
|
+ install -m 700 ${grub_binary} ${grubdir} || exit 1
|
||||||
|
+ # Create a hidden file to indicate that grub2 now has BLS support.
|
||||||
|
+ touch /boot/grub2/.grub2-blscfg-supported
|
||||||
|
+fi
|
||||||
+
|
+
|
||||||
+GENERATE=0
|
+GENERATE=0
|
||||||
+if grep '^GRUB_ENABLE_BLSCFG=.*' "${etcdefaultgrub}" \
|
+if grep '^GRUB_ENABLE_BLSCFG=.*' "${etcdefaultgrub}" \
|
||||||
@ -329,13 +352,27 @@ index 000000000..3ae5e4ea8
|
|||||||
+ GENERATE=1
|
+ GENERATE=1
|
||||||
+fi
|
+fi
|
||||||
+
|
+
|
||||||
+if [[ "${GENERATE}" -eq 1 ]] ; then
|
+if [ "${GENERATE}" -eq 1 ] ; then
|
||||||
|
+ copy_bls
|
||||||
|
+
|
||||||
|
+ if [ $arch = "x86_64" ] && [ ! -d /sys/firmware/efi ]; then
|
||||||
|
+ mod_dir="i386-pc"
|
||||||
|
+ elif [ $arch = "ppc64" -o $arch = "ppc64le" ] && [ ! -d /sys/firmware/opal ]; then
|
||||||
|
+ mod_dir="powerpc-ieee1275"
|
||||||
|
+ fi
|
||||||
|
+
|
||||||
|
+ if [ -n "${mod_dir}" ]; then
|
||||||
|
+ for mod in blscfg increment; do
|
||||||
|
+ install -m 700 ${prefix}/lib/grub/${mod_dir}/${mod}.mod ${grubdir}/$mod_dir/ || exit 1
|
||||||
|
+ done
|
||||||
|
+ fi
|
||||||
|
+
|
||||||
+ cp -af "${GRUB_CONFIG_FILE}" "${GRUB_CONFIG_FILE}${backupsuffix}"
|
+ cp -af "${GRUB_CONFIG_FILE}" "${GRUB_CONFIG_FILE}${backupsuffix}"
|
||||||
+ if ! grub2-mkconfig -o "${GRUB_CONFIG_FILE}" ; then
|
+ if ! grub2-mkconfig -o "${GRUB_CONFIG_FILE}" ; then
|
||||||
+ cp -af "${GRUB_CONFIG_FILE}${backupsuffix}" "${GRUB_CONFIG_FILE}"
|
+ install -m 700 "${GRUB_CONFIG_FILE}${backupsuffix}" "${GRUB_CONFIG_FILE}"
|
||||||
+ sed -i"${backupsuffix}" \
|
+ sed -i"${backupsuffix}" \
|
||||||
+ -e 's,^GRUB_ENABLE_BLSCFG=.*,GRUB_ENABLE_BLSCFG=false,' \
|
+ -e 's,^GRUB_ENABLE_BLSCFG=.*,GRUB_ENABLE_BLSCFG=false,' \
|
||||||
+ /etc/default/grub
|
+ "${etcdefaultgrub}"
|
||||||
+ gettext_printf "Updating %s failed\n" "${GRUB_CONFIG_FILE}"
|
+ gettext_printf "Updating %s failed\n" "${GRUB_CONFIG_FILE}"
|
||||||
+ exit 1
|
+ exit 1
|
||||||
+ fi
|
+ fi
|
||||||
@ -343,3 +380,16 @@ index 000000000..3ae5e4ea8
|
|||||||
+
|
+
|
||||||
+# Bye.
|
+# Bye.
|
||||||
+exit 0
|
+exit 0
|
||||||
|
diff --git a/util/grub.d/10_linux.in b/util/grub.d/10_linux.in
|
||||||
|
index 2851952659..e490e1a43a 100644
|
||||||
|
--- a/util/grub.d/10_linux.in
|
||||||
|
+++ b/util/grub.d/10_linux.in
|
||||||
|
@@ -138,7 +138,7 @@ blsdir="/boot/loader/entries"
|
||||||
|
|
||||||
|
get_sorted_bls()
|
||||||
|
{
|
||||||
|
- if ! [ -d "${blsdir}" ]; then
|
||||||
|
+ if ! [ -d "${blsdir}" ] || [ -f /run/ostree-booted ] || [ -d /ostree/repo ]; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
@ -1,12 +1,12 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
From: Peter Jones <pjones@redhat.com>
|
From: Peter Jones <pjones@redhat.com>
|
||||||
Date: Mon, 6 Nov 2017 18:31:56 -0500
|
Date: Tue, 9 Jul 2019 17:05:03 +0200
|
||||||
Subject: [PATCH] make better backtraces
|
Subject: [PATCH] make better backtraces
|
||||||
|
|
||||||
Signed-off-by: Peter Jones <pjones@redhat.com>
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
---
|
---
|
||||||
Makefile.util.def | 6 ++
|
Makefile.util.def | 6 ++
|
||||||
grub-core/Makefile.core.def | 15 ++--
|
grub-core/Makefile.core.def | 16 ++--
|
||||||
grub-core/{lib => commands}/backtrace.c | 2 +-
|
grub-core/{lib => commands}/backtrace.c | 2 +-
|
||||||
grub-core/gdb/cstub.c | 1 -
|
grub-core/gdb/cstub.c | 1 -
|
||||||
grub-core/kern/arm64/backtrace.c | 94 ++++++++++++++++++++++++
|
grub-core/kern/arm64/backtrace.c | 94 ++++++++++++++++++++++++
|
||||||
@ -29,7 +29,7 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
grub-core/kern/ia64/efi/startup.S | 3 +-
|
grub-core/kern/ia64/efi/startup.S | 3 +-
|
||||||
grub-core/kern/sparc64/ieee1275/crt0.S | 3 +-
|
grub-core/kern/sparc64/ieee1275/crt0.S | 3 +-
|
||||||
grub-core/Makefile.am | 1 +
|
grub-core/Makefile.am | 1 +
|
||||||
24 files changed, 414 insertions(+), 166 deletions(-)
|
24 files changed, 414 insertions(+), 167 deletions(-)
|
||||||
rename grub-core/{lib => commands}/backtrace.c (98%)
|
rename grub-core/{lib => commands}/backtrace.c (98%)
|
||||||
create mode 100644 grub-core/kern/arm64/backtrace.c
|
create mode 100644 grub-core/kern/arm64/backtrace.c
|
||||||
create mode 100644 grub-core/kern/backtrace.c
|
create mode 100644 grub-core/kern/backtrace.c
|
||||||
@ -38,10 +38,10 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
delete mode 100644 grub-core/lib/i386/backtrace.c
|
delete mode 100644 grub-core/lib/i386/backtrace.c
|
||||||
|
|
||||||
diff --git a/Makefile.util.def b/Makefile.util.def
|
diff --git a/Makefile.util.def b/Makefile.util.def
|
||||||
index f4fbd2506..cbd661d63 100644
|
index 88f55e35c4..bda9fd1211 100644
|
||||||
--- a/Makefile.util.def
|
--- a/Makefile.util.def
|
||||||
+++ b/Makefile.util.def
|
+++ b/Makefile.util.def
|
||||||
@@ -49,6 +49,12 @@ library = {
|
@@ -51,6 +51,12 @@ library = {
|
||||||
common = grub-core/partmap/msdos.c;
|
common = grub-core/partmap/msdos.c;
|
||||||
common = grub-core/fs/proc.c;
|
common = grub-core/fs/proc.c;
|
||||||
common = grub-core/fs/archelp.c;
|
common = grub-core/fs/archelp.c;
|
||||||
@ -55,13 +55,13 @@ index f4fbd2506..cbd661d63 100644
|
|||||||
|
|
||||||
library = {
|
library = {
|
||||||
diff --git a/grub-core/Makefile.core.def b/grub-core/Makefile.core.def
|
diff --git a/grub-core/Makefile.core.def b/grub-core/Makefile.core.def
|
||||||
index 067b97a42..cb24f92a4 100644
|
index 058c88ac3a..52ec0fafcd 100644
|
||||||
--- a/grub-core/Makefile.core.def
|
--- a/grub-core/Makefile.core.def
|
||||||
+++ b/grub-core/Makefile.core.def
|
+++ b/grub-core/Makefile.core.def
|
||||||
@@ -130,6 +130,12 @@ kernel = {
|
@@ -142,6 +142,12 @@ kernel = {
|
||||||
common = kern/rescue_reader.c;
|
common = kern/rescue_reader.c;
|
||||||
common = kern/term.c;
|
common = kern/term.c;
|
||||||
common = kern/qsort.c;
|
common = kern/verifiers.c;
|
||||||
+ common = kern/backtrace.c;
|
+ common = kern/backtrace.c;
|
||||||
+
|
+
|
||||||
+ x86 = kern/i386/backtrace.c;
|
+ x86 = kern/i386/backtrace.c;
|
||||||
@ -71,7 +71,7 @@ index 067b97a42..cb24f92a4 100644
|
|||||||
|
|
||||||
noemu = kern/compiler-rt.c;
|
noemu = kern/compiler-rt.c;
|
||||||
noemu = kern/mm.c;
|
noemu = kern/mm.c;
|
||||||
@@ -176,9 +182,6 @@ kernel = {
|
@@ -188,9 +194,6 @@ kernel = {
|
||||||
|
|
||||||
softdiv = lib/division.c;
|
softdiv = lib/division.c;
|
||||||
|
|
||||||
@ -80,17 +80,19 @@ index 067b97a42..cb24f92a4 100644
|
|||||||
-
|
-
|
||||||
i386 = kern/i386/dl.c;
|
i386 = kern/i386/dl.c;
|
||||||
i386_xen = kern/i386/dl.c;
|
i386_xen = kern/i386/dl.c;
|
||||||
|
i386_xen_pvh = kern/i386/dl.c;
|
||||||
@@ -2277,13 +2280,11 @@ module = {
|
@@ -2399,15 +2402,12 @@ module = {
|
||||||
|
|
||||||
module = {
|
module = {
|
||||||
name = backtrace;
|
name = backtrace;
|
||||||
- x86 = lib/i386/backtrace.c;
|
- x86 = lib/i386/backtrace.c;
|
||||||
|
- i386_xen_pvh = lib/i386/backtrace.c;
|
||||||
- i386_xen = lib/i386/backtrace.c;
|
- i386_xen = lib/i386/backtrace.c;
|
||||||
- x86_64_xen = lib/i386/backtrace.c;
|
- x86_64_xen = lib/i386/backtrace.c;
|
||||||
- common = lib/backtrace.c;
|
- common = lib/backtrace.c;
|
||||||
+ common = commands/backtrace.c;
|
+ common = commands/backtrace.c;
|
||||||
enable = x86;
|
enable = x86;
|
||||||
|
enable = i386_xen_pvh;
|
||||||
enable = i386_xen;
|
enable = i386_xen;
|
||||||
enable = x86_64_xen;
|
enable = x86_64_xen;
|
||||||
+ enable = arm64;
|
+ enable = arm64;
|
||||||
@ -101,7 +103,7 @@ diff --git a/grub-core/lib/backtrace.c b/grub-core/commands/backtrace.c
|
|||||||
similarity index 98%
|
similarity index 98%
|
||||||
rename from grub-core/lib/backtrace.c
|
rename from grub-core/lib/backtrace.c
|
||||||
rename to grub-core/commands/backtrace.c
|
rename to grub-core/commands/backtrace.c
|
||||||
index c0ad6ab8b..8b5ec3913 100644
|
index c0ad6ab8be..8b5ec3913b 100644
|
||||||
--- a/grub-core/lib/backtrace.c
|
--- a/grub-core/lib/backtrace.c
|
||||||
+++ b/grub-core/commands/backtrace.c
|
+++ b/grub-core/commands/backtrace.c
|
||||||
@@ -54,7 +54,7 @@ grub_cmd_backtrace (grub_command_t cmd __attribute__ ((unused)),
|
@@ -54,7 +54,7 @@ grub_cmd_backtrace (grub_command_t cmd __attribute__ ((unused)),
|
||||||
@ -114,7 +116,7 @@ index c0ad6ab8b..8b5ec3913 100644
|
|||||||
}
|
}
|
||||||
|
|
||||||
diff --git a/grub-core/gdb/cstub.c b/grub-core/gdb/cstub.c
|
diff --git a/grub-core/gdb/cstub.c b/grub-core/gdb/cstub.c
|
||||||
index b64acd70f..99281472d 100644
|
index b64acd70fe..99281472d3 100644
|
||||||
--- a/grub-core/gdb/cstub.c
|
--- a/grub-core/gdb/cstub.c
|
||||||
+++ b/grub-core/gdb/cstub.c
|
+++ b/grub-core/gdb/cstub.c
|
||||||
@@ -215,7 +215,6 @@ grub_gdb_trap (int trap_no)
|
@@ -215,7 +215,6 @@ grub_gdb_trap (int trap_no)
|
||||||
@ -127,7 +129,7 @@ index b64acd70f..99281472d 100644
|
|||||||
|
|
||||||
diff --git a/grub-core/kern/arm64/backtrace.c b/grub-core/kern/arm64/backtrace.c
|
diff --git a/grub-core/kern/arm64/backtrace.c b/grub-core/kern/arm64/backtrace.c
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..019c6fdfe
|
index 0000000000..019c6fdfef
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/grub-core/kern/arm64/backtrace.c
|
+++ b/grub-core/kern/arm64/backtrace.c
|
||||||
@@ -0,0 +1,94 @@
|
@@ -0,0 +1,94 @@
|
||||||
@ -227,7 +229,7 @@ index 000000000..019c6fdfe
|
|||||||
+}
|
+}
|
||||||
diff --git a/grub-core/kern/backtrace.c b/grub-core/kern/backtrace.c
|
diff --git a/grub-core/kern/backtrace.c b/grub-core/kern/backtrace.c
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..4a82e865c
|
index 0000000000..4a82e865cc
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/grub-core/kern/backtrace.c
|
+++ b/grub-core/kern/backtrace.c
|
||||||
@@ -0,0 +1,97 @@
|
@@ -0,0 +1,97 @@
|
||||||
@ -329,7 +331,7 @@ index 000000000..4a82e865c
|
|||||||
+ grub_backtrace (skip + 1);
|
+ grub_backtrace (skip + 1);
|
||||||
+}
|
+}
|
||||||
diff --git a/grub-core/kern/dl.c b/grub-core/kern/dl.c
|
diff --git a/grub-core/kern/dl.c b/grub-core/kern/dl.c
|
||||||
index 621070918..5028d157c 100644
|
index 7afb9e6f72..88d2077709 100644
|
||||||
--- a/grub-core/kern/dl.c
|
--- a/grub-core/kern/dl.c
|
||||||
+++ b/grub-core/kern/dl.c
|
+++ b/grub-core/kern/dl.c
|
||||||
@@ -124,6 +124,50 @@ grub_dl_resolve_symbol (const char *name)
|
@@ -124,6 +124,50 @@ grub_dl_resolve_symbol (const char *name)
|
||||||
@ -393,7 +395,7 @@ index 621070918..5028d157c 100644
|
|||||||
i++, s = (Elf_Shdr *) ((char *) s + e->e_shentsize))
|
i++, s = (Elf_Shdr *) ((char *) s + e->e_shentsize))
|
||||||
diff --git a/grub-core/kern/i386/backtrace.c b/grub-core/kern/i386/backtrace.c
|
diff --git a/grub-core/kern/i386/backtrace.c b/grub-core/kern/i386/backtrace.c
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..2413f9a57
|
index 0000000000..2413f9a57d
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/grub-core/kern/i386/backtrace.c
|
+++ b/grub-core/kern/i386/backtrace.c
|
||||||
@@ -0,0 +1,125 @@
|
@@ -0,0 +1,125 @@
|
||||||
@ -523,7 +525,7 @@ index 000000000..2413f9a57
|
|||||||
+#endif
|
+#endif
|
||||||
+}
|
+}
|
||||||
diff --git a/grub-core/kern/i386/pc/init.c b/grub-core/kern/i386/pc/init.c
|
diff --git a/grub-core/kern/i386/pc/init.c b/grub-core/kern/i386/pc/init.c
|
||||||
index 27bc68b8a..b51d0abfa 100644
|
index 27bc68b8a5..b51d0abfa6 100644
|
||||||
--- a/grub-core/kern/i386/pc/init.c
|
--- a/grub-core/kern/i386/pc/init.c
|
||||||
+++ b/grub-core/kern/i386/pc/init.c
|
+++ b/grub-core/kern/i386/pc/init.c
|
||||||
@@ -153,7 +153,7 @@ compact_mem_regions (void)
|
@@ -153,7 +153,7 @@ compact_mem_regions (void)
|
||||||
@ -545,10 +547,10 @@ index 27bc68b8a..b51d0abfa 100644
|
|||||||
/* Initialize the console as early as possible. */
|
/* Initialize the console as early as possible. */
|
||||||
grub_console_init ();
|
grub_console_init ();
|
||||||
diff --git a/grub-core/kern/ieee1275/init.c b/grub-core/kern/ieee1275/init.c
|
diff --git a/grub-core/kern/ieee1275/init.c b/grub-core/kern/ieee1275/init.c
|
||||||
index e01bc6eab..e731a57a4 100644
|
index 0cd2a62723..937c1bc44c 100644
|
||||||
--- a/grub-core/kern/ieee1275/init.c
|
--- a/grub-core/kern/ieee1275/init.c
|
||||||
+++ b/grub-core/kern/ieee1275/init.c
|
+++ b/grub-core/kern/ieee1275/init.c
|
||||||
@@ -60,7 +60,6 @@
|
@@ -63,7 +63,6 @@
|
||||||
#define HEAP_MAX_ADDR (unsigned long) (32 * 1024 * 1024)
|
#define HEAP_MAX_ADDR (unsigned long) (32 * 1024 * 1024)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -557,11 +559,11 @@ index e01bc6eab..e731a57a4 100644
|
|||||||
|
|
||||||
#ifdef __sparc__
|
#ifdef __sparc__
|
||||||
diff --git a/grub-core/kern/misc.c b/grub-core/kern/misc.c
|
diff --git a/grub-core/kern/misc.c b/grub-core/kern/misc.c
|
||||||
index e758ab341..5c2d2039d 100644
|
index c60601b699..a432a6be54 100644
|
||||||
--- a/grub-core/kern/misc.c
|
--- a/grub-core/kern/misc.c
|
||||||
+++ b/grub-core/kern/misc.c
|
+++ b/grub-core/kern/misc.c
|
||||||
@@ -1110,15 +1110,15 @@ grub_xasprintf (const char *fmt, ...)
|
@@ -1197,15 +1197,15 @@ grub_printf_fmt_check (const char *fmt, const char *fmt_expected)
|
||||||
}
|
|
||||||
|
|
||||||
/* Abort GRUB. This function does not return. */
|
/* Abort GRUB. This function does not return. */
|
||||||
-static void __attribute__ ((noreturn))
|
-static void __attribute__ ((noreturn))
|
||||||
@ -582,7 +584,7 @@ index e758ab341..5c2d2039d 100644
|
|||||||
|
|
||||||
#ifndef GRUB_UTIL
|
#ifndef GRUB_UTIL
|
||||||
if (grub_term_inputs)
|
if (grub_term_inputs)
|
||||||
@@ -1145,6 +1145,7 @@ grub_fatal (const char *fmt, ...)
|
@@ -1232,6 +1232,7 @@ grub_fatal (const char *fmt, ...)
|
||||||
{
|
{
|
||||||
va_list ap;
|
va_list ap;
|
||||||
|
|
||||||
@ -591,10 +593,10 @@ index e758ab341..5c2d2039d 100644
|
|||||||
grub_vprintf (_(fmt), ap);
|
grub_vprintf (_(fmt), ap);
|
||||||
va_end (ap);
|
va_end (ap);
|
||||||
diff --git a/grub-core/kern/mm.c b/grub-core/kern/mm.c
|
diff --git a/grub-core/kern/mm.c b/grub-core/kern/mm.c
|
||||||
index ee88ff611..002cbfa4f 100644
|
index c070afc621..d8c8377578 100644
|
||||||
--- a/grub-core/kern/mm.c
|
--- a/grub-core/kern/mm.c
|
||||||
+++ b/grub-core/kern/mm.c
|
+++ b/grub-core/kern/mm.c
|
||||||
@@ -95,13 +95,13 @@ get_header_from_pointer (void *ptr, grub_mm_header_t *p, grub_mm_region_t *r)
|
@@ -97,13 +97,13 @@ get_header_from_pointer (void *ptr, grub_mm_header_t *p, grub_mm_region_t *r)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
if (! *r)
|
if (! *r)
|
||||||
@ -613,7 +615,7 @@ index ee88ff611..002cbfa4f 100644
|
|||||||
|
|
||||||
diff --git a/grub-core/lib/arm64/backtrace.c b/grub-core/lib/arm64/backtrace.c
|
diff --git a/grub-core/lib/arm64/backtrace.c b/grub-core/lib/arm64/backtrace.c
|
||||||
deleted file mode 100644
|
deleted file mode 100644
|
||||||
index 1079b5380..000000000
|
index 1079b5380e..0000000000
|
||||||
--- a/grub-core/lib/arm64/backtrace.c
|
--- a/grub-core/lib/arm64/backtrace.c
|
||||||
+++ /dev/null
|
+++ /dev/null
|
||||||
@@ -1,62 +0,0 @@
|
@@ -1,62 +0,0 @@
|
||||||
@ -681,7 +683,7 @@ index 1079b5380..000000000
|
|||||||
-
|
-
|
||||||
diff --git a/grub-core/lib/i386/backtrace.c b/grub-core/lib/i386/backtrace.c
|
diff --git a/grub-core/lib/i386/backtrace.c b/grub-core/lib/i386/backtrace.c
|
||||||
deleted file mode 100644
|
deleted file mode 100644
|
||||||
index c67273db3..000000000
|
index c67273db3a..0000000000
|
||||||
--- a/grub-core/lib/i386/backtrace.c
|
--- a/grub-core/lib/i386/backtrace.c
|
||||||
+++ /dev/null
|
+++ /dev/null
|
||||||
@@ -1,78 +0,0 @@
|
@@ -1,78 +0,0 @@
|
||||||
@ -764,7 +766,7 @@ index c67273db3..000000000
|
|||||||
-}
|
-}
|
||||||
-
|
-
|
||||||
diff --git a/include/grub/backtrace.h b/include/grub/backtrace.h
|
diff --git a/include/grub/backtrace.h b/include/grub/backtrace.h
|
||||||
index 395519762..275cf85e2 100644
|
index 395519762f..275cf85e2d 100644
|
||||||
--- a/include/grub/backtrace.h
|
--- a/include/grub/backtrace.h
|
||||||
+++ b/include/grub/backtrace.h
|
+++ b/include/grub/backtrace.h
|
||||||
@@ -19,8 +19,14 @@
|
@@ -19,8 +19,14 @@
|
||||||
@ -785,10 +787,10 @@ index 395519762..275cf85e2 100644
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
diff --git a/include/grub/dl.h b/include/grub/dl.h
|
diff --git a/include/grub/dl.h b/include/grub/dl.h
|
||||||
index b1ed3c333..7b5bfb07c 100644
|
index 91933b85f2..2f76e6b043 100644
|
||||||
--- a/include/grub/dl.h
|
--- a/include/grub/dl.h
|
||||||
+++ b/include/grub/dl.h
|
+++ b/include/grub/dl.h
|
||||||
@@ -244,6 +244,8 @@ grub_dl_get (const char *name)
|
@@ -259,6 +259,8 @@ grub_dl_is_persistent (grub_dl_t mod)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -798,10 +800,10 @@ index b1ed3c333..7b5bfb07c 100644
|
|||||||
int isfunc, grub_dl_t mod);
|
int isfunc, grub_dl_t mod);
|
||||||
|
|
||||||
diff --git a/include/grub/kernel.h b/include/grub/kernel.h
|
diff --git a/include/grub/kernel.h b/include/grub/kernel.h
|
||||||
index ecd88ca72..ae69218af 100644
|
index abbca5ea33..300a9766cd 100644
|
||||||
--- a/include/grub/kernel.h
|
--- a/include/grub/kernel.h
|
||||||
+++ b/include/grub/kernel.h
|
+++ b/include/grub/kernel.h
|
||||||
@@ -108,6 +108,9 @@ grub_addr_t grub_modules_get_end (void);
|
@@ -111,6 +111,9 @@ grub_addr_t grub_modules_get_end (void);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -812,7 +814,7 @@ index ecd88ca72..ae69218af 100644
|
|||||||
void grub_main (void) __attribute__ ((noreturn));
|
void grub_main (void) __attribute__ ((noreturn));
|
||||||
|
|
||||||
diff --git a/grub-core/kern/arm/efi/startup.S b/grub-core/kern/arm/efi/startup.S
|
diff --git a/grub-core/kern/arm/efi/startup.S b/grub-core/kern/arm/efi/startup.S
|
||||||
index 9f8265315..f3bc41f9d 100644
|
index 9f8265315a..f3bc41f9d0 100644
|
||||||
--- a/grub-core/kern/arm/efi/startup.S
|
--- a/grub-core/kern/arm/efi/startup.S
|
||||||
+++ b/grub-core/kern/arm/efi/startup.S
|
+++ b/grub-core/kern/arm/efi/startup.S
|
||||||
@@ -23,6 +23,8 @@
|
@@ -23,6 +23,8 @@
|
||||||
@ -825,7 +827,7 @@ index 9f8265315..f3bc41f9d 100644
|
|||||||
/*
|
/*
|
||||||
* EFI_SYSTEM_TABLE and EFI_HANDLE are passed in r1/r0.
|
* EFI_SYSTEM_TABLE and EFI_HANDLE are passed in r1/r0.
|
||||||
diff --git a/grub-core/kern/arm/startup.S b/grub-core/kern/arm/startup.S
|
diff --git a/grub-core/kern/arm/startup.S b/grub-core/kern/arm/startup.S
|
||||||
index 3946fe8e1..5679a1d00 100644
|
index 3946fe8e18..5679a1d00a 100644
|
||||||
--- a/grub-core/kern/arm/startup.S
|
--- a/grub-core/kern/arm/startup.S
|
||||||
+++ b/grub-core/kern/arm/startup.S
|
+++ b/grub-core/kern/arm/startup.S
|
||||||
@@ -48,6 +48,8 @@
|
@@ -48,6 +48,8 @@
|
||||||
@ -838,7 +840,7 @@ index 3946fe8e1..5679a1d00 100644
|
|||||||
b codestart
|
b codestart
|
||||||
|
|
||||||
diff --git a/grub-core/kern/arm64/efi/startup.S b/grub-core/kern/arm64/efi/startup.S
|
diff --git a/grub-core/kern/arm64/efi/startup.S b/grub-core/kern/arm64/efi/startup.S
|
||||||
index 666a7ee3c..41676bdb2 100644
|
index 666a7ee3c9..41676bdb2b 100644
|
||||||
--- a/grub-core/kern/arm64/efi/startup.S
|
--- a/grub-core/kern/arm64/efi/startup.S
|
||||||
+++ b/grub-core/kern/arm64/efi/startup.S
|
+++ b/grub-core/kern/arm64/efi/startup.S
|
||||||
@@ -19,7 +19,9 @@
|
@@ -19,7 +19,9 @@
|
||||||
@ -852,7 +854,7 @@ index 666a7ee3c..41676bdb2 100644
|
|||||||
/*
|
/*
|
||||||
* EFI_SYSTEM_TABLE and EFI_HANDLE are passed in x1/x0.
|
* EFI_SYSTEM_TABLE and EFI_HANDLE are passed in x1/x0.
|
||||||
diff --git a/grub-core/kern/i386/qemu/startup.S b/grub-core/kern/i386/qemu/startup.S
|
diff --git a/grub-core/kern/i386/qemu/startup.S b/grub-core/kern/i386/qemu/startup.S
|
||||||
index 0d89858d9..939f182fc 100644
|
index 0d89858d9b..939f182fc7 100644
|
||||||
--- a/grub-core/kern/i386/qemu/startup.S
|
--- a/grub-core/kern/i386/qemu/startup.S
|
||||||
+++ b/grub-core/kern/i386/qemu/startup.S
|
+++ b/grub-core/kern/i386/qemu/startup.S
|
||||||
@@ -24,7 +24,8 @@
|
@@ -24,7 +24,8 @@
|
||||||
@ -866,7 +868,7 @@ index 0d89858d9..939f182fc 100644
|
|||||||
jmp codestart
|
jmp codestart
|
||||||
|
|
||||||
diff --git a/grub-core/kern/ia64/efi/startup.S b/grub-core/kern/ia64/efi/startup.S
|
diff --git a/grub-core/kern/ia64/efi/startup.S b/grub-core/kern/ia64/efi/startup.S
|
||||||
index d75c6d7cc..8f2a593e5 100644
|
index d75c6d7cc7..8f2a593e52 100644
|
||||||
--- a/grub-core/kern/ia64/efi/startup.S
|
--- a/grub-core/kern/ia64/efi/startup.S
|
||||||
+++ b/grub-core/kern/ia64/efi/startup.S
|
+++ b/grub-core/kern/ia64/efi/startup.S
|
||||||
@@ -24,8 +24,9 @@
|
@@ -24,8 +24,9 @@
|
||||||
@ -881,7 +883,7 @@ index d75c6d7cc..8f2a593e5 100644
|
|||||||
alloc loc0=ar.pfs,2,4,0,0
|
alloc loc0=ar.pfs,2,4,0,0
|
||||||
mov loc1=rp
|
mov loc1=rp
|
||||||
diff --git a/grub-core/kern/sparc64/ieee1275/crt0.S b/grub-core/kern/sparc64/ieee1275/crt0.S
|
diff --git a/grub-core/kern/sparc64/ieee1275/crt0.S b/grub-core/kern/sparc64/ieee1275/crt0.S
|
||||||
index 03b916f05..701bf63ab 100644
|
index 03b916f053..701bf63abc 100644
|
||||||
--- a/grub-core/kern/sparc64/ieee1275/crt0.S
|
--- a/grub-core/kern/sparc64/ieee1275/crt0.S
|
||||||
+++ b/grub-core/kern/sparc64/ieee1275/crt0.S
|
+++ b/grub-core/kern/sparc64/ieee1275/crt0.S
|
||||||
@@ -22,7 +22,8 @@
|
@@ -22,7 +22,8 @@
|
||||||
@ -895,7 +897,7 @@ index 03b916f05..701bf63ab 100644
|
|||||||
ba codestart
|
ba codestart
|
||||||
mov %o4, %o0
|
mov %o4, %o0
|
||||||
diff --git a/grub-core/Makefile.am b/grub-core/Makefile.am
|
diff --git a/grub-core/Makefile.am b/grub-core/Makefile.am
|
||||||
index 0108c0d42..f36200bd6 100644
|
index ee88e44e97..bfd29a3bf0 100644
|
||||||
--- a/grub-core/Makefile.am
|
--- a/grub-core/Makefile.am
|
||||||
+++ b/grub-core/Makefile.am
|
+++ b/grub-core/Makefile.am
|
||||||
@@ -66,6 +66,7 @@ CLEANFILES += grub_script.yy.c grub_script.yy.h
|
@@ -66,6 +66,7 @@ CLEANFILES += grub_script.yy.c grub_script.yy.h
|
@ -8,10 +8,10 @@ Subject: [PATCH] normal: don't draw our startup message if debug is set
|
|||||||
1 file changed, 3 insertions(+)
|
1 file changed, 3 insertions(+)
|
||||||
|
|
||||||
diff --git a/grub-core/normal/main.c b/grub-core/normal/main.c
|
diff --git a/grub-core/normal/main.c b/grub-core/normal/main.c
|
||||||
index b69f9e738..04ae9ed02 100644
|
index 55558cc0b9..af9792c963 100644
|
||||||
--- a/grub-core/normal/main.c
|
--- a/grub-core/normal/main.c
|
||||||
+++ b/grub-core/normal/main.c
|
+++ b/grub-core/normal/main.c
|
||||||
@@ -419,6 +419,9 @@ grub_normal_reader_init (int nested)
|
@@ -430,6 +430,9 @@ grub_normal_reader_init (int nested)
|
||||||
const char *msg_esc = _("ESC at any time exits.");
|
const char *msg_esc = _("ESC at any time exits.");
|
||||||
char *msg_formatted;
|
char *msg_formatted;
|
||||||
|
|
@ -17,7 +17,7 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
|
|
||||||
diff --git a/include/grub/arm/efi/console.h b/include/grub/arm/efi/console.h
|
diff --git a/include/grub/arm/efi/console.h b/include/grub/arm/efi/console.h
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..1592f6f76
|
index 0000000000..1592f6f76b
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/include/grub/arm/efi/console.h
|
+++ b/include/grub/arm/efi/console.h
|
||||||
@@ -0,0 +1,24 @@
|
@@ -0,0 +1,24 @@
|
||||||
@ -47,7 +47,7 @@ index 000000000..1592f6f76
|
|||||||
+#endif /* ! GRUB_ARM_EFI_CONSOLE_H */
|
+#endif /* ! GRUB_ARM_EFI_CONSOLE_H */
|
||||||
diff --git a/include/grub/arm64/efi/console.h b/include/grub/arm64/efi/console.h
|
diff --git a/include/grub/arm64/efi/console.h b/include/grub/arm64/efi/console.h
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..956893393
|
index 0000000000..9568933938
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/include/grub/arm64/efi/console.h
|
+++ b/include/grub/arm64/efi/console.h
|
||||||
@@ -0,0 +1,24 @@
|
@@ -0,0 +1,24 @@
|
||||||
@ -77,7 +77,7 @@ index 000000000..956893393
|
|||||||
+#endif /* ! GRUB_ARM64_EFI_CONSOLE_H */
|
+#endif /* ! GRUB_ARM64_EFI_CONSOLE_H */
|
||||||
diff --git a/include/grub/i386/efi/console.h b/include/grub/i386/efi/console.h
|
diff --git a/include/grub/i386/efi/console.h b/include/grub/i386/efi/console.h
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..9231375cb
|
index 0000000000..9231375cb0
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/include/grub/i386/efi/console.h
|
+++ b/include/grub/i386/efi/console.h
|
||||||
@@ -0,0 +1,24 @@
|
@@ -0,0 +1,24 @@
|
||||||
@ -107,7 +107,7 @@ index 000000000..9231375cb
|
|||||||
+#endif /* ! GRUB_I386_EFI_CONSOLE_H */
|
+#endif /* ! GRUB_I386_EFI_CONSOLE_H */
|
||||||
diff --git a/include/grub/x86_64/efi/console.h b/include/grub/x86_64/efi/console.h
|
diff --git a/include/grub/x86_64/efi/console.h b/include/grub/x86_64/efi/console.h
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..dba9d8678
|
index 0000000000..dba9d8678d
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/include/grub/x86_64/efi/console.h
|
+++ b/include/grub/x86_64/efi/console.h
|
||||||
@@ -0,0 +1,24 @@
|
@@ -0,0 +1,24 @@
|
@ -10,10 +10,10 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
2 files changed, 27 insertions(+)
|
2 files changed, 27 insertions(+)
|
||||||
|
|
||||||
diff --git a/configure.ac b/configure.ac
|
diff --git a/configure.ac b/configure.ac
|
||||||
index f69f89867..359cac3c2 100644
|
index 0d0e6782a1..302300711f 100644
|
||||||
--- a/configure.ac
|
--- a/configure.ac
|
||||||
+++ b/configure.ac
|
+++ b/configure.ac
|
||||||
@@ -1386,7 +1386,15 @@ grub_PROG_TARGET_CC
|
@@ -1442,7 +1442,15 @@ grub_PROG_TARGET_CC
|
||||||
if test "x$TARGET_APPLE_LINKER" != x1 ; then
|
if test "x$TARGET_APPLE_LINKER" != x1 ; then
|
||||||
grub_PROG_OBJCOPY_ABSOLUTE
|
grub_PROG_OBJCOPY_ABSOLUTE
|
||||||
fi
|
fi
|
||||||
@ -30,7 +30,7 @@ index f69f89867..359cac3c2 100644
|
|||||||
if test "$platform" != emu && test "x$TARGET_APPLE_LINKER" != x1 ; then
|
if test "$platform" != emu && test "x$TARGET_APPLE_LINKER" != x1 ; then
|
||||||
if test ! -z "$TARGET_IMG_LDSCRIPT"; then
|
if test ! -z "$TARGET_IMG_LDSCRIPT"; then
|
||||||
diff --git a/acinclude.m4 b/acinclude.m4
|
diff --git a/acinclude.m4 b/acinclude.m4
|
||||||
index 78cdf6e1d..242e829ff 100644
|
index 6e14bb553c..21238fcfd0 100644
|
||||||
--- a/acinclude.m4
|
--- a/acinclude.m4
|
||||||
+++ b/acinclude.m4
|
+++ b/acinclude.m4
|
||||||
@@ -136,6 +136,25 @@ if test "x$grub_cv_prog_ld_build_id_none" = xyes; then
|
@@ -136,6 +136,25 @@ if test "x$grub_cv_prog_ld_build_id_none" = xyes; then
|
@ -13,10 +13,10 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
2 files changed, 20 insertions(+)
|
2 files changed, 20 insertions(+)
|
||||||
|
|
||||||
diff --git a/grub-core/kern/misc.c b/grub-core/kern/misc.c
|
diff --git a/grub-core/kern/misc.c b/grub-core/kern/misc.c
|
||||||
index 5c2d2039d..0e89c483d 100644
|
index a432a6be54..9a2fae6398 100644
|
||||||
--- a/grub-core/kern/misc.c
|
--- a/grub-core/kern/misc.c
|
||||||
+++ b/grub-core/kern/misc.c
|
+++ b/grub-core/kern/misc.c
|
||||||
@@ -190,6 +190,24 @@ grub_real_dprintf (const char *file, const int line, const char *condition,
|
@@ -191,6 +191,24 @@ grub_real_dprintf (const char *file, const int line, const char *condition,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -42,10 +42,10 @@ index 5c2d2039d..0e89c483d 100644
|
|||||||
|
|
||||||
int
|
int
|
||||||
diff --git a/include/grub/misc.h b/include/grub/misc.h
|
diff --git a/include/grub/misc.h b/include/grub/misc.h
|
||||||
index f7473c154..5f1c1c1be 100644
|
index fd18e6320b..3adc4036e3 100644
|
||||||
--- a/include/grub/misc.h
|
--- a/include/grub/misc.h
|
||||||
+++ b/include/grub/misc.h
|
+++ b/include/grub/misc.h
|
||||||
@@ -372,6 +372,8 @@ void EXPORT_FUNC(grub_real_dprintf) (const char *file,
|
@@ -345,6 +345,8 @@ void EXPORT_FUNC(grub_real_dprintf) (const char *file,
|
||||||
const int line,
|
const int line,
|
||||||
const char *condition,
|
const char *condition,
|
||||||
const char *fmt, ...) __attribute__ ((format (GNU_PRINTF, 4, 5)));
|
const char *fmt, ...) __attribute__ ((format (GNU_PRINTF, 4, 5)));
|
@ -20,7 +20,7 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
4 files changed, 78 insertions(+), 4 deletions(-)
|
4 files changed, 78 insertions(+), 4 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/kern/dl.c b/grub-core/kern/dl.c
|
diff --git a/grub-core/kern/dl.c b/grub-core/kern/dl.c
|
||||||
index 5028d157c..eb8b969cd 100644
|
index 88d2077709..9557254035 100644
|
||||||
--- a/grub-core/kern/dl.c
|
--- a/grub-core/kern/dl.c
|
||||||
+++ b/grub-core/kern/dl.c
|
+++ b/grub-core/kern/dl.c
|
||||||
@@ -501,6 +501,23 @@ grub_dl_find_section (Elf_Ehdr *e, const char *name)
|
@@ -501,6 +501,23 @@ grub_dl_find_section (Elf_Ehdr *e, const char *name)
|
||||||
@ -47,7 +47,7 @@ index 5028d157c..eb8b969cd 100644
|
|||||||
|
|
||||||
/* Me, Vladimir Serbinenko, hereby I add this module check as per new
|
/* Me, Vladimir Serbinenko, hereby I add this module check as per new
|
||||||
GNU module policy. Note that this license check is informative only.
|
GNU module policy. Note that this license check is informative only.
|
||||||
@@ -644,6 +661,37 @@ grub_dl_relocate_symbols (grub_dl_t mod, void *ehdr)
|
@@ -653,6 +670,37 @@ grub_dl_relocate_symbols (grub_dl_t mod, void *ehdr)
|
||||||
|
|
||||||
return GRUB_ERR_NONE;
|
return GRUB_ERR_NONE;
|
||||||
}
|
}
|
||||||
@ -85,7 +85,7 @@ index 5028d157c..eb8b969cd 100644
|
|||||||
|
|
||||||
/* Load a module from core memory. */
|
/* Load a module from core memory. */
|
||||||
grub_dl_t
|
grub_dl_t
|
||||||
@@ -703,6 +751,8 @@ grub_dl_load_core_noinit (void *addr, grub_size_t size)
|
@@ -712,6 +760,8 @@ grub_dl_load_core_noinit (void *addr, grub_size_t size)
|
||||||
grub_dprintf ("modules", "module name: %s\n", mod->name);
|
grub_dprintf ("modules", "module name: %s\n", mod->name);
|
||||||
grub_dprintf ("modules", "init function: %p\n", mod->init);
|
grub_dprintf ("modules", "init function: %p\n", mod->init);
|
||||||
|
|
||||||
@ -95,10 +95,10 @@ index 5028d157c..eb8b969cd 100644
|
|||||||
{
|
{
|
||||||
grub_dl_unload (mod);
|
grub_dl_unload (mod);
|
||||||
diff --git a/grub-core/kern/efi/efi.c b/grub-core/kern/efi/efi.c
|
diff --git a/grub-core/kern/efi/efi.c b/grub-core/kern/efi/efi.c
|
||||||
index bcae7f469..a2a732ffc 100644
|
index ae9885edb8..d6a2fb5778 100644
|
||||||
--- a/grub-core/kern/efi/efi.c
|
--- a/grub-core/kern/efi/efi.c
|
||||||
+++ b/grub-core/kern/efi/efi.c
|
+++ b/grub-core/kern/efi/efi.c
|
||||||
@@ -283,7 +283,7 @@ grub_efi_get_variable (const char *var, const grub_efi_guid_t *guid,
|
@@ -296,7 +296,7 @@ grub_efi_get_variable (const char *var, const grub_efi_guid_t *guid,
|
||||||
/* Search the mods section from the PE32/PE32+ image. This code uses
|
/* Search the mods section from the PE32/PE32+ image. This code uses
|
||||||
a PE32 header, but should work with PE32+ as well. */
|
a PE32 header, but should work with PE32+ as well. */
|
||||||
grub_addr_t
|
grub_addr_t
|
||||||
@ -107,7 +107,7 @@ index bcae7f469..a2a732ffc 100644
|
|||||||
{
|
{
|
||||||
grub_efi_loaded_image_t *image;
|
grub_efi_loaded_image_t *image;
|
||||||
struct grub_pe32_header *header;
|
struct grub_pe32_header *header;
|
||||||
@@ -308,7 +308,7 @@ grub_efi_modules_addr (void)
|
@@ -321,7 +321,7 @@ grub_efi_modules_addr (void)
|
||||||
i < coff_header->num_sections;
|
i < coff_header->num_sections;
|
||||||
i++, section++)
|
i++, section++)
|
||||||
{
|
{
|
||||||
@ -117,10 +117,10 @@ index bcae7f469..a2a732ffc 100644
|
|||||||
}
|
}
|
||||||
|
|
||||||
diff --git a/grub-core/kern/efi/init.c b/grub-core/kern/efi/init.c
|
diff --git a/grub-core/kern/efi/init.c b/grub-core/kern/efi/init.c
|
||||||
index 71d2279a0..e6183a4c4 100644
|
index 6d39bd3ad2..2d12e6188f 100644
|
||||||
--- a/grub-core/kern/efi/init.c
|
--- a/grub-core/kern/efi/init.c
|
||||||
+++ b/grub-core/kern/efi/init.c
|
+++ b/grub-core/kern/efi/init.c
|
||||||
@@ -59,10 +59,33 @@ grub_efi_env_init (void)
|
@@ -115,10 +115,33 @@ grub_efi_env_init (void)
|
||||||
grub_free (envblk_s.buf);
|
grub_free (envblk_s.buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -155,7 +155,7 @@ index 71d2279a0..e6183a4c4 100644
|
|||||||
/* First of all, initialize the console so that GRUB can display
|
/* First of all, initialize the console so that GRUB can display
|
||||||
messages. */
|
messages. */
|
||||||
grub_console_init ();
|
grub_console_init ();
|
||||||
@@ -74,6 +97,7 @@ grub_efi_init (void)
|
@@ -142,6 +165,7 @@ grub_efi_init (void)
|
||||||
0, 0, 0, NULL);
|
0, 0, 0, NULL);
|
||||||
|
|
||||||
grub_efi_env_init ();
|
grub_efi_env_init ();
|
||||||
@ -164,11 +164,11 @@ index 71d2279a0..e6183a4c4 100644
|
|||||||
}
|
}
|
||||||
|
|
||||||
diff --git a/include/grub/efi/efi.h b/include/grub/efi/efi.h
|
diff --git a/include/grub/efi/efi.h b/include/grub/efi/efi.h
|
||||||
index 09a18e563..570a69361 100644
|
index 03f9a9d011..2e0691454b 100644
|
||||||
--- a/include/grub/efi/efi.h
|
--- a/include/grub/efi/efi.h
|
||||||
+++ b/include/grub/efi/efi.h
|
+++ b/include/grub/efi/efi.h
|
||||||
@@ -132,7 +132,7 @@ grub_err_t grub_armxx_efi_linux_check_image(struct linux_armxx_kernel_header *lh
|
@@ -138,7 +138,7 @@ grub_err_t grub_arch_efi_linux_check_image(struct linux_arch_kernel_header *lh);
|
||||||
grub_err_t grub_armxx_efi_linux_boot_image(grub_addr_t addr, char *args);
|
grub_err_t grub_arch_efi_linux_boot_image(grub_addr_t addr, char *args);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
-grub_addr_t grub_efi_modules_addr (void);
|
-grub_addr_t grub_efi_modules_addr (void);
|
@ -9,10 +9,10 @@ Subject: [PATCH] Fixup for newer compiler
|
|||||||
2 files changed, 2 insertions(+), 2 deletions(-)
|
2 files changed, 2 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/fs/btrfs.c b/grub-core/fs/btrfs.c
|
diff --git a/grub-core/fs/btrfs.c b/grub-core/fs/btrfs.c
|
||||||
index 7002ad81b..dac73b2fa 100644
|
index 2b21cbaa67..4cc86e9b79 100644
|
||||||
--- a/grub-core/fs/btrfs.c
|
--- a/grub-core/fs/btrfs.c
|
||||||
+++ b/grub-core/fs/btrfs.c
|
+++ b/grub-core/fs/btrfs.c
|
||||||
@@ -198,7 +198,7 @@ struct grub_btrfs_inode
|
@@ -218,7 +218,7 @@ struct grub_btrfs_inode
|
||||||
grub_uint64_t size;
|
grub_uint64_t size;
|
||||||
grub_uint8_t dummy2[0x70];
|
grub_uint8_t dummy2[0x70];
|
||||||
struct grub_btrfs_time mtime;
|
struct grub_btrfs_time mtime;
|
||||||
@ -22,7 +22,7 @@ index 7002ad81b..dac73b2fa 100644
|
|||||||
struct grub_btrfs_extent_data
|
struct grub_btrfs_extent_data
|
||||||
{
|
{
|
||||||
diff --git a/include/grub/gpt_partition.h b/include/grub/gpt_partition.h
|
diff --git a/include/grub/gpt_partition.h b/include/grub/gpt_partition.h
|
||||||
index 7a93f4329..8212697bf 100644
|
index 7a93f43291..8212697bf6 100644
|
||||||
--- a/include/grub/gpt_partition.h
|
--- a/include/grub/gpt_partition.h
|
||||||
+++ b/include/grub/gpt_partition.h
|
+++ b/include/grub/gpt_partition.h
|
||||||
@@ -76,7 +76,7 @@ struct grub_gpt_partentry
|
@@ -76,7 +76,7 @@ struct grub_gpt_partentry
|
@ -26,10 +26,10 @@ Signed-off-by: Javier Martinez Canillas <javierm@redhat.com>
|
|||||||
1 file changed, 2 insertions(+)
|
1 file changed, 2 insertions(+)
|
||||||
|
|
||||||
diff --git a/include/grub/kernel.h b/include/grub/kernel.h
|
diff --git a/include/grub/kernel.h b/include/grub/kernel.h
|
||||||
index ae69218af..9548d552a 100644
|
index 300a9766cd..55849777ea 100644
|
||||||
--- a/include/grub/kernel.h
|
--- a/include/grub/kernel.h
|
||||||
+++ b/include/grub/kernel.h
|
+++ b/include/grub/kernel.h
|
||||||
@@ -108,8 +108,10 @@ grub_addr_t grub_modules_get_end (void);
|
@@ -111,8 +111,10 @@ grub_addr_t grub_modules_get_end (void);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
@ -8,7 +8,7 @@ Subject: [PATCH] Fixup for newer compiler
|
|||||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
diff --git a/conf/Makefile.common b/conf/Makefile.common
|
diff --git a/conf/Makefile.common b/conf/Makefile.common
|
||||||
index 044ab3abe..c75848f5c 100644
|
index 191b1a70c6..5f0ef96985 100644
|
||||||
--- a/conf/Makefile.common
|
--- a/conf/Makefile.common
|
||||||
+++ b/conf/Makefile.common
|
+++ b/conf/Makefile.common
|
||||||
@@ -38,7 +38,7 @@ CFLAGS_KERNEL = $(CFLAGS_PLATFORM) -ffreestanding
|
@@ -38,7 +38,7 @@ CFLAGS_KERNEL = $(CFLAGS_PLATFORM) -ffreestanding
|
@ -1,6 +1,6 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
From: Andrzej Kacprowski <andrzej.kacprowski@intel.com>
|
From: Andrzej Kacprowski <andrzej.kacprowski@intel.com>
|
||||||
Date: Fri, 21 Apr 2017 10:06:20 +0200
|
Date: Wed, 10 Jul 2019 15:22:29 +0200
|
||||||
Subject: [PATCH] Add support for non-Ethernet network cards
|
Subject: [PATCH] Add support for non-Ethernet network cards
|
||||||
|
|
||||||
This patch replaces fixed 6-byte link layer address with
|
This patch replaces fixed 6-byte link layer address with
|
||||||
@ -20,12 +20,11 @@ then chaddr field in BOOTP it will be set to 0 as per rfc4390.
|
|||||||
Resolves: rhbz#1370642
|
Resolves: rhbz#1370642
|
||||||
|
|
||||||
Signed-off-by: Andrzej Kacprowski <andrzej.kacprowski@intel.com>
|
Signed-off-by: Andrzej Kacprowski <andrzej.kacprowski@intel.com>
|
||||||
|
[msalter: Fix max string calculation in grub_net_hwaddr_to_str]
|
||||||
Conflicts:
|
Signed-off-by: Mark Salter <msalter@redhat.com>
|
||||||
grub-core/net/ip.c
|
|
||||||
---
|
---
|
||||||
grub-core/net/arp.c | 155 ++++++++++++++++++++++-----------
|
grub-core/net/arp.c | 155 ++++++++++++++++++++++-----------
|
||||||
grub-core/net/bootp.c | 14 ++-
|
grub-core/net/bootp.c | 15 ++--
|
||||||
grub-core/net/drivers/efi/efinet.c | 8 +-
|
grub-core/net/drivers/efi/efinet.c | 8 +-
|
||||||
grub-core/net/drivers/emu/emunet.c | 1 +
|
grub-core/net/drivers/emu/emunet.c | 1 +
|
||||||
grub-core/net/drivers/i386/pc/pxe.c | 13 +--
|
grub-core/net/drivers/i386/pc/pxe.c | 13 +--
|
||||||
@ -34,12 +33,12 @@ Conflicts:
|
|||||||
grub-core/net/ethernet.c | 88 +++++++++----------
|
grub-core/net/ethernet.c | 88 +++++++++----------
|
||||||
grub-core/net/icmp6.c | 15 ++--
|
grub-core/net/icmp6.c | 15 ++--
|
||||||
grub-core/net/ip.c | 4 +-
|
grub-core/net/ip.c | 4 +-
|
||||||
grub-core/net/net.c | 48 +++++-----
|
grub-core/net/net.c | 50 ++++++-----
|
||||||
include/grub/net.h | 19 ++--
|
include/grub/net.h | 19 ++--
|
||||||
12 files changed, 216 insertions(+), 152 deletions(-)
|
12 files changed, 219 insertions(+), 152 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/net/arp.c b/grub-core/net/arp.c
|
diff --git a/grub-core/net/arp.c b/grub-core/net/arp.c
|
||||||
index 54306e3b1..67b409a8a 100644
|
index 54306e3b16..67b409a8ac 100644
|
||||||
--- a/grub-core/net/arp.c
|
--- a/grub-core/net/arp.c
|
||||||
+++ b/grub-core/net/arp.c
|
+++ b/grub-core/net/arp.c
|
||||||
@@ -31,22 +31,12 @@ enum
|
@@ -31,22 +31,12 @@ enum
|
||||||
@ -272,10 +271,10 @@ index 54306e3b1..67b409a8a 100644
|
|||||||
/* Change operation to REPLY and send packet */
|
/* Change operation to REPLY and send packet */
|
||||||
send_ethernet_packet (inf, &nb_reply, target, GRUB_NET_ETHERTYPE_ARP);
|
send_ethernet_packet (inf, &nb_reply, target, GRUB_NET_ETHERTYPE_ARP);
|
||||||
diff --git a/grub-core/net/bootp.c b/grub-core/net/bootp.c
|
diff --git a/grub-core/net/bootp.c b/grub-core/net/bootp.c
|
||||||
index 2869482fe..4e55adc55 100644
|
index e28fb6a09f..08b6b2b5d6 100644
|
||||||
--- a/grub-core/net/bootp.c
|
--- a/grub-core/net/bootp.c
|
||||||
+++ b/grub-core/net/bootp.c
|
+++ b/grub-core/net/bootp.c
|
||||||
@@ -219,7 +219,6 @@ grub_net_configure_by_dhcp_ack (const char *name,
|
@@ -233,7 +233,6 @@ grub_net_configure_by_dhcp_ack (const char *name,
|
||||||
int is_def, char **device, char **path)
|
int is_def, char **device, char **path)
|
||||||
{
|
{
|
||||||
grub_net_network_level_address_t addr;
|
grub_net_network_level_address_t addr;
|
||||||
@ -283,7 +282,7 @@ index 2869482fe..4e55adc55 100644
|
|||||||
struct grub_net_network_level_interface *inter;
|
struct grub_net_network_level_interface *inter;
|
||||||
int mask = -1;
|
int mask = -1;
|
||||||
char server_ip[sizeof ("xxx.xxx.xxx.xxx")];
|
char server_ip[sizeof ("xxx.xxx.xxx.xxx")];
|
||||||
@@ -232,12 +231,8 @@ grub_net_configure_by_dhcp_ack (const char *name,
|
@@ -250,12 +249,8 @@ grub_net_configure_by_dhcp_ack (const char *name,
|
||||||
if (path)
|
if (path)
|
||||||
*path = 0;
|
*path = 0;
|
||||||
|
|
||||||
@ -298,30 +297,31 @@ index 2869482fe..4e55adc55 100644
|
|||||||
if (!inter)
|
if (!inter)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@@ -770,7 +765,8 @@ grub_cmd_bootp (struct grub_command *cmd __attribute__ ((unused)),
|
@@ -567,7 +562,9 @@ send_dhcp_packet (struct grub_net_network_level_interface *iface)
|
||||||
grub_memset (pack, 0, sizeof (*pack) + 64);
|
grub_memset (pack, 0, sizeof (*pack));
|
||||||
pack->opcode = 1;
|
pack->opcode = 1;
|
||||||
pack->hw_type = 1;
|
pack->hw_type = 1;
|
||||||
- pack->hw_len = 6;
|
- pack->hw_len = 6;
|
||||||
+ pack->hw_len = ifaces[j].hwaddress.len > 16 ? 0
|
+ pack->hw_len = iface->hwaddress.len > 16 ? 0
|
||||||
+ : ifaces[j].hwaddress.len;
|
+ : iface->hwaddress.len;
|
||||||
|
+
|
||||||
err = grub_get_datetime (&date);
|
err = grub_get_datetime (&date);
|
||||||
if (err || !grub_datetime2unixtime (&date, &t))
|
if (err || !grub_datetime2unixtime (&date, &t))
|
||||||
{
|
{
|
||||||
@@ -781,7 +777,7 @@ grub_cmd_bootp (struct grub_command *cmd __attribute__ ((unused)),
|
@@ -580,7 +577,7 @@ send_dhcp_packet (struct grub_net_network_level_interface *iface)
|
||||||
ifaces[j].dhcp_xid = pack->xid;
|
else
|
||||||
pack->seconds = grub_cpu_to_be16 (t);
|
pack->ident = iface->xid;
|
||||||
|
|
||||||
- grub_memcpy (&pack->mac_addr, &ifaces[j].hwaddress.mac, 6);
|
- grub_memcpy (&pack->mac_addr, &iface->hwaddress.mac, 6);
|
||||||
+ grub_memcpy (&pack->mac_addr, &ifaces[j].hwaddress.mac, pack->hw_len);
|
+ grub_memcpy (&pack->mac_addr, &iface->hwaddress.mac, pack->hw_len);
|
||||||
|
|
||||||
grub_netbuff_push (nb, sizeof (*udph));
|
grub_netbuff_push (nb, sizeof (*udph));
|
||||||
|
|
||||||
diff --git a/grub-core/net/drivers/efi/efinet.c b/grub-core/net/drivers/efi/efinet.c
|
diff --git a/grub-core/net/drivers/efi/efinet.c b/grub-core/net/drivers/efi/efinet.c
|
||||||
index a4daaa460..cd6dba79f 100644
|
index 173fb63153..a673bea807 100644
|
||||||
--- a/grub-core/net/drivers/efi/efinet.c
|
--- a/grub-core/net/drivers/efi/efinet.c
|
||||||
+++ b/grub-core/net/drivers/efi/efinet.c
|
+++ b/grub-core/net/drivers/efi/efinet.c
|
||||||
@@ -280,6 +280,9 @@ grub_efinet_findcards (void)
|
@@ -279,6 +279,9 @@ grub_efinet_findcards (void)
|
||||||
/* This should not happen... Why? */
|
/* This should not happen... Why? */
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
@ -331,7 +331,7 @@ index a4daaa460..cd6dba79f 100644
|
|||||||
if (net->mode->state == GRUB_EFI_NETWORK_STOPPED
|
if (net->mode->state == GRUB_EFI_NETWORK_STOPPED
|
||||||
&& efi_call_1 (net->start, net) != GRUB_EFI_SUCCESS)
|
&& efi_call_1 (net->start, net) != GRUB_EFI_SUCCESS)
|
||||||
continue;
|
continue;
|
||||||
@@ -316,10 +319,11 @@ grub_efinet_findcards (void)
|
@@ -315,10 +318,11 @@ grub_efinet_findcards (void)
|
||||||
card->name = grub_xasprintf ("efinet%d", i++);
|
card->name = grub_xasprintf ("efinet%d", i++);
|
||||||
card->driver = &efidriver;
|
card->driver = &efidriver;
|
||||||
card->flags = 0;
|
card->flags = 0;
|
||||||
@ -346,7 +346,7 @@ index a4daaa460..cd6dba79f 100644
|
|||||||
card->efi_handle = *handle;
|
card->efi_handle = *handle;
|
||||||
|
|
||||||
diff --git a/grub-core/net/drivers/emu/emunet.c b/grub-core/net/drivers/emu/emunet.c
|
diff --git a/grub-core/net/drivers/emu/emunet.c b/grub-core/net/drivers/emu/emunet.c
|
||||||
index b19492086..5b6c5e16a 100644
|
index b194920861..5b6c5e16a6 100644
|
||||||
--- a/grub-core/net/drivers/emu/emunet.c
|
--- a/grub-core/net/drivers/emu/emunet.c
|
||||||
+++ b/grub-core/net/drivers/emu/emunet.c
|
+++ b/grub-core/net/drivers/emu/emunet.c
|
||||||
@@ -46,6 +46,7 @@ static struct grub_net_card emucard =
|
@@ -46,6 +46,7 @@ static struct grub_net_card emucard =
|
||||||
@ -358,7 +358,7 @@ index b19492086..5b6c5e16a 100644
|
|||||||
},
|
},
|
||||||
.flags = 0
|
.flags = 0
|
||||||
diff --git a/grub-core/net/drivers/i386/pc/pxe.c b/grub-core/net/drivers/i386/pc/pxe.c
|
diff --git a/grub-core/net/drivers/i386/pc/pxe.c b/grub-core/net/drivers/i386/pc/pxe.c
|
||||||
index 3f4152d03..9f8fb4b6d 100644
|
index 3f4152d036..9f8fb4b6d2 100644
|
||||||
--- a/grub-core/net/drivers/i386/pc/pxe.c
|
--- a/grub-core/net/drivers/i386/pc/pxe.c
|
||||||
+++ b/grub-core/net/drivers/i386/pc/pxe.c
|
+++ b/grub-core/net/drivers/i386/pc/pxe.c
|
||||||
@@ -386,20 +386,21 @@ GRUB_MOD_INIT(pxe)
|
@@ -386,20 +386,21 @@ GRUB_MOD_INIT(pxe)
|
||||||
@ -390,7 +390,7 @@ index 3f4152d03..9f8fb4b6d 100644
|
|||||||
|
|
||||||
grub_pxe_card.default_address.type = GRUB_NET_LINK_LEVEL_PROTOCOL_ETHERNET;
|
grub_pxe_card.default_address.type = GRUB_NET_LINK_LEVEL_PROTOCOL_ETHERNET;
|
||||||
diff --git a/grub-core/net/drivers/ieee1275/ofnet.c b/grub-core/net/drivers/ieee1275/ofnet.c
|
diff --git a/grub-core/net/drivers/ieee1275/ofnet.c b/grub-core/net/drivers/ieee1275/ofnet.c
|
||||||
index 3df75357a..ba50415f5 100644
|
index 3860b6f78d..bcb3f9ea02 100644
|
||||||
--- a/grub-core/net/drivers/ieee1275/ofnet.c
|
--- a/grub-core/net/drivers/ieee1275/ofnet.c
|
||||||
+++ b/grub-core/net/drivers/ieee1275/ofnet.c
|
+++ b/grub-core/net/drivers/ieee1275/ofnet.c
|
||||||
@@ -160,6 +160,7 @@ grub_ieee1275_parse_bootpath (const char *devpath, char *bootpath,
|
@@ -160,6 +160,7 @@ grub_ieee1275_parse_bootpath (const char *devpath, char *bootpath,
|
||||||
@ -410,7 +410,7 @@ index 3df75357a..ba50415f5 100644
|
|||||||
|
|
||||||
card->txbufsize = ALIGN_UP (card->mtu, 64) + 256;
|
card->txbufsize = ALIGN_UP (card->mtu, 64) + 256;
|
||||||
diff --git a/grub-core/net/drivers/uboot/ubootnet.c b/grub-core/net/drivers/uboot/ubootnet.c
|
diff --git a/grub-core/net/drivers/uboot/ubootnet.c b/grub-core/net/drivers/uboot/ubootnet.c
|
||||||
index 056052e40..22ebcbf21 100644
|
index 056052e40d..22ebcbf211 100644
|
||||||
--- a/grub-core/net/drivers/uboot/ubootnet.c
|
--- a/grub-core/net/drivers/uboot/ubootnet.c
|
||||||
+++ b/grub-core/net/drivers/uboot/ubootnet.c
|
+++ b/grub-core/net/drivers/uboot/ubootnet.c
|
||||||
@@ -131,6 +131,7 @@ GRUB_MOD_INIT (ubootnet)
|
@@ -131,6 +131,7 @@ GRUB_MOD_INIT (ubootnet)
|
||||||
@ -422,7 +422,7 @@ index 056052e40..22ebcbf21 100644
|
|||||||
card->txbufsize = ALIGN_UP (card->mtu, 64) + 256;
|
card->txbufsize = ALIGN_UP (card->mtu, 64) + 256;
|
||||||
card->txbuf = grub_zalloc (card->txbufsize);
|
card->txbuf = grub_zalloc (card->txbufsize);
|
||||||
diff --git a/grub-core/net/ethernet.c b/grub-core/net/ethernet.c
|
diff --git a/grub-core/net/ethernet.c b/grub-core/net/ethernet.c
|
||||||
index 4d7ceed6f..9aae83a5e 100644
|
index 4d7ceed6f9..9aae83a5eb 100644
|
||||||
--- a/grub-core/net/ethernet.c
|
--- a/grub-core/net/ethernet.c
|
||||||
+++ b/grub-core/net/ethernet.c
|
+++ b/grub-core/net/ethernet.c
|
||||||
@@ -29,13 +29,6 @@
|
@@ -29,13 +29,6 @@
|
||||||
@ -572,7 +572,7 @@ index 4d7ceed6f..9aae83a5e 100644
|
|||||||
{
|
{
|
||||||
/* ARP packet. */
|
/* ARP packet. */
|
||||||
diff --git a/grub-core/net/icmp6.c b/grub-core/net/icmp6.c
|
diff --git a/grub-core/net/icmp6.c b/grub-core/net/icmp6.c
|
||||||
index 2cbd95dce..56a3ec5c8 100644
|
index 2cbd95dce2..56a3ec5c8e 100644
|
||||||
--- a/grub-core/net/icmp6.c
|
--- a/grub-core/net/icmp6.c
|
||||||
+++ b/grub-core/net/icmp6.c
|
+++ b/grub-core/net/icmp6.c
|
||||||
@@ -231,8 +231,9 @@ grub_net_recv_icmp6_packet (struct grub_net_buff *nb,
|
@@ -231,8 +231,9 @@ grub_net_recv_icmp6_packet (struct grub_net_buff *nb,
|
||||||
@ -612,25 +612,25 @@ index 2cbd95dce..56a3ec5c8 100644
|
|||||||
}
|
}
|
||||||
if (ohdr->type == OPTION_PREFIX && ohdr->len == 4)
|
if (ohdr->type == OPTION_PREFIX && ohdr->len == 4)
|
||||||
diff --git a/grub-core/net/ip.c b/grub-core/net/ip.c
|
diff --git a/grub-core/net/ip.c b/grub-core/net/ip.c
|
||||||
index 8411e0ecc..b2ca74b6e 100644
|
index ea5edf8f1f..a5896f6dc2 100644
|
||||||
--- a/grub-core/net/ip.c
|
--- a/grub-core/net/ip.c
|
||||||
+++ b/grub-core/net/ip.c
|
+++ b/grub-core/net/ip.c
|
||||||
@@ -277,8 +277,8 @@ handle_dgram (struct grub_net_buff *nb,
|
@@ -276,8 +276,8 @@ handle_dgram (struct grub_net_buff *nb,
|
||||||
|
if (inf->card == card
|
||||||
&& inf->address.type == GRUB_NET_NETWORK_LEVEL_PROTOCOL_DHCP_RECV
|
&& inf->address.type == GRUB_NET_NETWORK_LEVEL_PROTOCOL_DHCP_RECV
|
||||||
&& inf->dhcp_xid == bootp->xid
|
|
||||||
&& inf->hwaddress.type == GRUB_NET_LINK_LEVEL_PROTOCOL_ETHERNET
|
&& inf->hwaddress.type == GRUB_NET_LINK_LEVEL_PROTOCOL_ETHERNET
|
||||||
- && grub_memcmp (inf->hwaddress.mac, &bootp->mac_addr,
|
- && grub_memcmp (inf->hwaddress.mac, &bootp->mac_addr,
|
||||||
- sizeof (inf->hwaddress.mac)) == 0)
|
- sizeof (inf->hwaddress.mac)) == 0)
|
||||||
+ && (grub_memcmp (inf->hwaddress.mac, &bootp->mac_addr,
|
+ && (grub_memcmp (inf->hwaddress.mac, &bootp->mac_addr,
|
||||||
+ bootp->hw_len) == 0 || bootp->hw_len == 0))
|
+ bootp->hw_len) == 0 || bootp->hw_len == 0))
|
||||||
{
|
{
|
||||||
grub_net_process_dhcp (nb, inf->card);
|
grub_net_process_dhcp (nb, inf);
|
||||||
grub_netbuff_free (nb);
|
grub_netbuff_free (nb);
|
||||||
diff --git a/grub-core/net/net.c b/grub-core/net/net.c
|
diff --git a/grub-core/net/net.c b/grub-core/net/net.c
|
||||||
index fa3e29126..9b8944292 100644
|
index 22f2689aae..a46f82362e 100644
|
||||||
--- a/grub-core/net/net.c
|
--- a/grub-core/net/net.c
|
||||||
+++ b/grub-core/net/net.c
|
+++ b/grub-core/net/net.c
|
||||||
@@ -128,8 +128,9 @@ grub_net_link_layer_resolve (struct grub_net_network_level_interface *inf,
|
@@ -133,8 +133,9 @@ grub_net_link_layer_resolve (struct grub_net_network_level_interface *inf,
|
||||||
<< 48)
|
<< 48)
|
||||||
&& proto_addr->ipv6[1] == (grub_be_to_cpu64_compile_time (1))))
|
&& proto_addr->ipv6[1] == (grub_be_to_cpu64_compile_time (1))))
|
||||||
{
|
{
|
||||||
@ -642,7 +642,7 @@ index fa3e29126..9b8944292 100644
|
|||||||
return GRUB_ERR_NONE;
|
return GRUB_ERR_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -137,6 +138,7 @@ grub_net_link_layer_resolve (struct grub_net_network_level_interface *inf,
|
@@ -142,6 +143,7 @@ grub_net_link_layer_resolve (struct grub_net_network_level_interface *inf,
|
||||||
&& ((grub_be_to_cpu64 (proto_addr->ipv6[0]) >> 56) == 0xff))
|
&& ((grub_be_to_cpu64 (proto_addr->ipv6[0]) >> 56) == 0xff))
|
||||||
{
|
{
|
||||||
hw_addr->type = GRUB_NET_LINK_LEVEL_PROTOCOL_ETHERNET;
|
hw_addr->type = GRUB_NET_LINK_LEVEL_PROTOCOL_ETHERNET;
|
||||||
@ -650,7 +650,7 @@ index fa3e29126..9b8944292 100644
|
|||||||
hw_addr->mac[0] = 0x33;
|
hw_addr->mac[0] = 0x33;
|
||||||
hw_addr->mac[1] = 0x33;
|
hw_addr->mac[1] = 0x33;
|
||||||
hw_addr->mac[2] = ((grub_be_to_cpu64 (proto_addr->ipv6[1]) >> 24) & 0xff);
|
hw_addr->mac[2] = ((grub_be_to_cpu64 (proto_addr->ipv6[1]) >> 24) & 0xff);
|
||||||
@@ -757,23 +759,21 @@ grub_net_addr_to_str (const grub_net_network_level_address_t *target, char *buf)
|
@@ -762,23 +764,23 @@ grub_net_addr_to_str (const grub_net_network_level_address_t *target, char *buf)
|
||||||
void
|
void
|
||||||
grub_net_hwaddr_to_str (const grub_net_link_level_address_t *addr, char *str)
|
grub_net_hwaddr_to_str (const grub_net_link_level_address_t *addr, char *str)
|
||||||
{
|
{
|
||||||
@ -658,6 +658,7 @@ index fa3e29126..9b8944292 100644
|
|||||||
- switch (addr->type)
|
- switch (addr->type)
|
||||||
+ char *ptr;
|
+ char *ptr;
|
||||||
+ unsigned i;
|
+ unsigned i;
|
||||||
|
+ int maxstr;
|
||||||
+
|
+
|
||||||
+ if (addr->len > GRUB_NET_MAX_LINK_ADDRESS_SIZE)
|
+ if (addr->len > GRUB_NET_MAX_LINK_ADDRESS_SIZE)
|
||||||
{
|
{
|
||||||
@ -678,16 +679,17 @@ index fa3e29126..9b8944292 100644
|
|||||||
+ addr->type, addr->len);
|
+ addr->type, addr->len);
|
||||||
+ return;
|
+ return;
|
||||||
+ }
|
+ }
|
||||||
|
+ maxstr = addr->len * grub_strlen ("XX:");
|
||||||
+ for (ptr = str, i = 0; i < addr->len; i++)
|
+ for (ptr = str, i = 0; i < addr->len; i++)
|
||||||
+ {
|
+ {
|
||||||
+ ptr += grub_snprintf (ptr, GRUB_NET_MAX_STR_HWADDR_LEN - (ptr - str),
|
+ ptr += grub_snprintf (ptr, maxstr - (ptr - str),
|
||||||
+ "%02x:", addr->mac[i] & 0xff);
|
+ "%02x:", addr->mac[i] & 0xff);
|
||||||
}
|
}
|
||||||
- grub_printf (_("Unsupported hw address type %d\n"), addr->type);
|
- grub_printf (_("Unsupported hw address type %d\n"), addr->type);
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
@@ -784,13 +784,17 @@ grub_net_hwaddr_cmp (const grub_net_link_level_address_t *a,
|
@@ -789,13 +791,17 @@ grub_net_hwaddr_cmp (const grub_net_link_level_address_t *a,
|
||||||
return -1;
|
return -1;
|
||||||
if (a->type > b->type)
|
if (a->type > b->type)
|
||||||
return +1;
|
return +1;
|
||||||
@ -711,7 +713,7 @@ index fa3e29126..9b8944292 100644
|
|||||||
|
|
||||||
int
|
int
|
||||||
diff --git a/include/grub/net.h b/include/grub/net.h
|
diff --git a/include/grub/net.h b/include/grub/net.h
|
||||||
index de51894cb..e9ebc6a1b 100644
|
index 8a05ec4fe7..af0404db7e 100644
|
||||||
--- a/include/grub/net.h
|
--- a/include/grub/net.h
|
||||||
+++ b/include/grub/net.h
|
+++ b/include/grub/net.h
|
||||||
@@ -29,7 +29,8 @@
|
@@ -29,7 +29,8 @@
|
||||||
@ -744,7 +746,7 @@ index de51894cb..e9ebc6a1b 100644
|
|||||||
};
|
};
|
||||||
} grub_net_link_level_address_t;
|
} grub_net_link_level_address_t;
|
||||||
|
|
||||||
@@ -555,11 +558,13 @@ grub_net_addr_cmp (const grub_net_network_level_address_t *a,
|
@@ -566,11 +569,13 @@ grub_net_addr_cmp (const grub_net_network_level_address_t *a,
|
||||||
#define GRUB_NET_MAX_STR_ADDR_LEN sizeof ("XXXX:XXXX:XXXX:XXXX:XXXX:XXXX:XXXX:XXXX")
|
#define GRUB_NET_MAX_STR_ADDR_LEN sizeof ("XXXX:XXXX:XXXX:XXXX:XXXX:XXXX:XXXX:XXXX")
|
||||||
|
|
||||||
/*
|
/*
|
@ -6,18 +6,33 @@ Subject: [PATCH] net: read bracketed ipv6 addrs and port numbers
|
|||||||
Allow specifying port numbers for http and tftp paths, and allow ipv6 addresses
|
Allow specifying port numbers for http and tftp paths, and allow ipv6 addresses
|
||||||
to be recognized with brackets around them, which is required to specify a port
|
to be recognized with brackets around them, which is required to specify a port
|
||||||
number
|
number
|
||||||
|
|
||||||
|
Signed-off-by: Aaron Miller <aaronmiller@fb.com>
|
||||||
|
[pjones: various bug fixes]
|
||||||
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
---
|
---
|
||||||
grub-core/net/http.c | 21 +++++++++++---
|
grub-core/net/http.c | 25 ++++++++++++---
|
||||||
grub-core/net/net.c | 77 ++++++++++++++++++++++++++++++++++++++++++++++++++++
|
grub-core/net/net.c | 87 +++++++++++++++++++++++++++++++++++++++++++++++++---
|
||||||
grub-core/net/tftp.c | 8 ++++--
|
grub-core/net/tftp.c | 8 +++--
|
||||||
include/grub/net.h | 1 +
|
include/grub/net.h | 1 +
|
||||||
4 files changed, 101 insertions(+), 6 deletions(-)
|
4 files changed, 109 insertions(+), 12 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/net/http.c b/grub-core/net/http.c
|
diff --git a/grub-core/net/http.c b/grub-core/net/http.c
|
||||||
index 5aa4ad3be..f182d7b87 100644
|
index b616cf40b1..12a2632ea5 100644
|
||||||
--- a/grub-core/net/http.c
|
--- a/grub-core/net/http.c
|
||||||
+++ b/grub-core/net/http.c
|
+++ b/grub-core/net/http.c
|
||||||
@@ -312,12 +312,14 @@ http_establish (struct grub_file *file, grub_off_t offset, int initial)
|
@@ -289,7 +289,9 @@ http_receive (grub_net_tcp_socket_t sock __attribute__ ((unused)),
|
||||||
|
nb2 = grub_netbuff_alloc (data->chunk_rem);
|
||||||
|
if (!nb2)
|
||||||
|
return grub_errno;
|
||||||
|
- grub_netbuff_put (nb2, data->chunk_rem);
|
||||||
|
+ err = grub_netbuff_put (nb2, data->chunk_rem);
|
||||||
|
+ if (err)
|
||||||
|
+ return grub_errno;
|
||||||
|
grub_memcpy (nb2->data, nb->data, data->chunk_rem);
|
||||||
|
if (file->device->net->packs.count >= 20)
|
||||||
|
{
|
||||||
|
@@ -312,12 +314,14 @@ http_establish (struct grub_file *file, grub_off_t offset, int initial)
|
||||||
int i;
|
int i;
|
||||||
struct grub_net_buff *nb;
|
struct grub_net_buff *nb;
|
||||||
grub_err_t err;
|
grub_err_t err;
|
||||||
@ -33,7 +48,7 @@ index 5aa4ad3be..f182d7b87 100644
|
|||||||
+ sizeof ("\r\nUser-Agent: " PACKAGE_STRING
|
+ sizeof ("\r\nUser-Agent: " PACKAGE_STRING
|
||||||
"\r\n") - 1
|
"\r\n") - 1
|
||||||
+ sizeof ("Range: bytes=XXXXXXXXXXXXXXXXXXXX"
|
+ sizeof ("Range: bytes=XXXXXXXXXXXXXXXXXXXX"
|
||||||
@@ -356,7 +358,7 @@ http_establish (struct grub_file *file, grub_off_t offset, int initial)
|
@@ -356,7 +360,7 @@ http_establish (struct grub_file *file, grub_off_t offset, int initial)
|
||||||
sizeof (" HTTP/1.1\r\nHost: ") - 1);
|
sizeof (" HTTP/1.1\r\nHost: ") - 1);
|
||||||
|
|
||||||
ptr = nb->tail;
|
ptr = nb->tail;
|
||||||
@ -42,7 +57,7 @@ index 5aa4ad3be..f182d7b87 100644
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
grub_netbuff_free (nb);
|
grub_netbuff_free (nb);
|
||||||
@@ -365,6 +367,15 @@ http_establish (struct grub_file *file, grub_off_t offset, int initial)
|
@@ -365,6 +369,15 @@ http_establish (struct grub_file *file, grub_off_t offset, int initial)
|
||||||
grub_memcpy (ptr, file->device->net->server,
|
grub_memcpy (ptr, file->device->net->server,
|
||||||
grub_strlen (file->device->net->server));
|
grub_strlen (file->device->net->server));
|
||||||
|
|
||||||
@ -58,7 +73,7 @@ index 5aa4ad3be..f182d7b87 100644
|
|||||||
ptr = nb->tail;
|
ptr = nb->tail;
|
||||||
err = grub_netbuff_put (nb,
|
err = grub_netbuff_put (nb,
|
||||||
sizeof ("\r\nUser-Agent: " PACKAGE_STRING "\r\n")
|
sizeof ("\r\nUser-Agent: " PACKAGE_STRING "\r\n")
|
||||||
@@ -390,8 +401,10 @@ http_establish (struct grub_file *file, grub_off_t offset, int initial)
|
@@ -390,8 +403,10 @@ http_establish (struct grub_file *file, grub_off_t offset, int initial)
|
||||||
grub_netbuff_put (nb, 2);
|
grub_netbuff_put (nb, 2);
|
||||||
grub_memcpy (ptr, "\r\n", 2);
|
grub_memcpy (ptr, "\r\n", 2);
|
||||||
|
|
||||||
@ -68,37 +83,37 @@ index 5aa4ad3be..f182d7b87 100644
|
|||||||
+ data->filename, server, port ? port : HTTP_PORT);
|
+ data->filename, server, port ? port : HTTP_PORT);
|
||||||
+ data->sock = grub_net_tcp_open (server,
|
+ data->sock = grub_net_tcp_open (server,
|
||||||
+ port ? port : HTTP_PORT, http_receive,
|
+ port ? port : HTTP_PORT, http_receive,
|
||||||
http_err, http_err,
|
http_err, NULL,
|
||||||
file);
|
file);
|
||||||
if (!data->sock)
|
if (!data->sock)
|
||||||
diff --git a/grub-core/net/net.c b/grub-core/net/net.c
|
diff --git a/grub-core/net/net.c b/grub-core/net/net.c
|
||||||
index 9b8944292..1f887d44b 100644
|
index a46f82362e..0ce5e675ed 100644
|
||||||
--- a/grub-core/net/net.c
|
--- a/grub-core/net/net.c
|
||||||
+++ b/grub-core/net/net.c
|
+++ b/grub-core/net/net.c
|
||||||
@@ -439,6 +439,12 @@ parse_ip6 (const char *val, grub_uint64_t *ip, const char **rest)
|
@@ -444,6 +444,13 @@ parse_ip6 (const char *val, grub_uint64_t *ip, const char **rest)
|
||||||
grub_uint16_t newip[8];
|
grub_uint16_t newip[8];
|
||||||
const char *ptr = val;
|
const char *ptr = val;
|
||||||
int word, quaddot = -1;
|
int word, quaddot = -1;
|
||||||
+ int bracketed = 0;
|
+ int bracketed = 0;
|
||||||
+
|
+
|
||||||
+ if (ptr[0] == '[') {
|
+ if (ptr[0] == '[')
|
||||||
|
+ {
|
||||||
+ bracketed = 1;
|
+ bracketed = 1;
|
||||||
+ ptr++;
|
+ ptr++;
|
||||||
+ }
|
+ }
|
||||||
|
|
||||||
if (ptr[0] == ':' && ptr[1] != ':')
|
if (ptr[0] == ':' && ptr[1] != ':')
|
||||||
return 0;
|
return 0;
|
||||||
@@ -477,6 +483,9 @@ parse_ip6 (const char *val, grub_uint64_t *ip, const char **rest)
|
@@ -482,6 +489,8 @@ parse_ip6 (const char *val, grub_uint64_t *ip, const char **rest)
|
||||||
grub_memset (&newip[quaddot], 0, (7 - word) * sizeof (newip[0]));
|
grub_memset (&newip[quaddot], 0, (7 - word) * sizeof (newip[0]));
|
||||||
}
|
}
|
||||||
grub_memcpy (ip, newip, 16);
|
grub_memcpy (ip, newip, 16);
|
||||||
+ if (bracketed && *ptr == ']') {
|
+ if (bracketed && *ptr == ']')
|
||||||
+ ptr++;
|
+ ptr++;
|
||||||
+ }
|
|
||||||
if (rest)
|
if (rest)
|
||||||
*rest = ptr;
|
*rest = ptr;
|
||||||
return 1;
|
return 1;
|
||||||
@@ -1336,8 +1345,10 @@ grub_net_open_real (const char *name)
|
@@ -1343,8 +1352,10 @@ grub_net_open_real (const char *name)
|
||||||
{
|
{
|
||||||
grub_net_app_level_t proto;
|
grub_net_app_level_t proto;
|
||||||
const char *protname, *server;
|
const char *protname, *server;
|
||||||
@ -109,7 +124,7 @@ index 9b8944292..1f887d44b 100644
|
|||||||
|
|
||||||
if (grub_strncmp (name, "pxe:", sizeof ("pxe:") - 1) == 0)
|
if (grub_strncmp (name, "pxe:", sizeof ("pxe:") - 1) == 0)
|
||||||
{
|
{
|
||||||
@@ -1375,6 +1386,72 @@ grub_net_open_real (const char *name)
|
@@ -1382,6 +1393,72 @@ grub_net_open_real (const char *name)
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -182,11 +197,38 @@ index 9b8944292..1f887d44b 100644
|
|||||||
for (try = 0; try < 2; try++)
|
for (try = 0; try < 2; try++)
|
||||||
{
|
{
|
||||||
FOR_NET_APP_LEVEL (proto)
|
FOR_NET_APP_LEVEL (proto)
|
||||||
|
@@ -1391,14 +1468,13 @@ grub_net_open_real (const char *name)
|
||||||
|
{
|
||||||
|
grub_net_t ret = grub_zalloc (sizeof (*ret));
|
||||||
|
if (!ret)
|
||||||
|
- return NULL;
|
||||||
|
- ret->protocol = proto;
|
||||||
|
- ret->server = grub_strdup (server);
|
||||||
|
- if (!ret->server)
|
||||||
|
{
|
||||||
|
- grub_free (ret);
|
||||||
|
+ grub_free (host);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
+ ret->protocol = proto;
|
||||||
|
+ ret->port = port;
|
||||||
|
+ ret->server = host;
|
||||||
|
ret->fs = &grub_net_fs;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
@@ -1473,6 +1549,7 @@ grub_net_open_real (const char *name)
|
||||||
|
grub_error (GRUB_ERR_UNKNOWN_DEVICE, N_("disk `%s' not found"),
|
||||||
|
name);
|
||||||
|
|
||||||
|
+ grub_free (host);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
diff --git a/grub-core/net/tftp.c b/grub-core/net/tftp.c
|
diff --git a/grub-core/net/tftp.c b/grub-core/net/tftp.c
|
||||||
index f90071353..e267af354 100644
|
index 4ab2f5c735..d54b13f09f 100644
|
||||||
--- a/grub-core/net/tftp.c
|
--- a/grub-core/net/tftp.c
|
||||||
+++ b/grub-core/net/tftp.c
|
+++ b/grub-core/net/tftp.c
|
||||||
@@ -333,6 +333,7 @@ tftp_open (struct grub_file *file, const char *filename)
|
@@ -295,6 +295,7 @@ tftp_open (struct grub_file *file, const char *filename)
|
||||||
grub_err_t err;
|
grub_err_t err;
|
||||||
grub_uint8_t *nbd;
|
grub_uint8_t *nbd;
|
||||||
grub_net_network_level_address_t addr;
|
grub_net_network_level_address_t addr;
|
||||||
@ -194,7 +236,7 @@ index f90071353..e267af354 100644
|
|||||||
|
|
||||||
data = grub_zalloc (sizeof (*data));
|
data = grub_zalloc (sizeof (*data));
|
||||||
if (!data)
|
if (!data)
|
||||||
@@ -405,7 +406,10 @@ tftp_open (struct grub_file *file, const char *filename)
|
@@ -362,14 +363,17 @@ tftp_open (struct grub_file *file, const char *filename)
|
||||||
err = grub_net_resolve_address (file->device->net->server, &addr);
|
err = grub_net_resolve_address (file->device->net->server, &addr);
|
||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
@ -203,10 +245,9 @@ index f90071353..e267af354 100644
|
|||||||
+ grub_dprintf ("tftp", "file_size is %llu, block_size is %llu\n",
|
+ grub_dprintf ("tftp", "file_size is %llu, block_size is %llu\n",
|
||||||
+ (unsigned long long)data->file_size,
|
+ (unsigned long long)data->file_size,
|
||||||
+ (unsigned long long)data->block_size);
|
+ (unsigned long long)data->block_size);
|
||||||
destroy_pq (data);
|
|
||||||
grub_free (data);
|
grub_free (data);
|
||||||
return err;
|
return err;
|
||||||
@@ -413,7 +417,7 @@ tftp_open (struct grub_file *file, const char *filename)
|
}
|
||||||
|
|
||||||
grub_dprintf("tftp", "opening connection\n");
|
grub_dprintf("tftp", "opening connection\n");
|
||||||
data->sock = grub_net_udp_open (addr,
|
data->sock = grub_net_udp_open (addr,
|
||||||
@ -216,7 +257,7 @@ index f90071353..e267af354 100644
|
|||||||
if (!data->sock)
|
if (!data->sock)
|
||||||
{
|
{
|
||||||
diff --git a/include/grub/net.h b/include/grub/net.h
|
diff --git a/include/grub/net.h b/include/grub/net.h
|
||||||
index e9ebc6a1b..f4cd86e58 100644
|
index af0404db7e..d55d505a03 100644
|
||||||
--- a/include/grub/net.h
|
--- a/include/grub/net.h
|
||||||
+++ b/include/grub/net.h
|
+++ b/include/grub/net.h
|
||||||
@@ -273,6 +273,7 @@ typedef struct grub_net
|
@@ -273,6 +273,7 @@ typedef struct grub_net
|
@ -1,6 +1,6 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
From: Michael Chang <mchang@suse.com>
|
From: Michael Chang <mchang@suse.com>
|
||||||
Date: Sun, 10 Jul 2016 23:46:06 +0800
|
Date: Wed, 10 Jul 2019 15:42:36 +0200
|
||||||
Subject: [PATCH] bootp: New net_bootp6 command
|
Subject: [PATCH] bootp: New net_bootp6 command
|
||||||
|
|
||||||
Implement new net_bootp6 command for IPv6 network auto configuration via the
|
Implement new net_bootp6 command for IPv6 network auto configuration via the
|
||||||
@ -8,21 +8,23 @@ DHCPv6 protocol (RFC3315).
|
|||||||
|
|
||||||
Signed-off-by: Michael Chang <mchang@suse.com>
|
Signed-off-by: Michael Chang <mchang@suse.com>
|
||||||
Signed-off-by: Ken Lin <ken.lin@hpe.com>
|
Signed-off-by: Ken Lin <ken.lin@hpe.com>
|
||||||
|
[pjones: Put back our code to add a local route]
|
||||||
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
---
|
---
|
||||||
grub-core/net/bootp.c | 1048 ++++++++++++++++++++++++++++++------
|
grub-core/net/bootp.c | 1059 ++++++++++++++++++++++++++++++------
|
||||||
grub-core/net/drivers/efi/efinet.c | 20 +-
|
grub-core/net/drivers/efi/efinet.c | 20 +-
|
||||||
grub-core/net/ip.c | 39 ++
|
grub-core/net/ip.c | 39 ++
|
||||||
include/grub/efi/api.h | 2 +-
|
include/grub/efi/api.h | 2 +-
|
||||||
include/grub/net.h | 91 ++--
|
include/grub/net.h | 91 ++--
|
||||||
5 files changed, 994 insertions(+), 206 deletions(-)
|
5 files changed, 1002 insertions(+), 209 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/net/bootp.c b/grub-core/net/bootp.c
|
diff --git a/grub-core/net/bootp.c b/grub-core/net/bootp.c
|
||||||
index 4e55adc55..ff1d7776e 100644
|
index 08b6b2b5d6..fe93b80f1c 100644
|
||||||
--- a/grub-core/net/bootp.c
|
--- a/grub-core/net/bootp.c
|
||||||
+++ b/grub-core/net/bootp.c
|
+++ b/grub-core/net/bootp.c
|
||||||
@@ -25,6 +25,98 @@
|
@@ -24,6 +24,98 @@
|
||||||
|
#include <grub/net/netbuff.h>
|
||||||
#include <grub/net/udp.h>
|
#include <grub/net/udp.h>
|
||||||
#include <grub/net/url.h>
|
|
||||||
#include <grub/datetime.h>
|
#include <grub/datetime.h>
|
||||||
+#include <grub/time.h>
|
+#include <grub/time.h>
|
||||||
+#include <grub/list.h>
|
+#include <grub/list.h>
|
||||||
@ -117,26 +119,12 @@ index 4e55adc55..ff1d7776e 100644
|
|||||||
+ return 1;
|
+ return 1;
|
||||||
+}
|
+}
|
||||||
|
|
||||||
static char *
|
struct grub_dhcp_discover_options
|
||||||
grub_env_write_readonly (struct grub_env_var *var __attribute__ ((unused)),
|
{
|
||||||
@@ -345,178 +437,578 @@ grub_net_configure_by_dhcp_ack (const char *name,
|
@@ -604,6 +696,584 @@ out:
|
||||||
return inter;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
-struct grub_net_network_level_interface *
|
|
||||||
-grub_net_configure_by_dhcpv6_ack (const char *name,
|
|
||||||
- struct grub_net_card *card,
|
|
||||||
- grub_net_interface_flags_t flags
|
|
||||||
- __attribute__((__unused__)),
|
|
||||||
- const grub_net_link_level_address_t *hwaddr,
|
|
||||||
- const struct grub_net_dhcpv6_packet *packet,
|
|
||||||
- int is_def, char **device, char **path)
|
|
||||||
-{
|
|
||||||
- struct grub_net_network_level_interface *inter = NULL;
|
|
||||||
- struct grub_net_network_level_address addr;
|
|
||||||
- int mask = -1;
|
|
||||||
-
|
|
||||||
- if (!device || !path)
|
|
||||||
+/* The default netbuff size for sending DHCPv6 packets which should be
|
+/* The default netbuff size for sending DHCPv6 packets which should be
|
||||||
+ large enough to hold the information */
|
+ large enough to hold the information */
|
||||||
+#define GRUB_DHCP6_DEFAULT_NETBUFF_ALLOC_SIZE 512
|
+#define GRUB_DHCP6_DEFAULT_NETBUFF_ALLOC_SIZE 512
|
||||||
@ -354,19 +342,8 @@ index 4e55adc55..ff1d7776e 100644
|
|||||||
+
|
+
|
||||||
+ options = grub_zalloc (sizeof(*options));
|
+ options = grub_zalloc (sizeof(*options));
|
||||||
+ if (!options)
|
+ if (!options)
|
||||||
return NULL;
|
+ return NULL;
|
||||||
|
+
|
||||||
- *device = 0;
|
|
||||||
- *path = 0;
|
|
||||||
-
|
|
||||||
- grub_dprintf ("net", "mac address is %02x:%02x:%02x:%02x:%02x:%02x\n",
|
|
||||||
- hwaddr->mac[0], hwaddr->mac[1], hwaddr->mac[2],
|
|
||||||
- hwaddr->mac[3], hwaddr->mac[4], hwaddr->mac[5]);
|
|
||||||
-
|
|
||||||
- if (is_def)
|
|
||||||
- grub_net_default_server = 0;
|
|
||||||
-
|
|
||||||
- if (is_def && !grub_net_default_server && packet)
|
|
||||||
+ foreach_dhcp6_option ((const struct grub_net_dhcp6_option *)v6h->dhcp_options,
|
+ foreach_dhcp6_option ((const struct grub_net_dhcp6_option *)v6h->dhcp_options,
|
||||||
+ size - sizeof (*v6h), parse_dhcp6_option, options);
|
+ size - sizeof (*v6h), parse_dhcp6_option, options);
|
||||||
+
|
+
|
||||||
@ -410,165 +387,37 @@ index 4e55adc55..ff1d7776e 100644
|
|||||||
+ struct grub_net_network_level_interface *inf;
|
+ struct grub_net_network_level_interface *inf;
|
||||||
+
|
+
|
||||||
+ if (dhcp6->ia_addr)
|
+ if (dhcp6->ia_addr)
|
||||||
{
|
+ {
|
||||||
- const grub_uint8_t *options = packet->dhcp_options;
|
|
||||||
- unsigned int option_max = 1024 - OFFSET_OF (dhcp_options, packet);
|
|
||||||
- unsigned int i;
|
|
||||||
-
|
|
||||||
- for (i = 0; i < option_max - sizeof (grub_net_dhcpv6_option_t); )
|
|
||||||
- {
|
|
||||||
- grub_uint16_t num, len;
|
|
||||||
- grub_net_dhcpv6_option_t *opt =
|
|
||||||
- (grub_net_dhcpv6_option_t *)(options + i);
|
|
||||||
-
|
|
||||||
- num = grub_be_to_cpu16(opt->option_num);
|
|
||||||
- len = grub_be_to_cpu16(opt->option_len);
|
|
||||||
-
|
|
||||||
- grub_dprintf ("net", "got dhcpv6 option %d len %d\n", num, len);
|
|
||||||
-
|
|
||||||
- if (len == 0)
|
|
||||||
- break;
|
|
||||||
-
|
|
||||||
- if (len + i > 1024)
|
|
||||||
- break;
|
|
||||||
-
|
|
||||||
- if (num == GRUB_NET_DHCP6_BOOTFILE_URL)
|
|
||||||
- {
|
|
||||||
- char *scheme, *userinfo, *host, *file;
|
|
||||||
- char *tmp;
|
|
||||||
- int hostlen;
|
|
||||||
- int port;
|
|
||||||
- int rc = extract_url_info ((const char *)opt->option_data,
|
|
||||||
- (grub_size_t)len,
|
|
||||||
- &scheme, &userinfo, &host, &port,
|
|
||||||
- &file);
|
|
||||||
- if (rc < 0)
|
|
||||||
- continue;
|
|
||||||
-
|
|
||||||
- /* right now this only handles tftp. */
|
|
||||||
- if (grub_strcmp("tftp", scheme))
|
|
||||||
- {
|
|
||||||
- grub_free (scheme);
|
|
||||||
- grub_free (userinfo);
|
|
||||||
- grub_free (host);
|
|
||||||
- grub_free (file);
|
|
||||||
- continue;
|
|
||||||
- }
|
|
||||||
- grub_free (userinfo);
|
|
||||||
-
|
|
||||||
- hostlen = grub_strlen (host);
|
|
||||||
- if (hostlen > 2 && host[0] == '[' && host[hostlen-1] == ']')
|
|
||||||
- {
|
|
||||||
- tmp = host+1;
|
|
||||||
- host[hostlen-1] = '\0';
|
|
||||||
- }
|
|
||||||
- else
|
|
||||||
- tmp = host;
|
|
||||||
+ inf = grub_net_add_addr (name, card, dhcp6->ia_addr, &card->default_address, flags);
|
+ inf = grub_net_add_addr (name, card, dhcp6->ia_addr, &card->default_address, flags);
|
||||||
|
+
|
||||||
- *device = grub_xasprintf ("%s,%s", scheme, tmp);
|
|
||||||
- grub_free (scheme);
|
|
||||||
- grub_free (host);
|
|
||||||
+ netaddr.type = GRUB_NET_NETWORK_LEVEL_PROTOCOL_IPV6;
|
+ netaddr.type = GRUB_NET_NETWORK_LEVEL_PROTOCOL_IPV6;
|
||||||
+ netaddr.ipv6.base[0] = dhcp6->ia_addr->ipv6[0];
|
+ netaddr.ipv6.base[0] = dhcp6->ia_addr->ipv6[0];
|
||||||
+ netaddr.ipv6.base[1] = 0;
|
+ netaddr.ipv6.base[1] = 0;
|
||||||
+ netaddr.ipv6.masksize = 64;
|
+ netaddr.ipv6.masksize = 64;
|
||||||
+ grub_net_add_route (name, netaddr, inf);
|
+ grub_net_add_route (name, netaddr, inf);
|
||||||
|
+
|
||||||
- if (file && *file)
|
|
||||||
- {
|
|
||||||
- tmp = grub_strrchr (file, '/');
|
|
||||||
- if (tmp)
|
|
||||||
- *(tmp+1) = '\0';
|
|
||||||
- else
|
|
||||||
- file[0] = '\0';
|
|
||||||
- }
|
|
||||||
- else if (!file)
|
|
||||||
- file = grub_strdup ("");
|
|
||||||
-
|
|
||||||
- if (file[0] == '/')
|
|
||||||
- {
|
|
||||||
- *path = grub_strdup (file+1);
|
|
||||||
- grub_free (file);
|
|
||||||
- }
|
|
||||||
- else
|
|
||||||
- *path = file;
|
|
||||||
- }
|
|
||||||
- else if (num == GRUB_NET_DHCP6_IA_NA)
|
|
||||||
- {
|
|
||||||
- const grub_net_dhcpv6_option_t *ia_na_opt;
|
|
||||||
- const grub_net_dhcpv6_opt_ia_na_t *ia_na =
|
|
||||||
- (const grub_net_dhcpv6_opt_ia_na_t *)opt;
|
|
||||||
- unsigned int left = len - OFFSET_OF (options, ia_na);
|
|
||||||
- unsigned int j;
|
|
||||||
-
|
|
||||||
- if ((grub_uint8_t *)ia_na + left >
|
|
||||||
- (grub_uint8_t *)options + option_max)
|
|
||||||
- left -= ((grub_uint8_t *)ia_na + left)
|
|
||||||
- - ((grub_uint8_t *)options + option_max);
|
|
||||||
-
|
|
||||||
- if (len < OFFSET_OF (option_data, opt)
|
|
||||||
- + sizeof (grub_net_dhcpv6_option_t))
|
|
||||||
- {
|
|
||||||
- grub_dprintf ("net",
|
|
||||||
- "found dhcpv6 ia_na option with no address\n");
|
|
||||||
- continue;
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
- for (j = 0; left > sizeof (grub_net_dhcpv6_option_t); )
|
|
||||||
- {
|
|
||||||
- ia_na_opt = (const grub_net_dhcpv6_option_t *)
|
|
||||||
- (ia_na->options + j);
|
|
||||||
- grub_uint16_t ia_na_opt_num, ia_na_opt_len;
|
|
||||||
-
|
|
||||||
- ia_na_opt_num = grub_be_to_cpu16 (ia_na_opt->option_num);
|
|
||||||
- ia_na_opt_len = grub_be_to_cpu16 (ia_na_opt->option_len);
|
|
||||||
- if (ia_na_opt_len == 0)
|
|
||||||
- break;
|
|
||||||
- if (j + ia_na_opt_len > left)
|
|
||||||
- break;
|
|
||||||
- if (ia_na_opt_num == GRUB_NET_DHCP6_IA_ADDRESS)
|
|
||||||
- {
|
|
||||||
- const grub_net_dhcpv6_opt_ia_address_t *ia_addr;
|
|
||||||
-
|
|
||||||
- ia_addr = (const grub_net_dhcpv6_opt_ia_address_t *)
|
|
||||||
- ia_na_opt;
|
|
||||||
- addr.type = GRUB_NET_NETWORK_LEVEL_PROTOCOL_IPV6;
|
|
||||||
- grub_memcpy(addr.ipv6, ia_addr->ipv6_address,
|
|
||||||
- sizeof (ia_addr->ipv6_address));
|
|
||||||
- inter = grub_net_add_addr (name, card, &addr, hwaddr, 0);
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
- j += ia_na_opt_len;
|
|
||||||
- left -= ia_na_opt_len;
|
|
||||||
- }
|
|
||||||
- }
|
|
||||||
+ if (ret_inf)
|
+ if (ret_inf)
|
||||||
+ *ret_inf = inf;
|
+ *ret_inf = inf;
|
||||||
+ }
|
+ }
|
||||||
|
+
|
||||||
- i += len + 4;
|
|
||||||
- }
|
|
||||||
+ if (dhcp6->dns_server_addrs)
|
+ if (dhcp6->dns_server_addrs)
|
||||||
+ {
|
+ {
|
||||||
+ grub_uint16_t i;
|
+ grub_uint16_t i;
|
||||||
|
+
|
||||||
- grub_print_error ();
|
|
||||||
+ for (i = 0; i < dhcp6->num_dns_server; ++i)
|
+ for (i = 0; i < dhcp6->num_dns_server; ++i)
|
||||||
+ grub_net_add_dns_server (dhcp6->dns_server_addrs + i);
|
+ grub_net_add_dns_server (dhcp6->dns_server_addrs + i);
|
||||||
}
|
+ }
|
||||||
|
+
|
||||||
- if (is_def)
|
|
||||||
+ if (dhcp6->boot_file_path)
|
+ if (dhcp6->boot_file_path)
|
||||||
+ grub_env_set_net_property (name, "boot_file", dhcp6->boot_file_path,
|
+ grub_env_set_net_property (name, "boot_file", dhcp6->boot_file_path,
|
||||||
+ grub_strlen (dhcp6->boot_file_path));
|
+ grub_strlen (dhcp6->boot_file_path));
|
||||||
+
|
+
|
||||||
+ if (is_def && dhcp6->boot_file_server_ip)
|
+ if (is_def && dhcp6->boot_file_server_ip)
|
||||||
{
|
+ {
|
||||||
+ grub_net_default_server = grub_strdup (dhcp6->boot_file_server_ip);
|
+ grub_net_default_server = grub_strdup (dhcp6->boot_file_server_ip);
|
||||||
grub_env_set ("net_default_interface", name);
|
+ grub_env_set ("net_default_interface", name);
|
||||||
grub_env_export ("net_default_interface");
|
+ grub_env_export ("net_default_interface");
|
||||||
}
|
+ }
|
||||||
+}
|
+}
|
||||||
+
|
+
|
||||||
+static void
|
+static void
|
||||||
@ -628,10 +477,7 @@ index 4e55adc55..ff1d7776e 100644
|
|||||||
+grub_dhcp6_session_configure_network (grub_dhcp6_session_t se)
|
+grub_dhcp6_session_configure_network (grub_dhcp6_session_t se)
|
||||||
+{
|
+{
|
||||||
+ char *name;
|
+ char *name;
|
||||||
|
+
|
||||||
- if (inter)
|
|
||||||
- grub_net_add_ipv6_local (inter, mask);
|
|
||||||
- return inter;
|
|
||||||
+ name = grub_xasprintf ("%s:dhcp6", se->iface->card->name);
|
+ name = grub_xasprintf ("%s:dhcp6", se->iface->card->name);
|
||||||
+ if (!name)
|
+ if (!name)
|
||||||
+ return grub_errno;
|
+ return grub_errno;
|
||||||
@ -640,8 +486,8 @@ index 4e55adc55..ff1d7776e 100644
|
|||||||
+ grub_free (name);
|
+ grub_free (name);
|
||||||
+
|
+
|
||||||
+ return GRUB_ERR_NONE;
|
+ return GRUB_ERR_NONE;
|
||||||
}
|
+}
|
||||||
|
+
|
||||||
+static grub_err_t
|
+static grub_err_t
|
||||||
+grub_dhcp6_session_send_request (grub_dhcp6_session_t se)
|
+grub_dhcp6_session_send_request (grub_dhcp6_session_t se)
|
||||||
+{
|
+{
|
||||||
@ -818,6 +664,7 @@ index 4e55adc55..ff1d7776e 100644
|
|||||||
+{
|
+{
|
||||||
+ struct grub_net_network_level_interface *inf;
|
+ struct grub_net_network_level_interface *inf;
|
||||||
+ grub_dhcp6_options_t dhcp6;
|
+ grub_dhcp6_options_t dhcp6;
|
||||||
|
+ int mask = -1;
|
||||||
+
|
+
|
||||||
+ dhcp6 = grub_dhcp6_options_get (v6h, size);
|
+ dhcp6 = grub_dhcp6_options_get (v6h, size);
|
||||||
+ if (!dhcp6)
|
+ if (!dhcp6)
|
||||||
@ -849,12 +696,17 @@ index 4e55adc55..ff1d7776e 100644
|
|||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ grub_dhcp6_options_free (dhcp6);
|
+ grub_dhcp6_options_free (dhcp6);
|
||||||
|
+
|
||||||
|
+ if (inf)
|
||||||
|
+ grub_net_add_ipv6_local (inf, mask);
|
||||||
|
+
|
||||||
+ return inf;
|
+ return inf;
|
||||||
+}
|
+}
|
||||||
|
+
|
||||||
void
|
/*
|
||||||
grub_net_process_dhcp (struct grub_net_buff *nb,
|
* This is called directly from net/ip.c:handle_dgram(), because those
|
||||||
@@ -550,6 +1042,77 @@ grub_net_process_dhcp (struct grub_net_buff *nb,
|
* BOOTP/DHCP packets are a bit special due to their improper
|
||||||
|
@@ -672,6 +1342,77 @@ grub_net_process_dhcp (struct grub_net_buff *nb,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -932,42 +784,195 @@ index 4e55adc55..ff1d7776e 100644
|
|||||||
static grub_err_t
|
static grub_err_t
|
||||||
grub_cmd_dhcpopt (struct grub_command *cmd __attribute__ ((unused)),
|
grub_cmd_dhcpopt (struct grub_command *cmd __attribute__ ((unused)),
|
||||||
int argc, char **args)
|
int argc, char **args)
|
||||||
@@ -824,7 +1387,174 @@ grub_cmd_bootp (struct grub_command *cmd __attribute__ ((unused)),
|
@@ -897,180 +1638,174 @@ grub_cmd_bootp (struct grub_command *cmd __attribute__ ((unused)),
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
-static grub_command_t cmd_getdhcp, cmd_bootp;
|
-static grub_command_t cmd_getdhcp, cmd_bootp, cmd_dhcp;
|
||||||
|
-
|
||||||
|
-struct grub_net_network_level_interface *
|
||||||
|
-grub_net_configure_by_dhcpv6_ack (const char *name,
|
||||||
|
- struct grub_net_card *card,
|
||||||
|
- grub_net_interface_flags_t flags
|
||||||
|
- __attribute__((__unused__)),
|
||||||
|
- const grub_net_link_level_address_t *hwaddr,
|
||||||
|
- const struct grub_net_dhcpv6_packet *packet,
|
||||||
|
- int is_def, char **device, char **path)
|
||||||
+static grub_err_t
|
+static grub_err_t
|
||||||
+grub_cmd_bootp6 (struct grub_command *cmd __attribute__ ((unused)),
|
+grub_cmd_bootp6 (struct grub_command *cmd __attribute__ ((unused)),
|
||||||
+ int argc, char **args)
|
+ int argc, char **args)
|
||||||
+{
|
{
|
||||||
|
- struct grub_net_network_level_interface *inter = NULL;
|
||||||
|
- struct grub_net_network_level_address addr;
|
||||||
|
- int mask = -1;
|
||||||
+ struct grub_net_card *card;
|
+ struct grub_net_card *card;
|
||||||
+ grub_uint32_t iaid = 0;
|
+ grub_uint32_t iaid = 0;
|
||||||
+ int interval;
|
+ int interval;
|
||||||
+ grub_err_t err;
|
+ grub_err_t err;
|
||||||
+ grub_dhcp6_session_t se;
|
+ grub_dhcp6_session_t se;
|
||||||
+
|
|
||||||
|
- if (!device || !path)
|
||||||
|
- return NULL;
|
||||||
+ err = GRUB_ERR_NONE;
|
+ err = GRUB_ERR_NONE;
|
||||||
+
|
|
||||||
|
- *device = 0;
|
||||||
|
- *path = 0;
|
||||||
+ FOR_NET_CARDS (card)
|
+ FOR_NET_CARDS (card)
|
||||||
+ {
|
+ {
|
||||||
+ struct grub_net_network_level_interface *iface;
|
+ struct grub_net_network_level_interface *iface;
|
||||||
+
|
|
||||||
|
- grub_dprintf ("net", "mac address is %02x:%02x:%02x:%02x:%02x:%02x\n",
|
||||||
|
- hwaddr->mac[0], hwaddr->mac[1], hwaddr->mac[2],
|
||||||
|
- hwaddr->mac[3], hwaddr->mac[4], hwaddr->mac[5]);
|
||||||
+ if (argc > 0 && grub_strcmp (card->name, args[0]) != 0)
|
+ if (argc > 0 && grub_strcmp (card->name, args[0]) != 0)
|
||||||
+ continue;
|
+ continue;
|
||||||
+
|
|
||||||
|
- if (is_def)
|
||||||
|
- grub_net_default_server = 0;
|
||||||
+ iface = grub_net_ipv6_get_link_local (card, &card->default_address);
|
+ iface = grub_net_ipv6_get_link_local (card, &card->default_address);
|
||||||
+ if (!iface)
|
+ if (!iface)
|
||||||
+ {
|
+ {
|
||||||
+ grub_dhcp6_session_remove_all ();
|
+ grub_dhcp6_session_remove_all ();
|
||||||
+ return grub_errno;
|
+ return grub_errno;
|
||||||
+ }
|
+ }
|
||||||
+
|
|
||||||
|
- if (is_def && !grub_net_default_server && packet)
|
||||||
+ grub_dhcp6_session_add (iface, iaid++);
|
+ grub_dhcp6_session_add (iface, iaid++);
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ for (interval = 200; interval < 10000; interval *= 2)
|
+ for (interval = 200; interval < 10000; interval *= 2)
|
||||||
+ {
|
{
|
||||||
|
- const grub_uint8_t *options = packet->dhcp_options;
|
||||||
|
- unsigned int option_max = 1024 - OFFSET_OF (dhcp_options, packet);
|
||||||
|
- unsigned int i;
|
||||||
|
-
|
||||||
|
- for (i = 0; i < option_max - sizeof (grub_net_dhcpv6_option_t); )
|
||||||
|
- {
|
||||||
|
- grub_uint16_t num, len;
|
||||||
|
- grub_net_dhcpv6_option_t *opt =
|
||||||
|
- (grub_net_dhcpv6_option_t *)(options + i);
|
||||||
|
-
|
||||||
|
- num = grub_be_to_cpu16(opt->option_num);
|
||||||
|
- len = grub_be_to_cpu16(opt->option_len);
|
||||||
|
-
|
||||||
|
- grub_dprintf ("net", "got dhcpv6 option %d len %d\n", num, len);
|
||||||
|
-
|
||||||
|
- if (len == 0)
|
||||||
|
- break;
|
||||||
|
-
|
||||||
|
- if (len + i > 1024)
|
||||||
|
- break;
|
||||||
|
-
|
||||||
|
- if (num == GRUB_NET_DHCP6_BOOTFILE_URL)
|
||||||
|
- {
|
||||||
|
- char *scheme, *userinfo, *host, *file;
|
||||||
|
- char *tmp;
|
||||||
|
- int hostlen;
|
||||||
|
- int port;
|
||||||
|
- int rc = extract_url_info ((const char *)opt->option_data,
|
||||||
|
- (grub_size_t)len,
|
||||||
|
- &scheme, &userinfo, &host, &port,
|
||||||
|
- &file);
|
||||||
|
- if (rc < 0)
|
||||||
|
- continue;
|
||||||
|
-
|
||||||
|
- /* right now this only handles tftp. */
|
||||||
|
- if (grub_strcmp("tftp", scheme))
|
||||||
|
- {
|
||||||
|
- grub_free (scheme);
|
||||||
|
- grub_free (userinfo);
|
||||||
|
- grub_free (host);
|
||||||
|
- grub_free (file);
|
||||||
|
- continue;
|
||||||
|
- }
|
||||||
|
- grub_free (userinfo);
|
||||||
|
-
|
||||||
|
- hostlen = grub_strlen (host);
|
||||||
|
- if (hostlen > 2 && host[0] == '[' && host[hostlen-1] == ']')
|
||||||
|
- {
|
||||||
|
- tmp = host+1;
|
||||||
|
- host[hostlen-1] = '\0';
|
||||||
|
- }
|
||||||
|
- else
|
||||||
|
- tmp = host;
|
||||||
|
-
|
||||||
|
- *device = grub_xasprintf ("%s,%s", scheme, tmp);
|
||||||
|
- grub_free (scheme);
|
||||||
|
- grub_free (host);
|
||||||
|
-
|
||||||
|
- if (file && *file)
|
||||||
|
- {
|
||||||
|
- tmp = grub_strrchr (file, '/');
|
||||||
|
- if (tmp)
|
||||||
|
- *(tmp+1) = '\0';
|
||||||
|
- else
|
||||||
|
- file[0] = '\0';
|
||||||
|
- }
|
||||||
|
- else if (!file)
|
||||||
|
- file = grub_strdup ("");
|
||||||
|
-
|
||||||
|
- if (file[0] == '/')
|
||||||
|
- {
|
||||||
|
- *path = grub_strdup (file+1);
|
||||||
|
- grub_free (file);
|
||||||
|
- }
|
||||||
|
- else
|
||||||
|
- *path = file;
|
||||||
|
- }
|
||||||
|
- else if (num == GRUB_NET_DHCP6_IA_NA)
|
||||||
|
- {
|
||||||
|
- const grub_net_dhcpv6_option_t *ia_na_opt;
|
||||||
|
- const grub_net_dhcpv6_opt_ia_na_t *ia_na =
|
||||||
|
- (const grub_net_dhcpv6_opt_ia_na_t *)opt;
|
||||||
|
- unsigned int left = len - OFFSET_OF (options, ia_na);
|
||||||
|
- unsigned int j;
|
||||||
|
-
|
||||||
|
- if ((grub_uint8_t *)ia_na + left >
|
||||||
|
- (grub_uint8_t *)options + option_max)
|
||||||
|
- left -= ((grub_uint8_t *)ia_na + left)
|
||||||
|
- - ((grub_uint8_t *)options + option_max);
|
||||||
|
-
|
||||||
|
- if (len < OFFSET_OF (option_data, opt)
|
||||||
|
- + sizeof (grub_net_dhcpv6_option_t))
|
||||||
|
- {
|
||||||
|
- grub_dprintf ("net",
|
||||||
|
- "found dhcpv6 ia_na option with no address\n");
|
||||||
|
- continue;
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- for (j = 0; left > sizeof (grub_net_dhcpv6_option_t); )
|
||||||
|
- {
|
||||||
|
- ia_na_opt = (const grub_net_dhcpv6_option_t *)
|
||||||
|
- (ia_na->options + j);
|
||||||
|
- grub_uint16_t ia_na_opt_num, ia_na_opt_len;
|
||||||
|
-
|
||||||
|
- ia_na_opt_num = grub_be_to_cpu16 (ia_na_opt->option_num);
|
||||||
|
- ia_na_opt_len = grub_be_to_cpu16 (ia_na_opt->option_len);
|
||||||
|
- if (ia_na_opt_len == 0)
|
||||||
|
- break;
|
||||||
|
- if (j + ia_na_opt_len > left)
|
||||||
|
- break;
|
||||||
|
- if (ia_na_opt_num == GRUB_NET_DHCP6_IA_ADDRESS)
|
||||||
|
- {
|
||||||
|
- const grub_net_dhcpv6_opt_ia_address_t *ia_addr;
|
||||||
|
-
|
||||||
|
- ia_addr = (const grub_net_dhcpv6_opt_ia_address_t *)
|
||||||
|
- ia_na_opt;
|
||||||
|
- addr.type = GRUB_NET_NETWORK_LEVEL_PROTOCOL_IPV6;
|
||||||
|
- grub_memcpy(addr.ipv6, ia_addr->ipv6_address,
|
||||||
|
- sizeof (ia_addr->ipv6_address));
|
||||||
|
- inter = grub_net_add_addr (name, card, &addr, hwaddr, 0);
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- j += ia_na_opt_len;
|
||||||
|
- left -= ia_na_opt_len;
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- i += len + 4;
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- grub_print_error ();
|
||||||
+ int done = 1;
|
+ int done = 1;
|
||||||
+
|
+
|
||||||
+ FOR_DHCP6_SESSIONS (se)
|
+ FOR_DHCP6_SESSIONS (se)
|
||||||
@ -1089,26 +1094,32 @@ index 4e55adc55..ff1d7776e 100644
|
|||||||
+ }
|
+ }
|
||||||
+ if (!done)
|
+ if (!done)
|
||||||
+ grub_net_poll_cards (interval, 0);
|
+ grub_net_poll_cards (interval, 0);
|
||||||
+ }
|
}
|
||||||
+
|
|
||||||
|
- if (is_def)
|
||||||
+ FOR_DHCP6_SESSIONS (se)
|
+ FOR_DHCP6_SESSIONS (se)
|
||||||
+ {
|
{
|
||||||
|
- grub_env_set ("net_default_interface", name);
|
||||||
|
- grub_env_export ("net_default_interface");
|
||||||
+ grub_error_push ();
|
+ grub_error_push ();
|
||||||
+ err = grub_error (GRUB_ERR_FILE_NOT_FOUND,
|
+ err = grub_error (GRUB_ERR_FILE_NOT_FOUND,
|
||||||
+ N_("couldn't autoconfigure %s"),
|
+ N_("couldn't autoconfigure %s"),
|
||||||
+ se->iface->card->name);
|
+ se->iface->card->name);
|
||||||
+ }
|
}
|
||||||
+
|
|
||||||
|
- if (inter)
|
||||||
|
- grub_net_add_ipv6_local (inter, mask);
|
||||||
|
- return inter;
|
||||||
+ grub_dhcp6_session_remove_all ();
|
+ grub_dhcp6_session_remove_all ();
|
||||||
+
|
+
|
||||||
+ return err;
|
+ return err;
|
||||||
+}
|
}
|
||||||
+
|
|
||||||
+static grub_command_t cmd_getdhcp, cmd_bootp, cmd_bootp6;
|
+static grub_command_t cmd_getdhcp, cmd_bootp, cmd_dhcp, cmd_bootp6;
|
||||||
|
|
||||||
void
|
void
|
||||||
grub_bootp_init (void)
|
grub_bootp_init (void)
|
||||||
@@ -835,6 +1565,9 @@ grub_bootp_init (void)
|
@@ -1084,11 +1819,15 @@ grub_bootp_init (void)
|
||||||
cmd_getdhcp = grub_register_command ("net_get_dhcp_option", grub_cmd_dhcpopt,
|
cmd_getdhcp = grub_register_command ("net_get_dhcp_option", grub_cmd_dhcpopt,
|
||||||
N_("VAR INTERFACE NUMBER DESCRIPTION"),
|
N_("VAR INTERFACE NUMBER DESCRIPTION"),
|
||||||
N_("retrieve DHCP option and save it into VAR. If VAR is - then print the value."));
|
N_("retrieve DHCP option and save it into VAR. If VAR is - then print the value."));
|
||||||
@ -1118,14 +1129,14 @@ index 4e55adc55..ff1d7776e 100644
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@@ -842,4 +1575,5 @@ grub_bootp_fini (void)
|
grub_bootp_fini (void)
|
||||||
{
|
{
|
||||||
|
+ grub_unregister_command (cmd_bootp6);
|
||||||
grub_unregister_command (cmd_getdhcp);
|
grub_unregister_command (cmd_getdhcp);
|
||||||
grub_unregister_command (cmd_bootp);
|
grub_unregister_command (cmd_bootp);
|
||||||
+ grub_unregister_command (cmd_bootp6);
|
grub_unregister_command (cmd_dhcp);
|
||||||
}
|
|
||||||
diff --git a/grub-core/net/drivers/efi/efinet.c b/grub-core/net/drivers/efi/efinet.c
|
diff --git a/grub-core/net/drivers/efi/efinet.c b/grub-core/net/drivers/efi/efinet.c
|
||||||
index cd6dba79f..6fd0a4f49 100644
|
index a673bea807..8e25680db0 100644
|
||||||
--- a/grub-core/net/drivers/efi/efinet.c
|
--- a/grub-core/net/drivers/efi/efinet.c
|
||||||
+++ b/grub-core/net/drivers/efi/efinet.c
|
+++ b/grub-core/net/drivers/efi/efinet.c
|
||||||
@@ -393,9 +393,6 @@ grub_efi_net_config_real (grub_efi_handle_t hnd, char **device,
|
@@ -393,9 +393,6 @@ grub_efi_net_config_real (grub_efi_handle_t hnd, char **device,
|
||||||
@ -1163,7 +1174,7 @@ index cd6dba79f..6fd0a4f49 100644
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
diff --git a/grub-core/net/ip.c b/grub-core/net/ip.c
|
diff --git a/grub-core/net/ip.c b/grub-core/net/ip.c
|
||||||
index b2ca74b6e..9a4e589aa 100644
|
index a5896f6dc2..ce6bdc75c6 100644
|
||||||
--- a/grub-core/net/ip.c
|
--- a/grub-core/net/ip.c
|
||||||
+++ b/grub-core/net/ip.c
|
+++ b/grub-core/net/ip.c
|
||||||
@@ -239,6 +239,45 @@ handle_dgram (struct grub_net_buff *nb,
|
@@ -239,6 +239,45 @@ handle_dgram (struct grub_net_buff *nb,
|
||||||
@ -1213,10 +1224,10 @@ index b2ca74b6e..9a4e589aa 100644
|
|||||||
{
|
{
|
||||||
const struct grub_net_bootp_packet *bootp;
|
const struct grub_net_bootp_packet *bootp;
|
||||||
diff --git a/include/grub/efi/api.h b/include/grub/efi/api.h
|
diff --git a/include/grub/efi/api.h b/include/grub/efi/api.h
|
||||||
index e5b521bd9..1250d493e 100644
|
index 9962880147..7614b58dca 100644
|
||||||
--- a/include/grub/efi/api.h
|
--- a/include/grub/efi/api.h
|
||||||
+++ b/include/grub/efi/api.h
|
+++ b/include/grub/efi/api.h
|
||||||
@@ -1507,7 +1507,7 @@ typedef struct grub_efi_pxe_ip_filter
|
@@ -1532,7 +1532,7 @@ typedef struct grub_efi_pxe_ip_filter
|
||||||
{
|
{
|
||||||
grub_efi_uint8_t filters;
|
grub_efi_uint8_t filters;
|
||||||
grub_efi_uint8_t ip_count;
|
grub_efi_uint8_t ip_count;
|
||||||
@ -1226,10 +1237,10 @@ index e5b521bd9..1250d493e 100644
|
|||||||
} grub_efi_pxe_ip_filter_t;
|
} grub_efi_pxe_ip_filter_t;
|
||||||
|
|
||||||
diff --git a/include/grub/net.h b/include/grub/net.h
|
diff --git a/include/grub/net.h b/include/grub/net.h
|
||||||
index f4cd86e58..5f78b22e1 100644
|
index d55d505a03..543251f727 100644
|
||||||
--- a/include/grub/net.h
|
--- a/include/grub/net.h
|
||||||
+++ b/include/grub/net.h
|
+++ b/include/grub/net.h
|
||||||
@@ -447,50 +447,65 @@ struct grub_net_bootp_packet
|
@@ -451,50 +451,65 @@ struct grub_net_bootp_packet
|
||||||
grub_uint8_t vendor[0];
|
grub_uint8_t vendor[0];
|
||||||
} GRUB_PACKED;
|
} GRUB_PACKED;
|
||||||
|
|
||||||
@ -1325,7 +1336,7 @@ index f4cd86e58..5f78b22e1 100644
|
|||||||
|
|
||||||
#define GRUB_NET_BOOTP_RFC1048_MAGIC_0 0x63
|
#define GRUB_NET_BOOTP_RFC1048_MAGIC_0 0x63
|
||||||
#define GRUB_NET_BOOTP_RFC1048_MAGIC_1 0x82
|
#define GRUB_NET_BOOTP_RFC1048_MAGIC_1 0x82
|
||||||
@@ -521,12 +536,12 @@ grub_net_configure_by_dhcp_ack (const char *name,
|
@@ -532,12 +547,12 @@ grub_net_configure_by_dhcp_ack (const char *name,
|
||||||
int is_def, char **device, char **path);
|
int is_def, char **device, char **path);
|
||||||
|
|
||||||
struct grub_net_network_level_interface *
|
struct grub_net_network_level_interface *
|
||||||
@ -1344,9 +1355,9 @@ index f4cd86e58..5f78b22e1 100644
|
|||||||
|
|
||||||
int
|
int
|
||||||
grub_ipv6_get_masksize(grub_uint16_t *mask);
|
grub_ipv6_get_masksize(grub_uint16_t *mask);
|
||||||
@@ -543,6 +558,10 @@ void
|
@@ -554,6 +569,10 @@ void
|
||||||
grub_net_process_dhcp (struct grub_net_buff *nb,
|
grub_net_process_dhcp (struct grub_net_buff *nb,
|
||||||
struct grub_net_card *card);
|
struct grub_net_network_level_interface *iface);
|
||||||
|
|
||||||
+grub_err_t
|
+grub_err_t
|
||||||
+grub_net_process_dhcp6 (struct grub_net_buff *nb,
|
+grub_net_process_dhcp6 (struct grub_net_buff *nb,
|
@ -15,7 +15,7 @@ Signed-off-by: Ken Lin <ken.lin@hpe.com>
|
|||||||
2 files changed, 46 insertions(+), 27 deletions(-)
|
2 files changed, 46 insertions(+), 27 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/net/drivers/efi/efinet.c b/grub-core/net/drivers/efi/efinet.c
|
diff --git a/grub-core/net/drivers/efi/efinet.c b/grub-core/net/drivers/efi/efinet.c
|
||||||
index 6fd0a4f49..712b4f859 100644
|
index 8e25680db0..014e5bf980 100644
|
||||||
--- a/grub-core/net/drivers/efi/efinet.c
|
--- a/grub-core/net/drivers/efi/efinet.c
|
||||||
+++ b/grub-core/net/drivers/efi/efinet.c
|
+++ b/grub-core/net/drivers/efi/efinet.c
|
||||||
@@ -409,6 +409,8 @@ grub_efi_net_config_real (grub_efi_handle_t hnd, char **device,
|
@@ -409,6 +409,8 @@ grub_efi_net_config_real (grub_efi_handle_t hnd, char **device,
|
||||||
@ -28,10 +28,10 @@ index 6fd0a4f49..712b4f859 100644
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
diff --git a/include/grub/efi/api.h b/include/grub/efi/api.h
|
diff --git a/include/grub/efi/api.h b/include/grub/efi/api.h
|
||||||
index 1250d493e..2f164d420 100644
|
index 7614b58dca..91ab528e4d 100644
|
||||||
--- a/include/grub/efi/api.h
|
--- a/include/grub/efi/api.h
|
||||||
+++ b/include/grub/efi/api.h
|
+++ b/include/grub/efi/api.h
|
||||||
@@ -1499,31 +1499,6 @@ typedef union
|
@@ -1524,31 +1524,6 @@ typedef union
|
||||||
grub_efi_pxe_dhcpv6_packet_t dhcpv6;
|
grub_efi_pxe_dhcpv6_packet_t dhcpv6;
|
||||||
} grub_efi_pxe_packet_t;
|
} grub_efi_pxe_packet_t;
|
||||||
|
|
||||||
@ -63,7 +63,7 @@ index 1250d493e..2f164d420 100644
|
|||||||
typedef struct grub_efi_pxe_icmp_error
|
typedef struct grub_efi_pxe_icmp_error
|
||||||
{
|
{
|
||||||
grub_efi_uint8_t type;
|
grub_efi_uint8_t type;
|
||||||
@@ -1549,6 +1524,48 @@ typedef struct grub_efi_pxe_tftp_error
|
@@ -1574,6 +1549,48 @@ typedef struct grub_efi_pxe_tftp_error
|
||||||
grub_efi_char8_t error_string[127];
|
grub_efi_char8_t error_string[127];
|
||||||
} grub_efi_pxe_tftp_error_t;
|
} grub_efi_pxe_tftp_error_t;
|
||||||
|
|
||||||
@ -112,7 +112,7 @@ index 1250d493e..2f164d420 100644
|
|||||||
typedef struct grub_efi_pxe_mode
|
typedef struct grub_efi_pxe_mode
|
||||||
{
|
{
|
||||||
grub_efi_boolean_t started;
|
grub_efi_boolean_t started;
|
||||||
@@ -1580,9 +1597,9 @@ typedef struct grub_efi_pxe_mode
|
@@ -1605,9 +1622,9 @@ typedef struct grub_efi_pxe_mode
|
||||||
grub_efi_pxe_packet_t pxe_bis_reply;
|
grub_efi_pxe_packet_t pxe_bis_reply;
|
||||||
grub_efi_pxe_ip_filter_t ip_filter;
|
grub_efi_pxe_ip_filter_t ip_filter;
|
||||||
grub_efi_uint32_t arp_cache_entries;
|
grub_efi_uint32_t arp_cache_entries;
|
@ -12,18 +12,18 @@ Signed-off-by: Ken Lin <ken.lin@hpe.com>
|
|||||||
1 file changed, 17 insertions(+)
|
1 file changed, 17 insertions(+)
|
||||||
|
|
||||||
diff --git a/docs/grub.texi b/docs/grub.texi
|
diff --git a/docs/grub.texi b/docs/grub.texi
|
||||||
index 2b7b7faf8..c54bee316 100644
|
index 0615d0ed97..04ed6ac1f0 100644
|
||||||
--- a/docs/grub.texi
|
--- a/docs/grub.texi
|
||||||
+++ b/docs/grub.texi
|
+++ b/docs/grub.texi
|
||||||
@@ -5303,6 +5303,7 @@ This command is only available on AArch64 systems.
|
@@ -5487,6 +5487,7 @@ This command is only available on AArch64 systems.
|
||||||
* net_add_dns:: Add a DNS server
|
* net_add_dns:: Add a DNS server
|
||||||
* net_add_route:: Add routing entry
|
* net_add_route:: Add routing entry
|
||||||
* net_bootp:: Perform a bootp autoconfiguration
|
* net_bootp:: Perform a bootp/DHCP autoconfiguration
|
||||||
+* net_bootp6:: Perform a DHCPv6 autoconfiguration
|
+* net_bootp6:: Perform a DHCPv6 autoconfiguration
|
||||||
* net_del_addr:: Remove IP address from interface
|
* net_del_addr:: Remove IP address from interface
|
||||||
* net_del_dns:: Remove a DNS server
|
* net_del_dns:: Remove a DNS server
|
||||||
* net_del_route:: Remove a route entry
|
* net_del_route:: Remove a route entry
|
||||||
@@ -5384,6 +5385,22 @@ Sets environment variable @samp{net_}@var{<card>}@samp{_dhcp_extensionspath}
|
@@ -5611,6 +5612,22 @@ Sets environment variable @samp{net_}@var{<card>}@samp{_boot_file}
|
||||||
|
|
||||||
@end deffn
|
@end deffn
|
||||||
|
|
||||||
@ -44,5 +44,5 @@ index 2b7b7faf8..c54bee316 100644
|
|||||||
+
|
+
|
||||||
+@end deffn
|
+@end deffn
|
||||||
|
|
||||||
@node net_del_addr
|
@node net_get_dhcp_option
|
||||||
@subsection net_del_addr
|
@subsection net_get_dhcp_option
|
108
0075-bootp-Add-processing-DHCPACK-packet-from-HTTP-Boot.patch
Normal file
108
0075-bootp-Add-processing-DHCPACK-packet-from-HTTP-Boot.patch
Normal file
@ -0,0 +1,108 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Michael Chang <mchang@suse.com>
|
||||||
|
Date: Wed, 10 Jul 2019 23:58:28 +0200
|
||||||
|
Subject: [PATCH] bootp: Add processing DHCPACK packet from HTTP Boot
|
||||||
|
|
||||||
|
The vendor class identifier with the string "HTTPClient" is used to denote the
|
||||||
|
packet as responding to HTTP boot request. In DHCP4 config, the filename for
|
||||||
|
HTTP boot is the URL of the boot file while for PXE boot it is the path to the
|
||||||
|
boot file. As a consequence, the next-server becomes obseleted because the HTTP
|
||||||
|
URL already contains the server address for the boot file. For DHCP6 config,
|
||||||
|
there's no difference definition in existing config as dhcp6.bootfile-url can
|
||||||
|
be used to specify URL for both HTTP and PXE boot file.
|
||||||
|
|
||||||
|
This patch adds processing for "HTTPClient" vendor class identifier in DHCPACK
|
||||||
|
packet by treating it as HTTP format, not as the PXE format.
|
||||||
|
|
||||||
|
Signed-off-by: Michael Chang <mchang@suse.com>
|
||||||
|
Signed-off-by: Ken Lin <ken.lin@hpe.com>
|
||||||
|
---
|
||||||
|
grub-core/net/bootp.c | 55 +++++++++++++++++++++++++++++++++++++++++++++++++++
|
||||||
|
include/grub/net.h | 1 +
|
||||||
|
2 files changed, 56 insertions(+)
|
||||||
|
|
||||||
|
diff --git a/grub-core/net/bootp.c b/grub-core/net/bootp.c
|
||||||
|
index fe93b80f1c..8fb8918ae7 100644
|
||||||
|
--- a/grub-core/net/bootp.c
|
||||||
|
+++ b/grub-core/net/bootp.c
|
||||||
|
@@ -20,6 +20,7 @@
|
||||||
|
#include <grub/env.h>
|
||||||
|
#include <grub/i18n.h>
|
||||||
|
#include <grub/command.h>
|
||||||
|
+#include <grub/net.h>
|
||||||
|
#include <grub/net/ip.h>
|
||||||
|
#include <grub/net/netbuff.h>
|
||||||
|
#include <grub/net/udp.h>
|
||||||
|
@@ -500,6 +501,60 @@ grub_net_configure_by_dhcp_ack (const char *name,
|
||||||
|
if (opt && opt_len)
|
||||||
|
grub_env_set_net_property (name, "rootpath", (const char *) opt, opt_len);
|
||||||
|
|
||||||
|
+ opt = find_dhcp_option (bp, size, GRUB_NET_BOOTP_VENDOR_CLASS_IDENTIFIER, &opt_len);
|
||||||
|
+ if (opt && opt_len)
|
||||||
|
+ {
|
||||||
|
+ grub_env_set_net_property (name, "vendor_class_identifier", (const char *) opt, opt_len);
|
||||||
|
+ if (opt && grub_strcmp (opt, "HTTPClient") == 0)
|
||||||
|
+ {
|
||||||
|
+ char *proto, *ip, *pa;
|
||||||
|
+
|
||||||
|
+ if (!dissect_url (bp->boot_file, &proto, &ip, &pa))
|
||||||
|
+ return inter;
|
||||||
|
+
|
||||||
|
+ grub_env_set_net_property (name, "boot_file", pa, grub_strlen (pa));
|
||||||
|
+ if (is_def)
|
||||||
|
+ {
|
||||||
|
+ grub_net_default_server = grub_strdup (ip);
|
||||||
|
+ grub_env_set ("net_default_interface", name);
|
||||||
|
+ grub_env_export ("net_default_interface");
|
||||||
|
+ }
|
||||||
|
+ if (device && !*device)
|
||||||
|
+ {
|
||||||
|
+ *device = grub_xasprintf ("%s,%s", proto, ip);
|
||||||
|
+ grub_print_error ();
|
||||||
|
+ }
|
||||||
|
+ if (path)
|
||||||
|
+ {
|
||||||
|
+ *path = grub_strdup (pa);
|
||||||
|
+ grub_print_error ();
|
||||||
|
+ if (*path)
|
||||||
|
+ {
|
||||||
|
+ char *slash;
|
||||||
|
+ slash = grub_strrchr (*path, '/');
|
||||||
|
+ if (slash)
|
||||||
|
+ *slash = 0;
|
||||||
|
+ else
|
||||||
|
+ **path = 0;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ grub_net_add_ipv4_local (inter, mask);
|
||||||
|
+ inter->dhcp_ack = grub_malloc (size);
|
||||||
|
+ if (inter->dhcp_ack)
|
||||||
|
+ {
|
||||||
|
+ grub_memcpy (inter->dhcp_ack, bp, size);
|
||||||
|
+ inter->dhcp_acklen = size;
|
||||||
|
+ }
|
||||||
|
+ else
|
||||||
|
+ grub_errno = GRUB_ERR_NONE;
|
||||||
|
+
|
||||||
|
+ grub_free (proto);
|
||||||
|
+ grub_free (ip);
|
||||||
|
+ grub_free (pa);
|
||||||
|
+ return inter;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
opt = find_dhcp_option (bp, size, GRUB_NET_BOOTP_EXTENSIONS_PATH, &opt_len);
|
||||||
|
if (opt && opt_len)
|
||||||
|
grub_env_set_net_property (name, "extensionspath", (const char *) opt, opt_len);
|
||||||
|
diff --git a/include/grub/net.h b/include/grub/net.h
|
||||||
|
index 543251f727..42af7de250 100644
|
||||||
|
--- a/include/grub/net.h
|
||||||
|
+++ b/include/grub/net.h
|
||||||
|
@@ -531,6 +531,7 @@ enum
|
||||||
|
GRUB_NET_DHCP_MESSAGE_TYPE = 53,
|
||||||
|
GRUB_NET_DHCP_SERVER_IDENTIFIER = 54,
|
||||||
|
GRUB_NET_DHCP_PARAMETER_REQUEST_LIST = 55,
|
||||||
|
+ GRUB_NET_BOOTP_VENDOR_CLASS_IDENTIFIER = 60,
|
||||||
|
GRUB_NET_BOOTP_CLIENT_ID = 61,
|
||||||
|
GRUB_NET_DHCP_TFTP_SERVER_NAME = 66,
|
||||||
|
GRUB_NET_DHCP_BOOTFILE_NAME = 67,
|
@ -32,10 +32,10 @@ Signed-off-by: Ken Lin <ken.lin@hpe.com>
|
|||||||
2 files changed, 280 insertions(+), 15 deletions(-)
|
2 files changed, 280 insertions(+), 15 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/net/drivers/efi/efinet.c b/grub-core/net/drivers/efi/efinet.c
|
diff --git a/grub-core/net/drivers/efi/efinet.c b/grub-core/net/drivers/efi/efinet.c
|
||||||
index 712b4f859..3e51e1064 100644
|
index 014e5bf980..8171ecaa5e 100644
|
||||||
--- a/grub-core/net/drivers/efi/efinet.c
|
--- a/grub-core/net/drivers/efi/efinet.c
|
||||||
+++ b/grub-core/net/drivers/efi/efinet.c
|
+++ b/grub-core/net/drivers/efi/efinet.c
|
||||||
@@ -27,6 +27,7 @@
|
@@ -26,6 +26,7 @@
|
||||||
#include <grub/i18n.h>
|
#include <grub/i18n.h>
|
||||||
#include <grub/lib/hexdump.h>
|
#include <grub/lib/hexdump.h>
|
||||||
#include <grub/types.h>
|
#include <grub/types.h>
|
||||||
@ -43,7 +43,7 @@ index 712b4f859..3e51e1064 100644
|
|||||||
|
|
||||||
GRUB_MOD_LICENSE ("GPLv3+");
|
GRUB_MOD_LICENSE ("GPLv3+");
|
||||||
|
|
||||||
@@ -332,6 +333,227 @@ grub_efinet_findcards (void)
|
@@ -331,6 +332,227 @@ grub_efinet_findcards (void)
|
||||||
grub_free (handles);
|
grub_free (handles);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -271,7 +271,7 @@ index 712b4f859..3e51e1064 100644
|
|||||||
static void
|
static void
|
||||||
grub_efi_net_config_real (grub_efi_handle_t hnd, char **device,
|
grub_efi_net_config_real (grub_efi_handle_t hnd, char **device,
|
||||||
char **path)
|
char **path)
|
||||||
@@ -347,7 +569,11 @@ grub_efi_net_config_real (grub_efi_handle_t hnd, char **device,
|
@@ -346,7 +568,11 @@ grub_efi_net_config_real (grub_efi_handle_t hnd, char **device,
|
||||||
{
|
{
|
||||||
grub_efi_device_path_t *cdp;
|
grub_efi_device_path_t *cdp;
|
||||||
struct grub_efi_pxe *pxe;
|
struct grub_efi_pxe *pxe;
|
||||||
@ -375,10 +375,10 @@ index 712b4f859..3e51e1064 100644
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
diff --git a/include/grub/efi/api.h b/include/grub/efi/api.h
|
diff --git a/include/grub/efi/api.h b/include/grub/efi/api.h
|
||||||
index 2f164d420..eb6bb5085 100644
|
index 91ab528e4d..4a51667adb 100644
|
||||||
--- a/include/grub/efi/api.h
|
--- a/include/grub/efi/api.h
|
||||||
+++ b/include/grub/efi/api.h
|
+++ b/include/grub/efi/api.h
|
||||||
@@ -839,6 +839,8 @@ struct grub_efi_ipv4_device_path
|
@@ -864,6 +864,8 @@ struct grub_efi_ipv4_device_path
|
||||||
grub_efi_uint16_t remote_port;
|
grub_efi_uint16_t remote_port;
|
||||||
grub_efi_uint16_t protocol;
|
grub_efi_uint16_t protocol;
|
||||||
grub_efi_uint8_t static_ip_address;
|
grub_efi_uint8_t static_ip_address;
|
||||||
@ -387,7 +387,7 @@ index 2f164d420..eb6bb5085 100644
|
|||||||
} GRUB_PACKED;
|
} GRUB_PACKED;
|
||||||
typedef struct grub_efi_ipv4_device_path grub_efi_ipv4_device_path_t;
|
typedef struct grub_efi_ipv4_device_path grub_efi_ipv4_device_path_t;
|
||||||
|
|
||||||
@@ -893,6 +895,15 @@ struct grub_efi_sata_device_path
|
@@ -918,6 +920,15 @@ struct grub_efi_sata_device_path
|
||||||
} GRUB_PACKED;
|
} GRUB_PACKED;
|
||||||
typedef struct grub_efi_sata_device_path grub_efi_sata_device_path_t;
|
typedef struct grub_efi_sata_device_path grub_efi_sata_device_path_t;
|
||||||
|
|
@ -29,14 +29,14 @@ Signed-off-by: Michael Chang <mchang@suse.com>
|
|||||||
Signed-off-by: Ken Lin <ken.lin@hpe.com>
|
Signed-off-by: Ken Lin <ken.lin@hpe.com>
|
||||||
---
|
---
|
||||||
grub-core/net/drivers/efi/efinet.c | 163 +++++++++++++++++++++++++++++++++++++
|
grub-core/net/drivers/efi/efinet.c | 163 +++++++++++++++++++++++++++++++++++++
|
||||||
include/grub/efi/api.h | 76 +++++++++++++++++
|
include/grub/efi/api.h | 75 +++++++++++++++++
|
||||||
2 files changed, 239 insertions(+)
|
2 files changed, 238 insertions(+)
|
||||||
|
|
||||||
diff --git a/grub-core/net/drivers/efi/efinet.c b/grub-core/net/drivers/efi/efinet.c
|
diff --git a/grub-core/net/drivers/efi/efinet.c b/grub-core/net/drivers/efi/efinet.c
|
||||||
index 3e51e1064..3d7750747 100644
|
index 8171ecaa5e..715a6168d7 100644
|
||||||
--- a/grub-core/net/drivers/efi/efinet.c
|
--- a/grub-core/net/drivers/efi/efinet.c
|
||||||
+++ b/grub-core/net/drivers/efi/efinet.c
|
+++ b/grub-core/net/drivers/efi/efinet.c
|
||||||
@@ -34,6 +34,8 @@ GRUB_MOD_LICENSE ("GPLv3+");
|
@@ -33,6 +33,8 @@ GRUB_MOD_LICENSE ("GPLv3+");
|
||||||
/* GUID. */
|
/* GUID. */
|
||||||
static grub_efi_guid_t net_io_guid = GRUB_EFI_SIMPLE_NETWORK_GUID;
|
static grub_efi_guid_t net_io_guid = GRUB_EFI_SIMPLE_NETWORK_GUID;
|
||||||
static grub_efi_guid_t pxe_io_guid = GRUB_EFI_PXE_GUID;
|
static grub_efi_guid_t pxe_io_guid = GRUB_EFI_PXE_GUID;
|
||||||
@ -45,7 +45,7 @@ index 3e51e1064..3d7750747 100644
|
|||||||
|
|
||||||
static grub_err_t
|
static grub_err_t
|
||||||
send_card_buffer (struct grub_net_card *dev,
|
send_card_buffer (struct grub_net_card *dev,
|
||||||
@@ -333,6 +335,125 @@ grub_efinet_findcards (void)
|
@@ -332,6 +334,125 @@ grub_efinet_findcards (void)
|
||||||
grub_free (handles);
|
grub_free (handles);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -171,7 +171,7 @@ index 3e51e1064..3d7750747 100644
|
|||||||
static struct grub_net_buff *
|
static struct grub_net_buff *
|
||||||
grub_efinet_create_dhcp_ack_from_device_path (grub_efi_device_path_t *dp, int *use_ipv6)
|
grub_efinet_create_dhcp_ack_from_device_path (grub_efi_device_path_t *dp, int *use_ipv6)
|
||||||
{
|
{
|
||||||
@@ -391,6 +512,8 @@ grub_efinet_create_dhcp_ack_from_device_path (grub_efi_device_path_t *dp, int *u
|
@@ -390,6 +511,8 @@ grub_efinet_create_dhcp_ack_from_device_path (grub_efi_device_path_t *dp, int *u
|
||||||
grub_efi_ipv4_device_path_t *ipv4 = (grub_efi_ipv4_device_path_t *) ldp;
|
grub_efi_ipv4_device_path_t *ipv4 = (grub_efi_ipv4_device_path_t *) ldp;
|
||||||
struct grub_net_bootp_packet *bp;
|
struct grub_net_bootp_packet *bp;
|
||||||
grub_uint8_t *ptr;
|
grub_uint8_t *ptr;
|
||||||
@ -180,7 +180,7 @@ index 3e51e1064..3d7750747 100644
|
|||||||
|
|
||||||
bp = (struct grub_net_bootp_packet *) nb->tail;
|
bp = (struct grub_net_bootp_packet *) nb->tail;
|
||||||
err = grub_netbuff_put (nb, sizeof (*bp) + 4);
|
err = grub_netbuff_put (nb, sizeof (*bp) + 4);
|
||||||
@@ -452,6 +575,25 @@ grub_efinet_create_dhcp_ack_from_device_path (grub_efi_device_path_t *dp, int *u
|
@@ -451,6 +574,25 @@ grub_efinet_create_dhcp_ack_from_device_path (grub_efi_device_path_t *dp, int *u
|
||||||
*ptr++ = sizeof ("HTTPClient") - 1;
|
*ptr++ = sizeof ("HTTPClient") - 1;
|
||||||
grub_memcpy (ptr, "HTTPClient", sizeof ("HTTPClient") - 1);
|
grub_memcpy (ptr, "HTTPClient", sizeof ("HTTPClient") - 1);
|
||||||
|
|
||||||
@ -206,7 +206,7 @@ index 3e51e1064..3d7750747 100644
|
|||||||
ptr = nb->tail;
|
ptr = nb->tail;
|
||||||
err = grub_netbuff_put (nb, 1);
|
err = grub_netbuff_put (nb, 1);
|
||||||
if (err)
|
if (err)
|
||||||
@@ -484,6 +626,8 @@ grub_efinet_create_dhcp_ack_from_device_path (grub_efi_device_path_t *dp, int *u
|
@@ -483,6 +625,8 @@ grub_efinet_create_dhcp_ack_from_device_path (grub_efi_device_path_t *dp, int *u
|
||||||
struct grub_net_dhcp6_option *opt;
|
struct grub_net_dhcp6_option *opt;
|
||||||
struct grub_net_dhcp6_option_iana *iana;
|
struct grub_net_dhcp6_option_iana *iana;
|
||||||
struct grub_net_dhcp6_option_iaaddr *iaaddr;
|
struct grub_net_dhcp6_option_iaaddr *iaaddr;
|
||||||
@ -215,7 +215,7 @@ index 3e51e1064..3d7750747 100644
|
|||||||
|
|
||||||
d6p = (struct grub_net_dhcp6_packet *)nb->tail;
|
d6p = (struct grub_net_dhcp6_packet *)nb->tail;
|
||||||
err = grub_netbuff_put (nb, sizeof(*d6p));
|
err = grub_netbuff_put (nb, sizeof(*d6p));
|
||||||
@@ -547,6 +691,25 @@ grub_efinet_create_dhcp_ack_from_device_path (grub_efi_device_path_t *dp, int *u
|
@@ -546,6 +690,25 @@ grub_efinet_create_dhcp_ack_from_device_path (grub_efi_device_path_t *dp, int *u
|
||||||
opt->len = grub_cpu_to_be16 (uri_len);
|
opt->len = grub_cpu_to_be16 (uri_len);
|
||||||
grub_memcpy (opt->data, uri_dp->uri, uri_len);
|
grub_memcpy (opt->data, uri_dp->uri, uri_len);
|
||||||
|
|
||||||
@ -242,13 +242,14 @@ index 3e51e1064..3d7750747 100644
|
|||||||
}
|
}
|
||||||
|
|
||||||
diff --git a/include/grub/efi/api.h b/include/grub/efi/api.h
|
diff --git a/include/grub/efi/api.h b/include/grub/efi/api.h
|
||||||
index eb6bb5085..dd3b07eac 100644
|
index 4a51667adb..0b490195ad 100644
|
||||||
--- a/include/grub/efi/api.h
|
--- a/include/grub/efi/api.h
|
||||||
+++ b/include/grub/efi/api.h
|
+++ b/include/grub/efi/api.h
|
||||||
@@ -334,6 +334,16 @@
|
@@ -352,6 +352,15 @@
|
||||||
{ 0x8B, 0x8C, 0xE2, 0x1B, 0x01, 0xAE, 0xF2, 0xB7 } \
|
#define GRUB_EFI_RNG_PROTOCOL_GUID \
|
||||||
}
|
{ 0x3152bca5, 0xeade, 0x433d, \
|
||||||
|
{ 0x86, 0x2e, 0xc0, 0x1c, 0xdc, 0x29, 0x1f, 0x44 } \
|
||||||
|
+
|
||||||
+#define GRUB_EFI_IP4_CONFIG2_PROTOCOL_GUID \
|
+#define GRUB_EFI_IP4_CONFIG2_PROTOCOL_GUID \
|
||||||
+ { 0x5b446ed1, 0xe30b, 0x4faa, \
|
+ { 0x5b446ed1, 0xe30b, 0x4faa, \
|
||||||
+ { 0x87, 0x1a, 0x36, 0x54, 0xec, 0xa3, 0x60, 0x80 } \
|
+ { 0x87, 0x1a, 0x36, 0x54, 0xec, 0xa3, 0x60, 0x80 } \
|
||||||
@ -257,14 +258,12 @@ index eb6bb5085..dd3b07eac 100644
|
|||||||
+#define GRUB_EFI_IP6_CONFIG_PROTOCOL_GUID \
|
+#define GRUB_EFI_IP6_CONFIG_PROTOCOL_GUID \
|
||||||
+ { 0x937fe521, 0x95ae, 0x4d1a, \
|
+ { 0x937fe521, 0x95ae, 0x4d1a, \
|
||||||
+ { 0x89, 0x29, 0x48, 0xbc, 0xd9, 0x0a, 0xd3, 0x1a } \
|
+ { 0x89, 0x29, 0x48, 0xbc, 0xd9, 0x0a, 0xd3, 0x1a } \
|
||||||
+ }
|
}
|
||||||
+
|
|
||||||
struct grub_efi_sal_system_table
|
struct grub_efi_sal_system_table
|
||||||
{
|
@@ -1883,6 +1892,72 @@ struct grub_efi_rng_protocol
|
||||||
grub_uint32_t signature;
|
|
||||||
@@ -1838,6 +1848,72 @@ struct grub_efi_block_io
|
|
||||||
};
|
};
|
||||||
typedef struct grub_efi_block_io grub_efi_block_io_t;
|
typedef struct grub_efi_rng_protocol grub_efi_rng_protocol_t;
|
||||||
|
|
||||||
+enum grub_efi_ip4_config2_data_type {
|
+enum grub_efi_ip4_config2_data_type {
|
||||||
+ GRUB_EFI_IP4_CONFIG2_DATA_TYPE_INTERFACEINFO,
|
+ GRUB_EFI_IP4_CONFIG2_DATA_TYPE_INTERFACEINFO,
|
||||||
@ -333,5 +332,5 @@ index eb6bb5085..dd3b07eac 100644
|
|||||||
+typedef struct grub_efi_ip6_config_protocol grub_efi_ip6_config_protocol_t;
|
+typedef struct grub_efi_ip6_config_protocol grub_efi_ip6_config_protocol_t;
|
||||||
+
|
+
|
||||||
#if (GRUB_TARGET_SIZEOF_VOID_P == 4) || defined (__ia64__) \
|
#if (GRUB_TARGET_SIZEOF_VOID_P == 4) || defined (__ia64__) \
|
||||||
|| defined (__aarch64__) || defined (__MINGW64__) || defined (__CYGWIN__)
|
|| defined (__aarch64__) || defined (__MINGW64__) || defined (__CYGWIN__) \
|
||||||
|
|| defined(__riscv)
|
@ -22,8 +22,12 @@ V3:
|
|||||||
* Use HEAD request method to test before GET
|
* Use HEAD request method to test before GET
|
||||||
* Finish HTTP transaction in one go
|
* Finish HTTP transaction in one go
|
||||||
* Fix bsc#1076132
|
* Fix bsc#1076132
|
||||||
|
|
||||||
|
Signed-off-by: Michael Chang <mchang@suse.com>
|
||||||
|
[pjones: make efi_netfs not duplicate symbols from efinet]
|
||||||
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
---
|
---
|
||||||
grub-core/Makefile.core.def | 18 +
|
grub-core/Makefile.core.def | 12 +
|
||||||
grub-core/io/bufio.c | 2 +-
|
grub-core/io/bufio.c | 2 +-
|
||||||
grub-core/kern/efi/efi.c | 96 ++-
|
grub-core/kern/efi/efi.c | 96 ++-
|
||||||
grub-core/net/drivers/efi/efinet.c | 27 +
|
grub-core/net/drivers/efi/efinet.c | 27 +
|
||||||
@ -40,7 +44,7 @@ V3:
|
|||||||
include/grub/efi/dhcp.h | 343 +++++++++
|
include/grub/efi/dhcp.h | 343 +++++++++
|
||||||
include/grub/efi/http.h | 215 ++++++
|
include/grub/efi/http.h | 215 ++++++
|
||||||
include/grub/net/efi.h | 144 ++++
|
include/grub/net/efi.h | 144 ++++
|
||||||
17 files changed, 4626 insertions(+), 41 deletions(-)
|
17 files changed, 4620 insertions(+), 41 deletions(-)
|
||||||
create mode 100644 grub-core/net/efi/dhcp.c
|
create mode 100644 grub-core/net/efi/dhcp.c
|
||||||
create mode 100644 grub-core/net/efi/efi_netfs.c
|
create mode 100644 grub-core/net/efi/efi_netfs.c
|
||||||
create mode 100644 grub-core/net/efi/http.c
|
create mode 100644 grub-core/net/efi/http.c
|
||||||
@ -53,32 +57,26 @@ V3:
|
|||||||
create mode 100644 include/grub/net/efi.h
|
create mode 100644 include/grub/net/efi.h
|
||||||
|
|
||||||
diff --git a/grub-core/Makefile.core.def b/grub-core/Makefile.core.def
|
diff --git a/grub-core/Makefile.core.def b/grub-core/Makefile.core.def
|
||||||
index 420831bc8..2851437e0 100644
|
index 52ec0fafcd..12797336c9 100644
|
||||||
--- a/grub-core/Makefile.core.def
|
--- a/grub-core/Makefile.core.def
|
||||||
+++ b/grub-core/Makefile.core.def
|
+++ b/grub-core/Makefile.core.def
|
||||||
@@ -2181,6 +2181,18 @@ module = {
|
@@ -2300,6 +2300,12 @@ module = {
|
||||||
common = hook/datehook.c;
|
common = hook/datehook.c;
|
||||||
};
|
};
|
||||||
|
|
||||||
+module = {
|
+module = {
|
||||||
+ name = efi_netfs;
|
+ name = efi_netfs;
|
||||||
+ common = net/efi/efi_netfs.c;
|
+ common = net/efi/efi_netfs.c;
|
||||||
+ common = net/efi/net.c;
|
|
||||||
+ common = net/efi/http.c;
|
|
||||||
+ common = net/efi/pxe.c;
|
|
||||||
+ common = net/efi/ip4_config.c;
|
|
||||||
+ common = net/efi/ip6_config.c;
|
|
||||||
+ common = net/efi/dhcp.c;
|
|
||||||
+ enable = efi;
|
+ enable = efi;
|
||||||
+};
|
+};
|
||||||
+
|
+
|
||||||
module = {
|
module = {
|
||||||
name = net;
|
name = net;
|
||||||
common = net/net.c;
|
common = net/net.c;
|
||||||
@@ -2195,6 +2207,12 @@ module = {
|
@@ -2313,6 +2319,12 @@ module = {
|
||||||
|
common = net/ethernet.c;
|
||||||
common = net/arp.c;
|
common = net/arp.c;
|
||||||
common = net/netbuff.c;
|
common = net/netbuff.c;
|
||||||
common = net/url.c;
|
|
||||||
+ efi = net/efi/net.c;
|
+ efi = net/efi/net.c;
|
||||||
+ efi = net/efi/http.c;
|
+ efi = net/efi/http.c;
|
||||||
+ efi = net/efi/pxe.c;
|
+ efi = net/efi/pxe.c;
|
||||||
@ -89,7 +87,7 @@ index 420831bc8..2851437e0 100644
|
|||||||
|
|
||||||
module = {
|
module = {
|
||||||
diff --git a/grub-core/io/bufio.c b/grub-core/io/bufio.c
|
diff --git a/grub-core/io/bufio.c b/grub-core/io/bufio.c
|
||||||
index dbed64744..6118bade5 100644
|
index a458c3aca7..1637731535 100644
|
||||||
--- a/grub-core/io/bufio.c
|
--- a/grub-core/io/bufio.c
|
||||||
+++ b/grub-core/io/bufio.c
|
+++ b/grub-core/io/bufio.c
|
||||||
@@ -139,7 +139,7 @@ grub_bufio_read (grub_file_t file, char *buf, grub_size_t len)
|
@@ -139,7 +139,7 @@ grub_bufio_read (grub_file_t file, char *buf, grub_size_t len)
|
||||||
@ -102,10 +100,10 @@ index dbed64744..6118bade5 100644
|
|||||||
if (file->offset + res < next_buf)
|
if (file->offset + res < next_buf)
|
||||||
{
|
{
|
||||||
diff --git a/grub-core/kern/efi/efi.c b/grub-core/kern/efi/efi.c
|
diff --git a/grub-core/kern/efi/efi.c b/grub-core/kern/efi/efi.c
|
||||||
index a2a732ffc..4d36fe311 100644
|
index d6a2fb5778..2a446f5031 100644
|
||||||
--- a/grub-core/kern/efi/efi.c
|
--- a/grub-core/kern/efi/efi.c
|
||||||
+++ b/grub-core/kern/efi/efi.c
|
+++ b/grub-core/kern/efi/efi.c
|
||||||
@@ -696,7 +696,7 @@ grub_efi_print_device_path (grub_efi_device_path_t *dp)
|
@@ -755,7 +755,7 @@ grub_efi_print_device_path (grub_efi_device_path_t *dp)
|
||||||
{
|
{
|
||||||
grub_efi_ipv4_device_path_t *ipv4
|
grub_efi_ipv4_device_path_t *ipv4
|
||||||
= (grub_efi_ipv4_device_path_t *) dp;
|
= (grub_efi_ipv4_device_path_t *) dp;
|
||||||
@ -114,7 +112,7 @@ index a2a732ffc..4d36fe311 100644
|
|||||||
(unsigned) ipv4->local_ip_address[0],
|
(unsigned) ipv4->local_ip_address[0],
|
||||||
(unsigned) ipv4->local_ip_address[1],
|
(unsigned) ipv4->local_ip_address[1],
|
||||||
(unsigned) ipv4->local_ip_address[2],
|
(unsigned) ipv4->local_ip_address[2],
|
||||||
@@ -709,33 +709,60 @@ grub_efi_print_device_path (grub_efi_device_path_t *dp)
|
@@ -768,33 +768,60 @@ grub_efi_print_device_path (grub_efi_device_path_t *dp)
|
||||||
(unsigned) ipv4->remote_port,
|
(unsigned) ipv4->remote_port,
|
||||||
(unsigned) ipv4->protocol,
|
(unsigned) ipv4->protocol,
|
||||||
(unsigned) ipv4->static_ip_address);
|
(unsigned) ipv4->static_ip_address);
|
||||||
@ -192,7 +190,7 @@ index a2a732ffc..4d36fe311 100644
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case GRUB_EFI_INFINIBAND_DEVICE_PATH_SUBTYPE:
|
case GRUB_EFI_INFINIBAND_DEVICE_PATH_SUBTYPE:
|
||||||
@@ -775,6 +802,39 @@ grub_efi_print_device_path (grub_efi_device_path_t *dp)
|
@@ -834,6 +861,39 @@ grub_efi_print_device_path (grub_efi_device_path_t *dp)
|
||||||
dump_vendor_path ("Messaging",
|
dump_vendor_path ("Messaging",
|
||||||
(grub_efi_vendor_device_path_t *) dp);
|
(grub_efi_vendor_device_path_t *) dp);
|
||||||
break;
|
break;
|
||||||
@ -233,10 +231,10 @@ index a2a732ffc..4d36fe311 100644
|
|||||||
grub_printf ("/UnknownMessaging(%x)", (unsigned) subtype);
|
grub_printf ("/UnknownMessaging(%x)", (unsigned) subtype);
|
||||||
break;
|
break;
|
||||||
diff --git a/grub-core/net/drivers/efi/efinet.c b/grub-core/net/drivers/efi/efinet.c
|
diff --git a/grub-core/net/drivers/efi/efinet.c b/grub-core/net/drivers/efi/efinet.c
|
||||||
index 3d7750747..df7760ad2 100644
|
index 715a6168d7..e11d759f19 100644
|
||||||
--- a/grub-core/net/drivers/efi/efinet.c
|
--- a/grub-core/net/drivers/efi/efinet.c
|
||||||
+++ b/grub-core/net/drivers/efi/efinet.c
|
+++ b/grub-core/net/drivers/efi/efinet.c
|
||||||
@@ -28,6 +28,7 @@
|
@@ -27,6 +27,7 @@
|
||||||
#include <grub/lib/hexdump.h>
|
#include <grub/lib/hexdump.h>
|
||||||
#include <grub/types.h>
|
#include <grub/types.h>
|
||||||
#include <grub/net/netbuff.h>
|
#include <grub/net/netbuff.h>
|
||||||
@ -244,7 +242,7 @@ index 3d7750747..df7760ad2 100644
|
|||||||
|
|
||||||
GRUB_MOD_LICENSE ("GPLv3+");
|
GRUB_MOD_LICENSE ("GPLv3+");
|
||||||
|
|
||||||
@@ -492,6 +493,17 @@ grub_efinet_create_dhcp_ack_from_device_path (grub_efi_device_path_t *dp, int *u
|
@@ -491,6 +492,17 @@ grub_efinet_create_dhcp_ack_from_device_path (grub_efi_device_path_t *dp, int *u
|
||||||
|
|
||||||
ldp = grub_efi_find_last_device_path (ddp);
|
ldp = grub_efi_find_last_device_path (ddp);
|
||||||
|
|
||||||
@ -306,7 +304,7 @@ index 3d7750747..df7760ad2 100644
|
|||||||
|
|
||||||
diff --git a/grub-core/net/efi/dhcp.c b/grub-core/net/efi/dhcp.c
|
diff --git a/grub-core/net/efi/dhcp.c b/grub-core/net/efi/dhcp.c
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..dbef63d8c
|
index 0000000000..dbef63d8c0
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/grub-core/net/efi/dhcp.c
|
+++ b/grub-core/net/efi/dhcp.c
|
||||||
@@ -0,0 +1,397 @@
|
@@ -0,0 +1,397 @@
|
||||||
@ -709,7 +707,7 @@ index 000000000..dbef63d8c
|
|||||||
+grub_command_func_t grub_efi_net_bootp6 = grub_cmd_efi_bootp6;
|
+grub_command_func_t grub_efi_net_bootp6 = grub_cmd_efi_bootp6;
|
||||||
diff --git a/grub-core/net/efi/efi_netfs.c b/grub-core/net/efi/efi_netfs.c
|
diff --git a/grub-core/net/efi/efi_netfs.c b/grub-core/net/efi/efi_netfs.c
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..ef371d885
|
index 0000000000..ef371d885e
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/grub-core/net/efi/efi_netfs.c
|
+++ b/grub-core/net/efi/efi_netfs.c
|
||||||
@@ -0,0 +1,57 @@
|
@@ -0,0 +1,57 @@
|
||||||
@ -772,7 +770,7 @@ index 000000000..ef371d885
|
|||||||
+}
|
+}
|
||||||
diff --git a/grub-core/net/efi/http.c b/grub-core/net/efi/http.c
|
diff --git a/grub-core/net/efi/http.c b/grub-core/net/efi/http.c
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..3f61fd2fa
|
index 0000000000..3f61fd2fa5
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/grub-core/net/efi/http.c
|
+++ b/grub-core/net/efi/http.c
|
||||||
@@ -0,0 +1,419 @@
|
@@ -0,0 +1,419 @@
|
||||||
@ -1197,7 +1195,7 @@ index 000000000..3f61fd2fa
|
|||||||
+ };
|
+ };
|
||||||
diff --git a/grub-core/net/efi/ip4_config.c b/grub-core/net/efi/ip4_config.c
|
diff --git a/grub-core/net/efi/ip4_config.c b/grub-core/net/efi/ip4_config.c
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..b711a5d94
|
index 0000000000..b711a5d945
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/grub-core/net/efi/ip4_config.c
|
+++ b/grub-core/net/efi/ip4_config.c
|
||||||
@@ -0,0 +1,398 @@
|
@@ -0,0 +1,398 @@
|
||||||
@ -1601,7 +1599,7 @@ index 000000000..b711a5d94
|
|||||||
+ };
|
+ };
|
||||||
diff --git a/grub-core/net/efi/ip6_config.c b/grub-core/net/efi/ip6_config.c
|
diff --git a/grub-core/net/efi/ip6_config.c b/grub-core/net/efi/ip6_config.c
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..017c4d05b
|
index 0000000000..017c4d05bc
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/grub-core/net/efi/ip6_config.c
|
+++ b/grub-core/net/efi/ip6_config.c
|
||||||
@@ -0,0 +1,422 @@
|
@@ -0,0 +1,422 @@
|
||||||
@ -2029,7 +2027,7 @@ index 000000000..017c4d05b
|
|||||||
+ };
|
+ };
|
||||||
diff --git a/grub-core/net/efi/net.c b/grub-core/net/efi/net.c
|
diff --git a/grub-core/net/efi/net.c b/grub-core/net/efi/net.c
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..9e0078ac1
|
index 0000000000..86bce6535d
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/grub-core/net/efi/net.c
|
+++ b/grub-core/net/efi/net.c
|
||||||
@@ -0,0 +1,1428 @@
|
@@ -0,0 +1,1428 @@
|
||||||
@ -3326,13 +3324,13 @@ index 000000000..9e0078ac1
|
|||||||
+static struct grub_fs grub_efi_netfs =
|
+static struct grub_fs grub_efi_netfs =
|
||||||
+ {
|
+ {
|
||||||
+ .name = "efi netfs",
|
+ .name = "efi netfs",
|
||||||
+ .dir = grub_efi_netfs_dir,
|
+ .fs_dir = grub_efi_netfs_dir,
|
||||||
+ .open = grub_efi_netfs_open,
|
+ .fs_open = grub_efi_netfs_open,
|
||||||
+ .read = grub_efi_netfs_read,
|
+ .fs_read = grub_efi_netfs_read,
|
||||||
+ .close = grub_efi_netfs_close,
|
+ .fs_close = grub_efi_netfs_close,
|
||||||
+ .label = NULL,
|
+ .fs_label = NULL,
|
||||||
+ .uuid = NULL,
|
+ .fs_uuid = NULL,
|
||||||
+ .mtime = NULL,
|
+ .fs_mtime = NULL,
|
||||||
+ };
|
+ };
|
||||||
+
|
+
|
||||||
+int
|
+int
|
||||||
@ -3463,7 +3461,7 @@ index 000000000..9e0078ac1
|
|||||||
+}
|
+}
|
||||||
diff --git a/grub-core/net/efi/pxe.c b/grub-core/net/efi/pxe.c
|
diff --git a/grub-core/net/efi/pxe.c b/grub-core/net/efi/pxe.c
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..531949cba
|
index 0000000000..531949cba5
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/grub-core/net/efi/pxe.c
|
+++ b/grub-core/net/efi/pxe.c
|
||||||
@@ -0,0 +1,424 @@
|
@@ -0,0 +1,424 @@
|
||||||
@ -3892,7 +3890,7 @@ index 000000000..531949cba
|
|||||||
+ };
|
+ };
|
||||||
+
|
+
|
||||||
diff --git a/grub-core/net/net.c b/grub-core/net/net.c
|
diff --git a/grub-core/net/net.c b/grub-core/net/net.c
|
||||||
index 191e8e41b..a571ee92e 100644
|
index 0ce5e675ed..55aed92722 100644
|
||||||
--- a/grub-core/net/net.c
|
--- a/grub-core/net/net.c
|
||||||
+++ b/grub-core/net/net.c
|
+++ b/grub-core/net/net.c
|
||||||
@@ -32,6 +32,9 @@
|
@@ -32,6 +32,9 @@
|
||||||
@ -3905,7 +3903,7 @@ index 191e8e41b..a571ee92e 100644
|
|||||||
|
|
||||||
GRUB_MOD_LICENSE ("GPLv3+");
|
GRUB_MOD_LICENSE ("GPLv3+");
|
||||||
|
|
||||||
@@ -2025,8 +2028,49 @@ static grub_command_t cmd_addaddr, cmd_deladdr, cmd_addroute, cmd_delroute;
|
@@ -2033,8 +2036,49 @@ static grub_command_t cmd_addaddr, cmd_deladdr, cmd_addroute, cmd_delroute;
|
||||||
static grub_command_t cmd_lsroutes, cmd_lscards;
|
static grub_command_t cmd_lsroutes, cmd_lscards;
|
||||||
static grub_command_t cmd_lsaddr, cmd_slaac;
|
static grub_command_t cmd_lsaddr, cmd_slaac;
|
||||||
|
|
||||||
@ -3955,7 +3953,7 @@ index 191e8e41b..a571ee92e 100644
|
|||||||
grub_register_variable_hook ("net_default_server", defserver_get_env,
|
grub_register_variable_hook ("net_default_server", defserver_get_env,
|
||||||
defserver_set_env);
|
defserver_set_env);
|
||||||
grub_env_export ("net_default_server");
|
grub_env_export ("net_default_server");
|
||||||
@@ -2074,10 +2118,37 @@ GRUB_MOD_INIT(net)
|
@@ -2082,10 +2126,37 @@ GRUB_MOD_INIT(net)
|
||||||
grub_net_restore_hw,
|
grub_net_restore_hw,
|
||||||
GRUB_LOADER_PREBOOT_HOOK_PRIO_DISK);
|
GRUB_LOADER_PREBOOT_HOOK_PRIO_DISK);
|
||||||
grub_net_poll_cards_idle = grub_net_poll_cards_idle_real;
|
grub_net_poll_cards_idle = grub_net_poll_cards_idle_real;
|
||||||
@ -3993,7 +3991,7 @@ index 191e8e41b..a571ee92e 100644
|
|||||||
grub_register_variable_hook ("net_default_server", 0, 0);
|
grub_register_variable_hook ("net_default_server", 0, 0);
|
||||||
grub_register_variable_hook ("pxe_default_server", 0, 0);
|
grub_register_variable_hook ("pxe_default_server", 0, 0);
|
||||||
|
|
||||||
@@ -2096,4 +2167,7 @@ GRUB_MOD_FINI(net)
|
@@ -2104,4 +2175,7 @@ GRUB_MOD_FINI(net)
|
||||||
grub_net_fini_hw (0);
|
grub_net_fini_hw (0);
|
||||||
grub_loader_unregister_preboot_hook (fini_hnd);
|
grub_loader_unregister_preboot_hook (fini_hnd);
|
||||||
grub_net_poll_cards_idle = grub_net_poll_cards_idle_real;
|
grub_net_poll_cards_idle = grub_net_poll_cards_idle_real;
|
||||||
@ -4002,7 +4000,7 @@ index 191e8e41b..a571ee92e 100644
|
|||||||
+#endif
|
+#endif
|
||||||
}
|
}
|
||||||
diff --git a/util/grub-mknetdir.c b/util/grub-mknetdir.c
|
diff --git a/util/grub-mknetdir.c b/util/grub-mknetdir.c
|
||||||
index 82073d5cc..ae31271bb 100644
|
index a2461cda1c..77958dd9dd 100644
|
||||||
--- a/util/grub-mknetdir.c
|
--- a/util/grub-mknetdir.c
|
||||||
+++ b/util/grub-mknetdir.c
|
+++ b/util/grub-mknetdir.c
|
||||||
@@ -32,13 +32,15 @@
|
@@ -32,13 +32,15 @@
|
||||||
@ -4057,7 +4055,7 @@ index 82073d5cc..ae31271bb 100644
|
|||||||
{
|
{
|
||||||
const char *mkimage_target;
|
const char *mkimage_target;
|
||||||
const char *netmodule;
|
const char *netmodule;
|
||||||
@@ -154,6 +159,7 @@ process_input_dir (const char *input_dir, enum grub_install_plat platform)
|
@@ -156,6 +161,7 @@ process_input_dir (const char *input_dir, enum grub_install_plat platform)
|
||||||
grub_install_push_module (targets[platform].netmodule);
|
grub_install_push_module (targets[platform].netmodule);
|
||||||
|
|
||||||
output = grub_util_path_concat_ext (2, grubdir, "core", targets[platform].ext);
|
output = grub_util_path_concat_ext (2, grubdir, "core", targets[platform].ext);
|
||||||
@ -4065,7 +4063,7 @@ index 82073d5cc..ae31271bb 100644
|
|||||||
grub_install_make_image_wrap (input_dir, prefix, output,
|
grub_install_make_image_wrap (input_dir, prefix, output,
|
||||||
0, load_cfg,
|
0, load_cfg,
|
||||||
targets[platform].mkimage_target, 0);
|
targets[platform].mkimage_target, 0);
|
||||||
@@ -190,7 +196,16 @@ main (int argc, char *argv[])
|
@@ -195,7 +201,16 @@ main (int argc, char *argv[])
|
||||||
|
|
||||||
grub_install_mkdir_p (base);
|
grub_install_mkdir_p (base);
|
||||||
|
|
||||||
@ -4084,10 +4082,10 @@ index 82073d5cc..ae31271bb 100644
|
|||||||
if (!grub_install_source_directory)
|
if (!grub_install_source_directory)
|
||||||
{
|
{
|
||||||
diff --git a/include/grub/efi/api.h b/include/grub/efi/api.h
|
diff --git a/include/grub/efi/api.h b/include/grub/efi/api.h
|
||||||
index dd3b07eac..b337e1a19 100644
|
index 0b490195ad..f431f49973 100644
|
||||||
--- a/include/grub/efi/api.h
|
--- a/include/grub/efi/api.h
|
||||||
+++ b/include/grub/efi/api.h
|
+++ b/include/grub/efi/api.h
|
||||||
@@ -602,6 +602,23 @@ typedef union
|
@@ -622,6 +622,23 @@ typedef union
|
||||||
|
|
||||||
typedef grub_efi_uint64_t grub_efi_physical_address_t;
|
typedef grub_efi_uint64_t grub_efi_physical_address_t;
|
||||||
typedef grub_efi_uint64_t grub_efi_virtual_address_t;
|
typedef grub_efi_uint64_t grub_efi_virtual_address_t;
|
||||||
@ -4111,7 +4109,7 @@ index dd3b07eac..b337e1a19 100644
|
|||||||
|
|
||||||
struct grub_efi_guid
|
struct grub_efi_guid
|
||||||
{
|
{
|
||||||
@@ -865,6 +882,8 @@ struct grub_efi_ipv6_device_path
|
@@ -889,6 +906,8 @@ struct grub_efi_ipv6_device_path
|
||||||
grub_efi_uint16_t remote_port;
|
grub_efi_uint16_t remote_port;
|
||||||
grub_efi_uint16_t protocol;
|
grub_efi_uint16_t protocol;
|
||||||
grub_efi_uint8_t static_ip_address;
|
grub_efi_uint8_t static_ip_address;
|
||||||
@ -4120,7 +4118,7 @@ index dd3b07eac..b337e1a19 100644
|
|||||||
} GRUB_PACKED;
|
} GRUB_PACKED;
|
||||||
typedef struct grub_efi_ipv6_device_path grub_efi_ipv6_device_path_t;
|
typedef struct grub_efi_ipv6_device_path grub_efi_ipv6_device_path_t;
|
||||||
|
|
||||||
@@ -914,6 +933,15 @@ struct grub_efi_uri_device_path
|
@@ -938,6 +957,15 @@ struct grub_efi_uri_device_path
|
||||||
} GRUB_PACKED;
|
} GRUB_PACKED;
|
||||||
typedef struct grub_efi_uri_device_path grub_efi_uri_device_path_t;
|
typedef struct grub_efi_uri_device_path grub_efi_uri_device_path_t;
|
||||||
|
|
||||||
@ -4136,7 +4134,7 @@ index dd3b07eac..b337e1a19 100644
|
|||||||
#define GRUB_EFI_VENDOR_MESSAGING_DEVICE_PATH_SUBTYPE 10
|
#define GRUB_EFI_VENDOR_MESSAGING_DEVICE_PATH_SUBTYPE 10
|
||||||
|
|
||||||
/* Media Device Path. */
|
/* Media Device Path. */
|
||||||
@@ -996,6 +1024,23 @@ struct grub_efi_bios_device_path
|
@@ -1020,6 +1048,23 @@ struct grub_efi_bios_device_path
|
||||||
} GRUB_PACKED;
|
} GRUB_PACKED;
|
||||||
typedef struct grub_efi_bios_device_path grub_efi_bios_device_path_t;
|
typedef struct grub_efi_bios_device_path grub_efi_bios_device_path_t;
|
||||||
|
|
||||||
@ -4160,7 +4158,7 @@ index dd3b07eac..b337e1a19 100644
|
|||||||
struct grub_efi_open_protocol_information_entry
|
struct grub_efi_open_protocol_information_entry
|
||||||
{
|
{
|
||||||
grub_efi_handle_t agent_handle;
|
grub_efi_handle_t agent_handle;
|
||||||
@@ -1545,23 +1590,27 @@ typedef struct grub_efi_pxe_tftp_error
|
@@ -1569,23 +1614,27 @@ typedef struct grub_efi_pxe_tftp_error
|
||||||
grub_efi_char8_t error_string[127];
|
grub_efi_char8_t error_string[127];
|
||||||
} grub_efi_pxe_tftp_error_t;
|
} grub_efi_pxe_tftp_error_t;
|
||||||
|
|
||||||
@ -4202,7 +4200,7 @@ index dd3b07eac..b337e1a19 100644
|
|||||||
|
|
||||||
#define GRUB_EFI_PXE_BASE_CODE_MAX_IPCNT 8
|
#define GRUB_EFI_PXE_BASE_CODE_MAX_IPCNT 8
|
||||||
typedef struct grub_efi_pxe_ip_filter
|
typedef struct grub_efi_pxe_ip_filter
|
||||||
@@ -1628,17 +1677,31 @@ typedef struct grub_efi_pxe_mode
|
@@ -1652,17 +1701,31 @@ typedef struct grub_efi_pxe_mode
|
||||||
typedef struct grub_efi_pxe
|
typedef struct grub_efi_pxe
|
||||||
{
|
{
|
||||||
grub_uint64_t rev;
|
grub_uint64_t rev;
|
||||||
@ -4238,7 +4236,7 @@ index dd3b07eac..b337e1a19 100644
|
|||||||
void (*setpackets) (void);
|
void (*setpackets) (void);
|
||||||
struct grub_efi_pxe_mode *mode;
|
struct grub_efi_pxe_mode *mode;
|
||||||
} grub_efi_pxe_t;
|
} grub_efi_pxe_t;
|
||||||
@@ -1880,6 +1943,44 @@ struct grub_efi_ip4_config2_protocol
|
@@ -1924,6 +1987,44 @@ struct grub_efi_ip4_config2_protocol
|
||||||
};
|
};
|
||||||
typedef struct grub_efi_ip4_config2_protocol grub_efi_ip4_config2_protocol_t;
|
typedef struct grub_efi_ip4_config2_protocol grub_efi_ip4_config2_protocol_t;
|
||||||
|
|
||||||
@ -4283,7 +4281,7 @@ index dd3b07eac..b337e1a19 100644
|
|||||||
enum grub_efi_ip6_config_data_type {
|
enum grub_efi_ip6_config_data_type {
|
||||||
GRUB_EFI_IP6_CONFIG_DATA_TYPE_INTERFACEINFO,
|
GRUB_EFI_IP6_CONFIG_DATA_TYPE_INTERFACEINFO,
|
||||||
GRUB_EFI_IP6_CONFIG_DATA_TYPE_ALT_INTERFACEID,
|
GRUB_EFI_IP6_CONFIG_DATA_TYPE_ALT_INTERFACEID,
|
||||||
@@ -1914,6 +2015,49 @@ struct grub_efi_ip6_config_protocol
|
@@ -1958,6 +2059,49 @@ struct grub_efi_ip6_config_protocol
|
||||||
};
|
};
|
||||||
typedef struct grub_efi_ip6_config_protocol grub_efi_ip6_config_protocol_t;
|
typedef struct grub_efi_ip6_config_protocol grub_efi_ip6_config_protocol_t;
|
||||||
|
|
||||||
@ -4331,11 +4329,11 @@ index dd3b07eac..b337e1a19 100644
|
|||||||
+typedef struct grub_efi_ip6_config_manual_address grub_efi_ip6_config_manual_address_t;
|
+typedef struct grub_efi_ip6_config_manual_address grub_efi_ip6_config_manual_address_t;
|
||||||
+
|
+
|
||||||
#if (GRUB_TARGET_SIZEOF_VOID_P == 4) || defined (__ia64__) \
|
#if (GRUB_TARGET_SIZEOF_VOID_P == 4) || defined (__ia64__) \
|
||||||
|| defined (__aarch64__) || defined (__MINGW64__) || defined (__CYGWIN__)
|
|| defined (__aarch64__) || defined (__MINGW64__) || defined (__CYGWIN__) \
|
||||||
|
|| defined(__riscv)
|
||||||
diff --git a/include/grub/efi/dhcp.h b/include/grub/efi/dhcp.h
|
diff --git a/include/grub/efi/dhcp.h b/include/grub/efi/dhcp.h
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..fdb88eb81
|
index 0000000000..fdb88eb810
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/include/grub/efi/dhcp.h
|
+++ b/include/grub/efi/dhcp.h
|
||||||
@@ -0,0 +1,343 @@
|
@@ -0,0 +1,343 @@
|
||||||
@ -4684,7 +4682,7 @@ index 000000000..fdb88eb81
|
|||||||
+#endif /* ! GRUB_EFI_DHCP_HEADER */
|
+#endif /* ! GRUB_EFI_DHCP_HEADER */
|
||||||
diff --git a/include/grub/efi/http.h b/include/grub/efi/http.h
|
diff --git a/include/grub/efi/http.h b/include/grub/efi/http.h
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..c5e9a89f5
|
index 0000000000..c5e9a89f50
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/include/grub/efi/http.h
|
+++ b/include/grub/efi/http.h
|
||||||
@@ -0,0 +1,215 @@
|
@@ -0,0 +1,215 @@
|
||||||
@ -4905,7 +4903,7 @@ index 000000000..c5e9a89f5
|
|||||||
+#endif /* !GRUB_EFI_HTTP_HEADER */
|
+#endif /* !GRUB_EFI_HTTP_HEADER */
|
||||||
diff --git a/include/grub/net/efi.h b/include/grub/net/efi.h
|
diff --git a/include/grub/net/efi.h b/include/grub/net/efi.h
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..de90d223e
|
index 0000000000..de90d223e8
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/include/grub/net/efi.h
|
+++ b/include/grub/net/efi.h
|
||||||
@@ -0,0 +1,144 @@
|
@@ -0,0 +1,144 @@
|
@ -22,7 +22,7 @@ Signed-off-by: Michael Chang <mchang@suse.com>
|
|||||||
2 files changed, 7 insertions(+), 2 deletions(-)
|
2 files changed, 7 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/net/efi/net.c b/grub-core/net/efi/net.c
|
diff --git a/grub-core/net/efi/net.c b/grub-core/net/efi/net.c
|
||||||
index 9e0078ac1..2bf15447f 100644
|
index 86bce6535d..4bb308026c 100644
|
||||||
--- a/grub-core/net/efi/net.c
|
--- a/grub-core/net/efi/net.c
|
||||||
+++ b/grub-core/net/efi/net.c
|
+++ b/grub-core/net/efi/net.c
|
||||||
@@ -645,8 +645,10 @@ grub_efihttp_chunk_read (grub_file_t file, char *buf,
|
@@ -645,8 +645,10 @@ grub_efihttp_chunk_read (grub_file_t file, char *buf,
|
||||||
@ -38,7 +38,7 @@ index 9e0078ac1..2bf15447f 100644
|
|||||||
if (buf)
|
if (buf)
|
||||||
{
|
{
|
||||||
diff --git a/grub-core/net/http.c b/grub-core/net/http.c
|
diff --git a/grub-core/net/http.c b/grub-core/net/http.c
|
||||||
index 00737c527..c9c59690a 100644
|
index 12a2632ea5..b52b558d63 100644
|
||||||
--- a/grub-core/net/http.c
|
--- a/grub-core/net/http.c
|
||||||
+++ b/grub-core/net/http.c
|
+++ b/grub-core/net/http.c
|
||||||
@@ -31,7 +31,8 @@ GRUB_MOD_LICENSE ("GPLv3+");
|
@@ -31,7 +31,8 @@ GRUB_MOD_LICENSE ("GPLv3+");
|
@ -17,7 +17,7 @@ Signed-off-by: Hans de Goede <hdegoede@redhat.com>
|
|||||||
1 file changed, 50 insertions(+)
|
1 file changed, 50 insertions(+)
|
||||||
|
|
||||||
diff --git a/util/grub-editenv.c b/util/grub-editenv.c
|
diff --git a/util/grub-editenv.c b/util/grub-editenv.c
|
||||||
index 118e89fe5..2918bb71c 100644
|
index db6f187cc6..948eec8a11 100644
|
||||||
--- a/util/grub-editenv.c
|
--- a/util/grub-editenv.c
|
||||||
+++ b/util/grub-editenv.c
|
+++ b/util/grub-editenv.c
|
||||||
@@ -53,6 +53,9 @@ static struct argp_option options[] = {
|
@@ -53,6 +53,9 @@ static struct argp_option options[] = {
|
||||||
@ -30,7 +30,7 @@ index 118e89fe5..2918bb71c 100644
|
|||||||
|
|
||||||
{0, 0, 0, OPTION_DOC, N_("Options:"), -1},
|
{0, 0, 0, OPTION_DOC, N_("Options:"), -1},
|
||||||
{"verbose", 'v', 0, 0, N_("print verbose messages."), 0},
|
{"verbose", 'v', 0, 0, N_("print verbose messages."), 0},
|
||||||
@@ -246,6 +249,51 @@ unset_variables (const char *name, int argc, char *argv[])
|
@@ -253,6 +256,51 @@ unset_variables (const char *name, int argc, char *argv[])
|
||||||
grub_envblk_close (envblk);
|
grub_envblk_close (envblk);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -82,7 +82,7 @@ index 118e89fe5..2918bb71c 100644
|
|||||||
int
|
int
|
||||||
main (int argc, char *argv[])
|
main (int argc, char *argv[])
|
||||||
{
|
{
|
||||||
@@ -285,6 +333,8 @@ main (int argc, char *argv[])
|
@@ -292,6 +340,8 @@ main (int argc, char *argv[])
|
||||||
set_variables (filename, argc - curindex, argv + curindex);
|
set_variables (filename, argc - curindex, argv + curindex);
|
||||||
else if (strcmp (command, "unset") == 0)
|
else if (strcmp (command, "unset") == 0)
|
||||||
unset_variables (filename, argc - curindex, argv + curindex);
|
unset_variables (filename, argc - curindex, argv + curindex);
|
@ -35,42 +35,36 @@ fastboot If set to "1" and the conditions for auto-hiding the menu
|
|||||||
https://git.launchpad.net/~ubuntu-core-dev/grub/+git/ubuntu/tree/debian/patches/quick_boot.patch
|
https://git.launchpad.net/~ubuntu-core-dev/grub/+git/ubuntu/tree/debian/patches/quick_boot.patch
|
||||||
|
|
||||||
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
|
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
|
||||||
---
|
|
||||||
Changes in v2:
|
|
||||||
-Drop shutdown_success tests, there is no meaningful way for systemd to set
|
|
||||||
this flag (by the time it knows all filesystems are unmounted or read-only
|
|
||||||
-Drop fwsetup_once support, systemd already supports booting directly into
|
|
||||||
the fwsetup by doing "systemctl reboot --firmware"
|
|
||||||
---
|
---
|
||||||
Makefile.util.def | 6 +++++
|
Makefile.util.def | 6 +++++
|
||||||
util/grub.d/00_menu_auto_hide.in | 50 ++++++++++++++++++++++++++++++++++++++++
|
util/grub.d/01_menu_auto_hide.in | 48 ++++++++++++++++++++++++++++++++++++++++
|
||||||
util/grub.d/30_os-prober.in | 18 +++++++++++++++
|
util/grub.d/30_os-prober.in | 18 +++++++++++++++
|
||||||
3 files changed, 74 insertions(+)
|
3 files changed, 72 insertions(+)
|
||||||
create mode 100644 util/grub.d/00_menu_auto_hide.in
|
create mode 100644 util/grub.d/01_menu_auto_hide.in
|
||||||
|
|
||||||
diff --git a/Makefile.util.def b/Makefile.util.def
|
diff --git a/Makefile.util.def b/Makefile.util.def
|
||||||
index cbd661d63..0fdfdd91f 100644
|
index bda9fd1211..cb8e3c3270 100644
|
||||||
--- a/Makefile.util.def
|
--- a/Makefile.util.def
|
||||||
+++ b/Makefile.util.def
|
+++ b/Makefile.util.def
|
||||||
@@ -448,6 +448,12 @@ script = {
|
@@ -458,6 +458,12 @@ script = {
|
||||||
installdir = grubconf;
|
installdir = grubconf;
|
||||||
};
|
};
|
||||||
|
|
||||||
+script = {
|
+script = {
|
||||||
+ name = '00_menu_auto_hide';
|
+ name = '01_menu_auto_hide';
|
||||||
+ common = util/grub.d/00_menu_auto_hide.in;
|
+ common = util/grub.d/01_menu_auto_hide.in;
|
||||||
+ installdir = grubconf;
|
+ installdir = grubconf;
|
||||||
+};
|
+};
|
||||||
+
|
+
|
||||||
script = {
|
script = {
|
||||||
name = '01_users';
|
name = '01_users';
|
||||||
common = util/grub.d/01_users.in;
|
common = util/grub.d/01_users.in;
|
||||||
diff --git a/util/grub.d/00_menu_auto_hide.in b/util/grub.d/00_menu_auto_hide.in
|
diff --git a/util/grub.d/01_menu_auto_hide.in b/util/grub.d/01_menu_auto_hide.in
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..a10fe45bb
|
index 0000000000..ad175870a5
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/util/grub.d/00_menu_auto_hide.in
|
+++ b/util/grub.d/01_menu_auto_hide.in
|
||||||
@@ -0,0 +1,50 @@
|
@@ -0,0 +1,48 @@
|
||||||
+#! /bin/sh
|
+#! /bin/sh
|
||||||
+
|
+
|
||||||
+# Disable / skip generating menu-auto-hide config parts on serial terminals
|
+# Disable / skip generating menu-auto-hide config parts on serial terminals
|
||||||
@ -92,21 +86,19 @@ index 000000000..a10fe45bb
|
|||||||
+# Reset boot_indeterminate after a successful boot
|
+# Reset boot_indeterminate after a successful boot
|
||||||
+if [ "\${boot_success}" = "1" ] ; then
|
+if [ "\${boot_success}" = "1" ] ; then
|
||||||
+ set boot_indeterminate=0
|
+ set boot_indeterminate=0
|
||||||
+ save_env boot_indeterminate
|
|
||||||
+# Avoid boot_indeterminate causing the menu to be hidden more then once
|
+# Avoid boot_indeterminate causing the menu to be hidden more then once
|
||||||
+elif [ "\${boot_indeterminate}" = "1" ]; then
|
+elif [ "\${boot_indeterminate}" = "1" ]; then
|
||||||
+ set boot_indeterminate=2
|
+ set boot_indeterminate=2
|
||||||
+ save_env boot_indeterminate
|
|
||||||
+fi
|
+fi
|
||||||
+set boot_success=0
|
+set boot_success=0
|
||||||
+save_env boot_success
|
+save_env boot_success boot_indeterminate
|
||||||
+
|
+
|
||||||
+if [ x\$feature_timeout_style = xy ] ; then
|
+if [ x\$feature_timeout_style = xy ] ; then
|
||||||
+ if [ "\${menu_show_once}" ]; then
|
+ if [ "\${menu_show_once}" ]; then
|
||||||
+ unset menu_show_once
|
+ unset menu_show_once
|
||||||
+ save_env menu_show_once
|
+ save_env menu_show_once
|
||||||
+ set timeout_style=menu
|
+ set timeout_style=menu
|
||||||
+ unset timeout
|
+ set timeout=60
|
||||||
+ elif [ "\${menu_auto_hide}" -a "\${last_boot_ok}" = "1" ]; then
|
+ elif [ "\${menu_auto_hide}" -a "\${last_boot_ok}" = "1" ]; then
|
||||||
+ set orig_timeout_style=\${timeout_style}
|
+ set orig_timeout_style=\${timeout_style}
|
||||||
+ set orig_timeout=\${timeout}
|
+ set orig_timeout=\${timeout}
|
||||||
@ -122,7 +114,7 @@ index 000000000..a10fe45bb
|
|||||||
+fi
|
+fi
|
||||||
+EOF
|
+EOF
|
||||||
diff --git a/util/grub.d/30_os-prober.in b/util/grub.d/30_os-prober.in
|
diff --git a/util/grub.d/30_os-prober.in b/util/grub.d/30_os-prober.in
|
||||||
index 13a3a6bc7..ab634393a 100644
|
index 4b27bd2015..3c9431cfcf 100644
|
||||||
--- a/util/grub.d/30_os-prober.in
|
--- a/util/grub.d/30_os-prober.in
|
||||||
+++ b/util/grub.d/30_os-prober.in
|
+++ b/util/grub.d/30_os-prober.in
|
||||||
@@ -42,6 +42,7 @@ if [ -z "${OSPROBED}" ] ; then
|
@@ -42,6 +42,7 @@ if [ -z "${OSPROBED}" ] ; then
|
||||||
@ -157,7 +149,7 @@ index 13a3a6bc7..ab634393a 100644
|
|||||||
onstr="$(gettext_printf "(on %s)" "${DEVICE}")"
|
onstr="$(gettext_printf "(on %s)" "${DEVICE}")"
|
||||||
recovery_params="$(echo "${LPARAMS}" | grep single)" || true
|
recovery_params="$(echo "${LPARAMS}" | grep single)" || true
|
||||||
counter=1
|
counter=1
|
||||||
@@ -249,6 +253,7 @@ EOF
|
@@ -257,6 +261,7 @@ EOF
|
||||||
done
|
done
|
||||||
;;
|
;;
|
||||||
hurd)
|
hurd)
|
||||||
@ -165,7 +157,7 @@ index 13a3a6bc7..ab634393a 100644
|
|||||||
onstr="$(gettext_printf "(on %s)" "${DEVICE}")"
|
onstr="$(gettext_printf "(on %s)" "${DEVICE}")"
|
||||||
cat << EOF
|
cat << EOF
|
||||||
menuentry '$(echo "${LONGNAME} $onstr" | grub_quote)' --class hurd --class gnu --class os \$menuentry_id_option 'osprober-gnuhurd-/boot/gnumach.gz-false-$(grub_get_device_id "${DEVICE}")' {
|
menuentry '$(echo "${LONGNAME} $onstr" | grub_quote)' --class hurd --class gnu --class os \$menuentry_id_option 'osprober-gnuhurd-/boot/gnumach.gz-false-$(grub_get_device_id "${DEVICE}")' {
|
||||||
@@ -275,6 +280,7 @@ EOF
|
@@ -283,6 +288,7 @@ EOF
|
||||||
EOF
|
EOF
|
||||||
;;
|
;;
|
||||||
minix)
|
minix)
|
||||||
@ -173,8 +165,8 @@ index 13a3a6bc7..ab634393a 100644
|
|||||||
cat << EOF
|
cat << EOF
|
||||||
menuentry "${LONGNAME} (on ${DEVICE}, Multiboot)" {
|
menuentry "${LONGNAME} (on ${DEVICE}, Multiboot)" {
|
||||||
EOF
|
EOF
|
||||||
@@ -306,3 +312,15 @@ EOF
|
@@ -299,3 +305,15 @@ EOF
|
||||||
esac
|
;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
+
|
+
|
@ -33,27 +33,27 @@ and a symlink to grub-boot-success.timer should be added to
|
|||||||
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
|
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
|
||||||
[makhomed: grub-boot-success.timer: Only run if not in a container]
|
[makhomed: grub-boot-success.timer: Only run if not in a container]
|
||||||
Signed-off-by: Gena Makhomed <makhomed@gmail.com>
|
Signed-off-by: Gena Makhomed <makhomed@gmail.com>
|
||||||
|
[rharwood: migrate to h2m]
|
||||||
Signed-off-by: Robbie Harwood <rharwood@redhat.com>
|
Signed-off-by: Robbie Harwood <rharwood@redhat.com>
|
||||||
(cherry-picked from commit 555625062cbb10388bb706620e2d8839644fc015)
|
|
||||||
---
|
---
|
||||||
Makefile.util.def | 7 ++
|
Makefile.util.def | 7 ++
|
||||||
util/grub-set-bootflag.c | 160 +++++++++++++++++++++++++++++++++++++++++
|
util/grub-set-bootflag.c | 172 +++++++++++++++++++++++++++++++++++++++++
|
||||||
conf/Makefile.extra-dist | 3 +
|
conf/Makefile.extra-dist | 3 +
|
||||||
docs/grub-boot-success.service | 6 ++
|
docs/grub-boot-success.service | 6 ++
|
||||||
docs/grub-boot-success.timer | 7 ++
|
docs/grub-boot-success.timer | 7 ++
|
||||||
util/grub-set-bootflag.1 | 20 ++++++
|
docs/man/grub-set-bootflag.h2m | 2 +
|
||||||
6 files changed, 203 insertions(+)
|
6 files changed, 197 insertions(+)
|
||||||
create mode 100644 util/grub-set-bootflag.c
|
create mode 100644 util/grub-set-bootflag.c
|
||||||
create mode 100644 docs/grub-boot-success.service
|
create mode 100644 docs/grub-boot-success.service
|
||||||
create mode 100644 docs/grub-boot-success.timer
|
create mode 100644 docs/grub-boot-success.timer
|
||||||
create mode 100644 util/grub-set-bootflag.1
|
create mode 100644 docs/man/grub-set-bootflag.h2m
|
||||||
|
|
||||||
diff --git a/Makefile.util.def b/Makefile.util.def
|
diff --git a/Makefile.util.def b/Makefile.util.def
|
||||||
index 5a8c390a1..5da553932 100644
|
index cb8e3c3270..d066652e9b 100644
|
||||||
--- a/Makefile.util.def
|
--- a/Makefile.util.def
|
||||||
+++ b/Makefile.util.def
|
+++ b/Makefile.util.def
|
||||||
@@ -1435,3 +1435,10 @@ program = {
|
@@ -1429,3 +1429,10 @@ program = {
|
||||||
ldadd = grub-core/gnulib/libgnu.a;
|
ldadd = grub-core/lib/gnulib/libgnu.a;
|
||||||
ldadd = '$(LIBINTL) $(LIBDEVMAPPER) $(LIBZFS) $(LIBNVPAIR) $(LIBGEOM)';
|
ldadd = '$(LIBINTL) $(LIBDEVMAPPER) $(LIBZFS) $(LIBNVPAIR) $(LIBGEOM)';
|
||||||
};
|
};
|
||||||
+
|
+
|
||||||
@ -65,10 +65,10 @@ index 5a8c390a1..5da553932 100644
|
|||||||
+};
|
+};
|
||||||
diff --git a/util/grub-set-bootflag.c b/util/grub-set-bootflag.c
|
diff --git a/util/grub-set-bootflag.c b/util/grub-set-bootflag.c
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..bb198f023
|
index 0000000000..d506f7e75b
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/util/grub-set-bootflag.c
|
+++ b/util/grub-set-bootflag.c
|
||||||
@@ -0,0 +1,160 @@
|
@@ -0,0 +1,172 @@
|
||||||
+/* grub-set-bootflag.c - tool to set boot-flags in the grubenv. */
|
+/* grub-set-bootflag.c - tool to set boot-flags in the grubenv. */
|
||||||
+/*
|
+/*
|
||||||
+ * GRUB -- GRand Unified Bootloader
|
+ * GRUB -- GRand Unified Bootloader
|
||||||
@ -102,6 +102,8 @@ index 000000000..bb198f023
|
|||||||
+#include <string.h>
|
+#include <string.h>
|
||||||
+#include <unistd.h>
|
+#include <unistd.h>
|
||||||
+
|
+
|
||||||
|
+#include "progname.h"
|
||||||
|
+
|
||||||
+#define GRUBENV "/" GRUB_BOOT_DIR_NAME "/" GRUB_DIR_NAME "/" GRUB_ENVBLK_DEFCFG
|
+#define GRUBENV "/" GRUB_BOOT_DIR_NAME "/" GRUB_DIR_NAME "/" GRUB_ENVBLK_DEFCFG
|
||||||
+#define GRUBENV_SIZE 1024
|
+#define GRUBENV_SIZE 1024
|
||||||
+
|
+
|
||||||
@ -111,13 +113,13 @@ index 000000000..bb198f023
|
|||||||
+ NULL
|
+ NULL
|
||||||
+};
|
+};
|
||||||
+
|
+
|
||||||
+static void usage(void)
|
+static void usage(FILE *out)
|
||||||
+{
|
+{
|
||||||
+ int i;
|
+ int i;
|
||||||
+
|
+
|
||||||
+ fprintf (stderr, "Usage: 'grub-set-bootflag <bootflag>', where <bootflag> is one of:\n");
|
+ fprintf (out, "Usage: 'grub-set-bootflag <bootflag>', where <bootflag> is one of:\n");
|
||||||
+ for (i = 0; bootflags[i]; i++)
|
+ for (i = 0; bootflags[i]; i++)
|
||||||
+ fprintf (stderr, " %s\n", bootflags[i]);
|
+ fprintf (out, " %s\n", bootflags[i]);
|
||||||
+}
|
+}
|
||||||
+
|
+
|
||||||
+int main(int argc, char *argv[])
|
+int main(int argc, char *argv[])
|
||||||
@ -130,9 +132,19 @@ index 000000000..bb198f023
|
|||||||
+
|
+
|
||||||
+ if (argc != 2)
|
+ if (argc != 2)
|
||||||
+ {
|
+ {
|
||||||
+ usage();
|
+ usage (stderr);
|
||||||
+ return 1;
|
+ return 1;
|
||||||
+ }
|
+ }
|
||||||
|
+ else if (!strcmp (argv[1], "--help"))
|
||||||
|
+ {
|
||||||
|
+ usage (stdout);
|
||||||
|
+ return 0;
|
||||||
|
+ }
|
||||||
|
+ else if (!strcmp (argv[1], "--version"))
|
||||||
|
+ {
|
||||||
|
+ printf ("grub-set-bootflag (%s) %s\n", PACKAGE_NAME, PACKAGE_VERSION);
|
||||||
|
+ return 0;
|
||||||
|
+ }
|
||||||
+
|
+
|
||||||
+ for (i = 0; bootflags[i]; i++)
|
+ for (i = 0; bootflags[i]; i++)
|
||||||
+ if (!strcmp (argv[1], bootflags[i]))
|
+ if (!strcmp (argv[1], bootflags[i]))
|
||||||
@ -140,7 +152,7 @@ index 000000000..bb198f023
|
|||||||
+ if (!bootflags[i])
|
+ if (!bootflags[i])
|
||||||
+ {
|
+ {
|
||||||
+ fprintf (stderr, "Invalid bootflag: '%s'\n", argv[1]);
|
+ fprintf (stderr, "Invalid bootflag: '%s'\n", argv[1]);
|
||||||
+ usage();
|
+ usage (stderr);
|
||||||
+ return 1;
|
+ return 1;
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
@ -230,10 +242,10 @@ index 000000000..bb198f023
|
|||||||
+ return 0;
|
+ return 0;
|
||||||
+}
|
+}
|
||||||
diff --git a/conf/Makefile.extra-dist b/conf/Makefile.extra-dist
|
diff --git a/conf/Makefile.extra-dist b/conf/Makefile.extra-dist
|
||||||
index 39eb94bde..5946ec24a 100644
|
index 8f1485d52a..ad235de7fc 100644
|
||||||
--- a/conf/Makefile.extra-dist
|
--- a/conf/Makefile.extra-dist
|
||||||
+++ b/conf/Makefile.extra-dist
|
+++ b/conf/Makefile.extra-dist
|
||||||
@@ -14,6 +14,9 @@ EXTRA_DIST += util/import_unicode.py
|
@@ -15,6 +15,9 @@ EXTRA_DIST += docs/man
|
||||||
EXTRA_DIST += docs/autoiso.cfg
|
EXTRA_DIST += docs/autoiso.cfg
|
||||||
EXTRA_DIST += docs/grub.cfg
|
EXTRA_DIST += docs/grub.cfg
|
||||||
EXTRA_DIST += docs/osdetect.cfg
|
EXTRA_DIST += docs/osdetect.cfg
|
||||||
@ -245,7 +257,7 @@ index 39eb94bde..5946ec24a 100644
|
|||||||
|
|
||||||
diff --git a/docs/grub-boot-success.service b/docs/grub-boot-success.service
|
diff --git a/docs/grub-boot-success.service b/docs/grub-boot-success.service
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..80e79584c
|
index 0000000000..80e79584c9
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/docs/grub-boot-success.service
|
+++ b/docs/grub-boot-success.service
|
||||||
@@ -0,0 +1,6 @@
|
@@ -0,0 +1,6 @@
|
||||||
@ -257,7 +269,7 @@ index 000000000..80e79584c
|
|||||||
+ExecStart=/usr/sbin/grub2-set-bootflag boot_success
|
+ExecStart=/usr/sbin/grub2-set-bootflag boot_success
|
||||||
diff --git a/docs/grub-boot-success.timer b/docs/grub-boot-success.timer
|
diff --git a/docs/grub-boot-success.timer b/docs/grub-boot-success.timer
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..406f17200
|
index 0000000000..406f172005
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/docs/grub-boot-success.timer
|
+++ b/docs/grub-boot-success.timer
|
||||||
@@ -0,0 +1,7 @@
|
@@ -0,0 +1,7 @@
|
||||||
@ -268,29 +280,11 @@ index 000000000..406f17200
|
|||||||
+
|
+
|
||||||
+[Timer]
|
+[Timer]
|
||||||
+OnActiveSec=2min
|
+OnActiveSec=2min
|
||||||
diff --git a/util/grub-set-bootflag.1 b/util/grub-set-bootflag.1
|
diff --git a/docs/man/grub-set-bootflag.h2m b/docs/man/grub-set-bootflag.h2m
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..57801da22
|
index 0000000000..94ec0b92ed
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/util/grub-set-bootflag.1
|
+++ b/docs/man/grub-set-bootflag.h2m
|
||||||
@@ -0,0 +1,20 @@
|
@@ -0,0 +1,2 @@
|
||||||
+.TH GRUB-SET-BOOTFLAG 1 "Tue Jun 12 2018"
|
+[NAME]
|
||||||
+.SH NAME
|
+grub-set-bootflag \- set a bootflag in the GRUB environment block
|
||||||
+\fBgrub-set-bootflag\fR \(em Set a bootflag in the GRUB environment block.
|
|
||||||
+
|
|
||||||
+.SH SYNOPSIS
|
|
||||||
+\fBgrub-set-bootflag\fR <\fIBOOTFLAG\fR>
|
|
||||||
+
|
|
||||||
+.SH DESCRIPTION
|
|
||||||
+\fBgrub-set-bootflag\fR is a command line to set bootflags in GRUB's
|
|
||||||
+stored environment.
|
|
||||||
+
|
|
||||||
+.SH COMMANDS
|
|
||||||
+.TP
|
|
||||||
+\fBBOOTFLAG\fR
|
|
||||||
+.RS 7
|
|
||||||
+Bootflag to set, one of \fIboot_success\fR or \fIshow_menu_once\fR.
|
|
||||||
+.RE
|
|
||||||
+
|
|
||||||
+.SH SEE ALSO
|
|
||||||
+.BR "info grub"
|
|
@ -16,7 +16,7 @@ Signed-off-by: Hans de Goede <hdegoede@redhat.com>
|
|||||||
|
|
||||||
diff --git a/docs/grub-boot-indeterminate.service b/docs/grub-boot-indeterminate.service
|
diff --git a/docs/grub-boot-indeterminate.service b/docs/grub-boot-indeterminate.service
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000..6c8dcb186
|
index 0000000000..6c8dcb186b
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/docs/grub-boot-indeterminate.service
|
+++ b/docs/grub-boot-indeterminate.service
|
||||||
@@ -0,0 +1,11 @@
|
@@ -0,0 +1,11 @@
|
@ -9,10 +9,10 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
1 file changed, 13 insertions(+), 1 deletion(-)
|
1 file changed, 13 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
diff --git a/gentpl.py b/gentpl.py
|
diff --git a/gentpl.py b/gentpl.py
|
||||||
index bf8439fa7..a8cd54055 100644
|
index c86550d4f9..f3c5f84f85 100644
|
||||||
--- a/gentpl.py
|
--- a/gentpl.py
|
||||||
+++ b/gentpl.py
|
+++ b/gentpl.py
|
||||||
@@ -589,11 +589,21 @@ def platform_conditional(platform, closure):
|
@@ -592,11 +592,21 @@ def platform_conditional(platform, closure):
|
||||||
# };
|
# };
|
||||||
#
|
#
|
||||||
def foreach_enabled_platform(defn, closure):
|
def foreach_enabled_platform(defn, closure):
|
||||||
@ -35,7 +35,7 @@ index bf8439fa7..a8cd54055 100644
|
|||||||
for platform in GRUB_PLATFORMS:
|
for platform in GRUB_PLATFORMS:
|
||||||
platform_conditional(platform, closure)
|
platform_conditional(platform, closure)
|
||||||
|
|
||||||
@@ -652,6 +662,8 @@ def first_time(defn, snippet):
|
@@ -655,6 +665,8 @@ def first_time(defn, snippet):
|
||||||
def is_platform_independent(defn):
|
def is_platform_independent(defn):
|
||||||
if 'enable' in defn:
|
if 'enable' in defn:
|
||||||
return False
|
return False
|
@ -1,6 +1,6 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
From: Peter Jones <pjones@redhat.com>
|
From: Peter Jones <pjones@redhat.com>
|
||||||
Date: Wed, 11 Jul 2018 13:43:34 -0400
|
Date: Thu, 11 Jul 2019 11:04:24 +0200
|
||||||
Subject: [PATCH] gentpl: add 'pc' firmware type
|
Subject: [PATCH] gentpl: add 'pc' firmware type
|
||||||
|
|
||||||
Signed-off-by: Peter Jones <pjones@redhat.com>
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
@ -9,14 +9,14 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
1 file changed, 1 insertion(+)
|
1 file changed, 1 insertion(+)
|
||||||
|
|
||||||
diff --git a/gentpl.py b/gentpl.py
|
diff --git a/gentpl.py b/gentpl.py
|
||||||
index a8cd54055..baac6a2af 100644
|
index f3c5f84f85..f09b336869 100644
|
||||||
--- a/gentpl.py
|
--- a/gentpl.py
|
||||||
+++ b/gentpl.py
|
+++ b/gentpl.py
|
||||||
@@ -49,6 +49,7 @@ GROUPS["arm"] = [ "arm_uboot", "arm_efi", "arm_coreboot" ]
|
@@ -51,6 +51,7 @@ GROUPS["riscv32"] = [ "riscv32_efi" ]
|
||||||
GROUPS["arm64"] = [ "arm64_efi" ]
|
GROUPS["riscv64"] = [ "riscv64_efi" ]
|
||||||
|
|
||||||
# Groups based on firmware
|
# Groups based on firmware
|
||||||
+GROUPS["pc"] = [ "i386_pc" ]
|
+GROUPS["pc"] = [ "i386_pc" ]
|
||||||
GROUPS["efi"] = [ "i386_efi", "x86_64_efi", "ia64_efi", "arm_efi", "arm64_efi" ]
|
GROUPS["efi"] = [ "i386_efi", "x86_64_efi", "ia64_efi", "arm_efi", "arm64_efi",
|
||||||
|
"riscv32_efi", "riscv64_efi" ]
|
||||||
GROUPS["ieee1275"] = [ "i386_ieee1275", "sparc64_ieee1275", "powerpc_ieee1275" ]
|
GROUPS["ieee1275"] = [ "i386_ieee1275", "sparc64_ieee1275", "powerpc_ieee1275" ]
|
||||||
GROUPS["uboot"] = [ "arm_uboot" ]
|
|
@ -9,7 +9,7 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
1 file changed, 3 insertions(+), 1 deletion(-)
|
1 file changed, 3 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
diff --git a/grub-core/net/efi/net.c b/grub-core/net/efi/net.c
|
diff --git a/grub-core/net/efi/net.c b/grub-core/net/efi/net.c
|
||||||
index 2bf15447f..f208d1b18 100644
|
index 4bb308026c..6603cd83ed 100644
|
||||||
--- a/grub-core/net/efi/net.c
|
--- a/grub-core/net/efi/net.c
|
||||||
+++ b/grub-core/net/efi/net.c
|
+++ b/grub-core/net/efi/net.c
|
||||||
@@ -1324,7 +1324,9 @@ grub_efi_net_boot_from_https (void)
|
@@ -1324,7 +1324,9 @@ grub_efi_net_boot_from_https (void)
|
@ -12,7 +12,7 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
1 file changed, 19 insertions(+)
|
1 file changed, 19 insertions(+)
|
||||||
|
|
||||||
diff --git a/grub-core/net/efi/http.c b/grub-core/net/efi/http.c
|
diff --git a/grub-core/net/efi/http.c b/grub-core/net/efi/http.c
|
||||||
index 3f61fd2fa..243acbaa3 100644
|
index 3f61fd2fa5..243acbaa35 100644
|
||||||
--- a/grub-core/net/efi/http.c
|
--- a/grub-core/net/efi/http.c
|
||||||
+++ b/grub-core/net/efi/http.c
|
+++ b/grub-core/net/efi/http.c
|
||||||
@@ -4,6 +4,7 @@
|
@@ -4,6 +4,7 @@
|
@ -17,10 +17,10 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
3 files changed, 64 insertions(+), 16 deletions(-)
|
3 files changed, 64 insertions(+), 16 deletions(-)
|
||||||
|
|
||||||
diff --git a/configure.ac b/configure.ac
|
diff --git a/configure.ac b/configure.ac
|
||||||
index 9ab683fef..819212095 100644
|
index 302300711f..008f6c273b 100644
|
||||||
--- a/configure.ac
|
--- a/configure.ac
|
||||||
+++ b/configure.ac
|
+++ b/configure.ac
|
||||||
@@ -850,11 +850,23 @@ if ( test "x$target_cpu" = xi386 || test "x$target_cpu" = xx86_64 ) && test "x$p
|
@@ -849,11 +849,23 @@ if ( test "x$target_cpu" = xi386 || test "x$target_cpu" = xx86_64 ) && test "x$p
|
||||||
TARGET_CFLAGS="$TARGET_CFLAGS -mno-mmx -mno-sse -mno-sse2 -mno-sse3 -mno-3dnow"
|
TARGET_CFLAGS="$TARGET_CFLAGS -mno-mmx -mno-sse -mno-sse2 -mno-sse3 -mno-3dnow"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@ -45,7 +45,7 @@ index 9ab683fef..819212095 100644
|
|||||||
AC_CACHE_CHECK([for options to get soft-float], grub_cv_target_cc_soft_float, [
|
AC_CACHE_CHECK([for options to get soft-float], grub_cv_target_cc_soft_float, [
|
||||||
grub_cv_target_cc_soft_float=no
|
grub_cv_target_cc_soft_float=no
|
||||||
if test "x$target_cpu" = xarm64; then
|
if test "x$target_cpu" = xarm64; then
|
||||||
@@ -1939,6 +1951,41 @@ HOST_CPPFLAGS="$HOST_CPPFLAGS -I\$(top_builddir)/include"
|
@@ -1954,6 +1966,41 @@ HOST_CPPFLAGS="$HOST_CPPFLAGS -I\$(top_builddir)/include"
|
||||||
TARGET_CPPFLAGS="$TARGET_CPPFLAGS -I\$(top_srcdir)/include"
|
TARGET_CPPFLAGS="$TARGET_CPPFLAGS -I\$(top_srcdir)/include"
|
||||||
TARGET_CPPFLAGS="$TARGET_CPPFLAGS -I\$(top_builddir)/include"
|
TARGET_CPPFLAGS="$TARGET_CPPFLAGS -I\$(top_builddir)/include"
|
||||||
|
|
||||||
@ -88,7 +88,7 @@ index 9ab683fef..819212095 100644
|
|||||||
GRUB_PLATFORM="${platform}"
|
GRUB_PLATFORM="${platform}"
|
||||||
|
|
||||||
diff --git a/conf/Makefile.common b/conf/Makefile.common
|
diff --git a/conf/Makefile.common b/conf/Makefile.common
|
||||||
index 1ecb921db..b93879804 100644
|
index 5f0ef96985..2ff9b39357 100644
|
||||||
--- a/conf/Makefile.common
|
--- a/conf/Makefile.common
|
||||||
+++ b/conf/Makefile.common
|
+++ b/conf/Makefile.common
|
||||||
@@ -40,24 +40,25 @@ CPPFLAGS_KERNEL = $(CPPFLAGS_CPU) $(CPPFLAGS_PLATFORM) -DGRUB_KERNEL=1
|
@@ -40,24 +40,25 @@ CPPFLAGS_KERNEL = $(CPPFLAGS_CPU) $(CPPFLAGS_PLATFORM) -DGRUB_KERNEL=1
|
||||||
@ -129,10 +129,10 @@ index 1ecb921db..b93879804 100644
|
|||||||
# Other variables
|
# Other variables
|
||||||
|
|
||||||
diff --git a/gentpl.py b/gentpl.py
|
diff --git a/gentpl.py b/gentpl.py
|
||||||
index 6409736e8..1e4635f44 100644
|
index f09b336869..0e62e14666 100644
|
||||||
--- a/gentpl.py
|
--- a/gentpl.py
|
||||||
+++ b/gentpl.py
|
+++ b/gentpl.py
|
||||||
@@ -694,10 +694,10 @@ def module(defn, platform):
|
@@ -697,10 +697,10 @@ def module(defn, platform):
|
||||||
var_set(cname(defn) + "_SOURCES", platform_sources(defn, platform) + " ## platform sources")
|
var_set(cname(defn) + "_SOURCES", platform_sources(defn, platform) + " ## platform sources")
|
||||||
var_set("nodist_" + cname(defn) + "_SOURCES", platform_nodist_sources(defn, platform) + " ## platform nodist sources")
|
var_set("nodist_" + cname(defn) + "_SOURCES", platform_nodist_sources(defn, platform) + " ## platform nodist sources")
|
||||||
var_set(cname(defn) + "_LDADD", platform_ldadd(defn, platform))
|
var_set(cname(defn) + "_LDADD", platform_ldadd(defn, platform))
|
@ -22,7 +22,7 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
3 files changed, 13 insertions(+)
|
3 files changed, 13 insertions(+)
|
||||||
|
|
||||||
diff --git a/util/grub-module-verifier32.c b/util/grub-module-verifier32.c
|
diff --git a/util/grub-module-verifier32.c b/util/grub-module-verifier32.c
|
||||||
index 257229f8f..ba7d41aaf 100644
|
index 257229f8f0..ba7d41aafe 100644
|
||||||
--- a/util/grub-module-verifier32.c
|
--- a/util/grub-module-verifier32.c
|
||||||
+++ b/util/grub-module-verifier32.c
|
+++ b/util/grub-module-verifier32.c
|
||||||
@@ -1,2 +1,4 @@
|
@@ -1,2 +1,4 @@
|
||||||
@ -31,7 +31,7 @@ index 257229f8f..ba7d41aaf 100644
|
|||||||
#include "grub-module-verifierXX.c"
|
#include "grub-module-verifierXX.c"
|
||||||
+#endif
|
+#endif
|
||||||
diff --git a/util/grub-module-verifier64.c b/util/grub-module-verifier64.c
|
diff --git a/util/grub-module-verifier64.c b/util/grub-module-verifier64.c
|
||||||
index 4db6b4bed..fc23ef800 100644
|
index 4db6b4bedd..fc23ef800b 100644
|
||||||
--- a/util/grub-module-verifier64.c
|
--- a/util/grub-module-verifier64.c
|
||||||
+++ b/util/grub-module-verifier64.c
|
+++ b/util/grub-module-verifier64.c
|
||||||
@@ -1,2 +1,4 @@
|
@@ -1,2 +1,4 @@
|
||||||
@ -40,7 +40,7 @@ index 4db6b4bed..fc23ef800 100644
|
|||||||
#include "grub-module-verifierXX.c"
|
#include "grub-module-verifierXX.c"
|
||||||
+#endif
|
+#endif
|
||||||
diff --git a/util/grub-module-verifierXX.c b/util/grub-module-verifierXX.c
|
diff --git a/util/grub-module-verifierXX.c b/util/grub-module-verifierXX.c
|
||||||
index 1feaafc9b..597ded143 100644
|
index ceb24309ae..a98e2f9b1a 100644
|
||||||
--- a/util/grub-module-verifierXX.c
|
--- a/util/grub-module-verifierXX.c
|
||||||
+++ b/util/grub-module-verifierXX.c
|
+++ b/util/grub-module-verifierXX.c
|
||||||
@@ -1,3 +1,12 @@
|
@@ -1,3 +1,12 @@
|
@ -1,6 +1,6 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
From: Peter Jones <pjones@redhat.com>
|
From: Peter Jones <pjones@redhat.com>
|
||||||
Date: Thu, 12 Jul 2018 11:00:45 -0400
|
Date: Thu, 11 Jul 2019 13:01:41 +0200
|
||||||
Subject: [PATCH] Rework how the fdt command builds.
|
Subject: [PATCH] Rework how the fdt command builds.
|
||||||
|
|
||||||
Trying to avoid all variants of:
|
Trying to avoid all variants of:
|
||||||
@ -13,19 +13,22 @@ grub_fdt_load in xen_boot is not defined
|
|||||||
grub_fdt_unload in xen_boot is not defined
|
grub_fdt_unload in xen_boot is not defined
|
||||||
|
|
||||||
Signed-off-by: Peter Jones <pjones@redhat.com>
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
|
[javierm: Fix build with platform emu, aarch64, and risc-v]
|
||||||
|
Signed-off-by: Javier Martinez Canillas <javierm@redhat.com>
|
||||||
|
Signed-off-by: Robbie Harwood <rharwood@redhat.com>
|
||||||
---
|
---
|
||||||
grub-core/Makefile.core.def | 5 ++---
|
grub-core/Makefile.core.def | 5 ++---
|
||||||
grub-core/lib/fdt.c | 2 --
|
grub-core/lib/fdt.c | 2 --
|
||||||
grub-core/loader/efi/fdt.c | 2 ++
|
grub-core/loader/efi/fdt.c | 2 ++
|
||||||
include/grub/fdt.h | 4 ++++
|
include/grub/fdt.h | 6 ++++++
|
||||||
grub-core/Makefile.am | 1 +
|
grub-core/Makefile.am | 1 +
|
||||||
5 files changed, 9 insertions(+), 5 deletions(-)
|
5 files changed, 11 insertions(+), 5 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/Makefile.core.def b/grub-core/Makefile.core.def
|
diff --git a/grub-core/Makefile.core.def b/grub-core/Makefile.core.def
|
||||||
index e35217b86..cf3d549d2 100644
|
index 12797336c9..4e7d90da76 100644
|
||||||
--- a/grub-core/Makefile.core.def
|
--- a/grub-core/Makefile.core.def
|
||||||
+++ b/grub-core/Makefile.core.def
|
+++ b/grub-core/Makefile.core.def
|
||||||
@@ -166,7 +166,6 @@ kernel = {
|
@@ -177,7 +177,6 @@ kernel = {
|
||||||
arm_coreboot = kern/arm/coreboot/init.c;
|
arm_coreboot = kern/arm/coreboot/init.c;
|
||||||
arm_coreboot = kern/arm/coreboot/timer.c;
|
arm_coreboot = kern/arm/coreboot/timer.c;
|
||||||
arm_coreboot = kern/arm/coreboot/coreboot.S;
|
arm_coreboot = kern/arm/coreboot/coreboot.S;
|
||||||
@ -33,24 +36,24 @@ index e35217b86..cf3d549d2 100644
|
|||||||
arm_coreboot = bus/fdt.c;
|
arm_coreboot = bus/fdt.c;
|
||||||
arm_coreboot = term/ps2.c;
|
arm_coreboot = term/ps2.c;
|
||||||
arm_coreboot = term/arm/pl050.c;
|
arm_coreboot = term/arm/pl050.c;
|
||||||
@@ -317,6 +316,8 @@ kernel = {
|
@@ -351,6 +350,8 @@ kernel = {
|
||||||
arm64 = kern/arm64/dl.c;
|
riscv64 = kern/riscv/cache_flush.S;
|
||||||
arm64 = kern/arm64/dl_helper.c;
|
riscv64 = kern/riscv/dl.c;
|
||||||
|
|
||||||
+ fdt = lib/fdt.c;
|
+ fdt = lib/fdt.c;
|
||||||
+
|
+
|
||||||
emu = disk/host.c;
|
emu = disk/host.c;
|
||||||
emu = kern/emu/cache_s.S;
|
emu = kern/emu/cache_s.S;
|
||||||
emu = kern/emu/hostdisk.c;
|
emu = kern/emu/hostdisk.c;
|
||||||
@@ -1714,7 +1715,6 @@ module = {
|
@@ -1825,7 +1826,6 @@ module = {
|
||||||
arm_uboot = loader/arm/linux.c;
|
riscv32 = loader/riscv/linux.c;
|
||||||
arm64 = loader/arm64/linux.c;
|
riscv64 = loader/riscv/linux.c;
|
||||||
emu = loader/emu/linux.c;
|
emu = loader/emu/linux.c;
|
||||||
- fdt = lib/fdt.c;
|
- fdt = lib/fdt.c;
|
||||||
|
|
||||||
common = loader/linux.c;
|
common = loader/linux.c;
|
||||||
common = lib/cmdline.c;
|
common = lib/cmdline.c;
|
||||||
@@ -1725,7 +1725,6 @@ module = {
|
@@ -1837,7 +1837,6 @@ module = {
|
||||||
module = {
|
module = {
|
||||||
name = fdt;
|
name = fdt;
|
||||||
efi = loader/efi/fdt.c;
|
efi = loader/efi/fdt.c;
|
||||||
@ -59,7 +62,7 @@ index e35217b86..cf3d549d2 100644
|
|||||||
};
|
};
|
||||||
|
|
||||||
diff --git a/grub-core/lib/fdt.c b/grub-core/lib/fdt.c
|
diff --git a/grub-core/lib/fdt.c b/grub-core/lib/fdt.c
|
||||||
index 0d371c563..37e04bd69 100644
|
index 0d371c5633..37e04bd69e 100644
|
||||||
--- a/grub-core/lib/fdt.c
|
--- a/grub-core/lib/fdt.c
|
||||||
+++ b/grub-core/lib/fdt.c
|
+++ b/grub-core/lib/fdt.c
|
||||||
@@ -21,8 +21,6 @@
|
@@ -21,8 +21,6 @@
|
||||||
@ -72,12 +75,12 @@ index 0d371c563..37e04bd69 100644
|
|||||||
|
|
||||||
#define FDT_BEGIN_NODE 0x00000001
|
#define FDT_BEGIN_NODE 0x00000001
|
||||||
diff --git a/grub-core/loader/efi/fdt.c b/grub-core/loader/efi/fdt.c
|
diff --git a/grub-core/loader/efi/fdt.c b/grub-core/loader/efi/fdt.c
|
||||||
index a4c6e8036..a9dbcfdfe 100644
|
index c86f283d75..c572415d38 100644
|
||||||
--- a/grub-core/loader/efi/fdt.c
|
--- a/grub-core/loader/efi/fdt.c
|
||||||
+++ b/grub-core/loader/efi/fdt.c
|
+++ b/grub-core/loader/efi/fdt.c
|
||||||
@@ -26,6 +26,8 @@
|
@@ -27,6 +27,8 @@
|
||||||
#include <grub/efi/fdtload.h>
|
|
||||||
#include <grub/efi/memory.h>
|
#include <grub/efi/memory.h>
|
||||||
|
#include <grub/cpu/efi/memory.h>
|
||||||
|
|
||||||
+GRUB_MOD_LICENSE ("GPLv3+");
|
+GRUB_MOD_LICENSE ("GPLv3+");
|
||||||
+
|
+
|
||||||
@ -85,27 +88,29 @@ index a4c6e8036..a9dbcfdfe 100644
|
|||||||
static void *fdt;
|
static void *fdt;
|
||||||
|
|
||||||
diff --git a/include/grub/fdt.h b/include/grub/fdt.h
|
diff --git a/include/grub/fdt.h b/include/grub/fdt.h
|
||||||
index 158b1bc4b..6ee57e11a 100644
|
index e609c7e411..3514aa4a5b 100644
|
||||||
--- a/include/grub/fdt.h
|
--- a/include/grub/fdt.h
|
||||||
+++ b/include/grub/fdt.h
|
+++ b/include/grub/fdt.h
|
||||||
@@ -19,6 +19,8 @@
|
@@ -19,6 +19,9 @@
|
||||||
#ifndef GRUB_FDT_HEADER
|
#ifndef GRUB_FDT_HEADER
|
||||||
#define GRUB_FDT_HEADER 1
|
#define GRUB_FDT_HEADER 1
|
||||||
|
|
||||||
+#if defined(__arm__) || defined(__aarch64__)
|
+#if !defined(GRUB_MACHINE_EMU) && \
|
||||||
|
+ (defined(__arm__) || defined(__aarch64__) || defined(__riscv))
|
||||||
+
|
+
|
||||||
#include <grub/types.h>
|
#include <grub/types.h>
|
||||||
#include <grub/symbol.h>
|
#include <grub/symbol.h>
|
||||||
|
|
||||||
@@ -141,4 +143,6 @@ int EXPORT_FUNC(grub_fdt_set_prop) (void *fdt, unsigned int nodeoffset, const ch
|
@@ -144,4 +147,7 @@ int EXPORT_FUNC(grub_fdt_set_prop) (void *fdt, unsigned int nodeoffset, const ch
|
||||||
grub_fdt_set_prop ((fdt), (nodeoffset), "reg", reg_64, 16); \
|
grub_fdt_set_prop ((fdt), (nodeoffset), "reg", reg_64, 16); \
|
||||||
})
|
})
|
||||||
|
|
||||||
+#endif /* defined(__arm__) || defined(__aarch64__) */
|
+#endif /* !defined(GRUB_MACHINE_EMU) && \
|
||||||
|
+ (defined(__arm__) || defined(__aarch64__) || defined(__riscv)) */
|
||||||
+
|
+
|
||||||
#endif /* ! GRUB_FDT_HEADER */
|
#endif /* ! GRUB_FDT_HEADER */
|
||||||
diff --git a/grub-core/Makefile.am b/grub-core/Makefile.am
|
diff --git a/grub-core/Makefile.am b/grub-core/Makefile.am
|
||||||
index 3781bb9cb..406265250 100644
|
index bfd29a3bf0..c2e8a82bce 100644
|
||||||
--- a/grub-core/Makefile.am
|
--- a/grub-core/Makefile.am
|
||||||
+++ b/grub-core/Makefile.am
|
+++ b/grub-core/Makefile.am
|
||||||
@@ -76,6 +76,7 @@ KERNEL_HEADER_FILES += $(top_srcdir)/include/grub/efi/sb.h
|
@@ -76,6 +76,7 @@ KERNEL_HEADER_FILES += $(top_srcdir)/include/grub/efi/sb.h
|
@ -9,10 +9,10 @@ Signed-off-by: Peter Jones <pjones@redhat.com>
|
|||||||
1 file changed, 20 insertions(+)
|
1 file changed, 20 insertions(+)
|
||||||
|
|
||||||
diff --git a/configure.ac b/configure.ac
|
diff --git a/configure.ac b/configure.ac
|
||||||
index 819212095..9323c1254 100644
|
index 008f6c273b..54462e0892 100644
|
||||||
--- a/configure.ac
|
--- a/configure.ac
|
||||||
+++ b/configure.ac
|
+++ b/configure.ac
|
||||||
@@ -1234,6 +1234,26 @@ if test "x$target_cpu" = xarm; then
|
@@ -1260,6 +1260,26 @@ if test "x$target_cpu" = xarm; then
|
||||||
done
|
done
|
||||||
])
|
])
|
||||||
|
|
@ -8,16 +8,18 @@ http_path: /foo/bar
|
|||||||
http_url: http://www.example.com/foo/bar
|
http_url: http://www.example.com/foo/bar
|
||||||
|
|
||||||
Signed-off-by: Peter Jones <pjones@redhat.com>
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
|
Signed-off-by: Stephen Benjamin <stephen@redhat.com>
|
||||||
|
Signed-off-by: Robbie Harwood <rharwood@redhat.com>
|
||||||
---
|
---
|
||||||
grub-core/kern/main.c | 10 +++++-
|
grub-core/kern/main.c | 10 +++++-
|
||||||
grub-core/net/efi/http.c | 82 ++++++++++++++++++++++++++++++++++++------------
|
grub-core/net/efi/http.c | 82 ++++++++++++++++++++++++++++++++++++------------
|
||||||
2 files changed, 71 insertions(+), 21 deletions(-)
|
2 files changed, 71 insertions(+), 21 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/kern/main.c b/grub-core/kern/main.c
|
diff --git a/grub-core/kern/main.c b/grub-core/kern/main.c
|
||||||
index da47b18b5..dcf48726d 100644
|
index d1de9fa687..1c540fc8c2 100644
|
||||||
--- a/grub-core/kern/main.c
|
--- a/grub-core/kern/main.c
|
||||||
+++ b/grub-core/kern/main.c
|
+++ b/grub-core/kern/main.c
|
||||||
@@ -130,11 +130,19 @@ grub_set_prefix_and_root (void)
|
@@ -131,11 +131,19 @@ grub_set_prefix_and_root (void)
|
||||||
if (fwdevice && fwpath)
|
if (fwdevice && fwpath)
|
||||||
{
|
{
|
||||||
char *fw_path;
|
char *fw_path;
|
||||||
@ -39,7 +41,7 @@ index da47b18b5..dcf48726d 100644
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
diff --git a/grub-core/net/efi/http.c b/grub-core/net/efi/http.c
|
diff --git a/grub-core/net/efi/http.c b/grub-core/net/efi/http.c
|
||||||
index 243acbaa3..2a9624dac 100644
|
index 243acbaa35..de351b2cd0 100644
|
||||||
--- a/grub-core/net/efi/http.c
|
--- a/grub-core/net/efi/http.c
|
||||||
+++ b/grub-core/net/efi/http.c
|
+++ b/grub-core/net/efi/http.c
|
||||||
@@ -9,10 +9,52 @@
|
@@ -9,10 +9,52 @@
|
||||||
@ -56,7 +58,7 @@ index 243acbaa3..2a9624dac 100644
|
|||||||
+ const char *rest, *http_server, *http_path = NULL;
|
+ const char *rest, *http_server, *http_path = NULL;
|
||||||
+
|
+
|
||||||
+ http_server = grub_env_get ("root");
|
+ http_server = grub_env_get ("root");
|
||||||
+ https = grub_strncmp (http_server, "https", 5) ? 1 : 0;
|
+ https = (grub_strncmp (http_server, "https", 5) == 0) ? 1 : 0;
|
||||||
+
|
+
|
||||||
+ /* extract http server + port */
|
+ /* extract http server + port */
|
||||||
+ if (http_server)
|
+ if (http_server)
|
||||||
@ -102,16 +104,12 @@ index 243acbaa3..2a9624dac 100644
|
|||||||
- char *root_url;
|
- char *root_url;
|
||||||
- grub_efi_ipv6_address_t address;
|
- grub_efi_ipv6_address_t address;
|
||||||
- const char *rest;
|
- const char *rest;
|
||||||
+ char *file_name;
|
+ char *file_name = NULL;
|
||||||
+ const char *http_path;
|
+ const char *http_path;
|
||||||
|
|
||||||
- if (grub_efi_string_to_ip6_address (file->device->net->server, &address, &rest) && *rest == 0)
|
- if (grub_efi_string_to_ip6_address (file->device->net->server, &address, &rest) && *rest == 0)
|
||||||
- root_url = grub_xasprintf ("%s://[%s]", type ? "https" : "http", file->device->net->server);
|
- root_url = grub_xasprintf ("%s://[%s]", type ? "https" : "http", file->device->net->server);
|
||||||
+ /* If path is relative, prepend http_path */
|
- else
|
||||||
+ http_path = grub_env_get ("http_path");
|
|
||||||
+ if (http_path && file->device->net->name[0] != '/')
|
|
||||||
+ file_name = grub_xasprintf ("%s/%s", http_path, file->device->net->name);
|
|
||||||
else
|
|
||||||
- root_url = grub_xasprintf ("%s://%s", type ? "https" : "http", file->device->net->server);
|
- root_url = grub_xasprintf ("%s://%s", type ? "https" : "http", file->device->net->server);
|
||||||
- if (root_url)
|
- if (root_url)
|
||||||
- {
|
- {
|
||||||
@ -121,15 +119,18 @@ index 243acbaa3..2a9624dac 100644
|
|||||||
- }
|
- }
|
||||||
- else
|
- else
|
||||||
- {
|
- {
|
||||||
- return grub_errno;
|
+ /* If path is relative, prepend http_path */
|
||||||
|
+ http_path = grub_env_get ("http_path");
|
||||||
|
+ if (http_path && file->device->net->name[0] != '/') {
|
||||||
|
+ file_name = grub_xasprintf ("%s/%s", http_path, file->device->net->name);
|
||||||
|
+ if (!file_name)
|
||||||
|
return grub_errno;
|
||||||
- }
|
- }
|
||||||
+ file_name = grub_strdup (file->device->net->name);
|
+ }
|
||||||
|
|
||||||
- err = efihttp_request (dev->http, file->device->net->server, file->device->net->name, type, 1, 0);
|
- err = efihttp_request (dev->http, file->device->net->server, file->device->net->name, type, 1, 0);
|
||||||
+ if (!file_name)
|
+ err = efihttp_request (dev->http, file->device->net->server,
|
||||||
+ return grub_errno;
|
+ file_name ? file_name : file->device->net->name, type, 1, 0);
|
||||||
+
|
|
||||||
+ err = efihttp_request (dev->http, file->device->net->server, file_name, type, 1, 0);
|
|
||||||
if (err != GRUB_ERR_NONE)
|
if (err != GRUB_ERR_NONE)
|
||||||
- return err;
|
- return err;
|
||||||
+ {
|
+ {
|
||||||
@ -138,7 +139,8 @@ index 243acbaa3..2a9624dac 100644
|
|||||||
+ }
|
+ }
|
||||||
|
|
||||||
- err = efihttp_request (dev->http, file->device->net->server, file->device->net->name, type, 0, &size);
|
- err = efihttp_request (dev->http, file->device->net->server, file->device->net->name, type, 0, &size);
|
||||||
+ err = efihttp_request (dev->http, file->device->net->server, file_name, type, 0, &size);
|
+ err = efihttp_request (dev->http, file->device->net->server,
|
||||||
|
+ file_name ? file_name : file->device->net->name, type, 0, &size);
|
||||||
+ grub_free (file_name);
|
+ grub_free (file_name);
|
||||||
if (err != GRUB_ERR_NONE)
|
if (err != GRUB_ERR_NONE)
|
||||||
- return err;
|
- return err;
|
@ -5,52 +5,12 @@ Subject: [PATCH] Make grub_error() more verbose
|
|||||||
|
|
||||||
Signed-off-by: Peter Jones <pjones@redhat.com>
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
---
|
---
|
||||||
grub-core/kern/efi/mm.c | 17 ++++++++++++++---
|
|
||||||
grub-core/kern/err.c | 13 +++++++++++--
|
grub-core/kern/err.c | 13 +++++++++++--
|
||||||
include/grub/err.h | 5 ++++-
|
include/grub/err.h | 8 ++++++--
|
||||||
3 files changed, 29 insertions(+), 6 deletions(-)
|
2 files changed, 17 insertions(+), 4 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/kern/efi/mm.c b/grub-core/kern/efi/mm.c
|
|
||||||
index 5cdf6c943..7692e63ba 100644
|
|
||||||
--- a/grub-core/kern/efi/mm.c
|
|
||||||
+++ b/grub-core/kern/efi/mm.c
|
|
||||||
@@ -157,12 +157,20 @@ grub_efi_allocate_pages_real (grub_efi_physical_address_t address,
|
|
||||||
|
|
||||||
/* Limit the memory access to less than 4GB for 32-bit platforms. */
|
|
||||||
if (address > GRUB_EFI_MAX_USABLE_ADDRESS)
|
|
||||||
- return 0;
|
|
||||||
+ {
|
|
||||||
+ grub_error (GRUB_ERR_BAD_ARGUMENT,
|
|
||||||
+ N_("invalid memory address (0x%llx > 0x%llx)"),
|
|
||||||
+ address, GRUB_EFI_MAX_USABLE_ADDRESS);
|
|
||||||
+ return NULL;
|
|
||||||
+ }
|
|
||||||
|
|
||||||
b = grub_efi_system_table->boot_services;
|
|
||||||
status = efi_call_4 (b->allocate_pages, alloctype, memtype, pages, &address);
|
|
||||||
if (status != GRUB_EFI_SUCCESS)
|
|
||||||
- return 0;
|
|
||||||
+ {
|
|
||||||
+ grub_error (GRUB_ERR_OUT_OF_MEMORY, N_("out of memory"));
|
|
||||||
+ return NULL;
|
|
||||||
+ }
|
|
||||||
|
|
||||||
if (address == 0)
|
|
||||||
{
|
|
||||||
@@ -172,7 +180,10 @@ grub_efi_allocate_pages_real (grub_efi_physical_address_t address,
|
|
||||||
status = efi_call_4 (b->allocate_pages, alloctype, memtype, pages, &address);
|
|
||||||
grub_efi_free_pages (0, pages);
|
|
||||||
if (status != GRUB_EFI_SUCCESS)
|
|
||||||
- return 0;
|
|
||||||
+ {
|
|
||||||
+ grub_error (GRUB_ERR_OUT_OF_MEMORY, N_("out of memory"));
|
|
||||||
+ return NULL;
|
|
||||||
+ }
|
|
||||||
}
|
|
||||||
|
|
||||||
grub_efi_store_alloc (address, pages);
|
|
||||||
diff --git a/grub-core/kern/err.c b/grub-core/kern/err.c
|
diff --git a/grub-core/kern/err.c b/grub-core/kern/err.c
|
||||||
index 53c734de7..aebfe0cf8 100644
|
index 53c734de70..aebfe0cf83 100644
|
||||||
--- a/grub-core/kern/err.c
|
--- a/grub-core/kern/err.c
|
||||||
+++ b/grub-core/kern/err.c
|
+++ b/grub-core/kern/err.c
|
||||||
@@ -33,15 +33,24 @@ static struct grub_error_saved grub_error_stack_items[GRUB_ERROR_STACK_SIZE];
|
@@ -33,15 +33,24 @@ static struct grub_error_saved grub_error_stack_items[GRUB_ERROR_STACK_SIZE];
|
||||||
@ -81,17 +41,20 @@ index 53c734de7..aebfe0cf8 100644
|
|||||||
|
|
||||||
return n;
|
return n;
|
||||||
diff --git a/include/grub/err.h b/include/grub/err.h
|
diff --git a/include/grub/err.h b/include/grub/err.h
|
||||||
index 1590c688e..9b830757d 100644
|
index b08d5d0de4..c0f90ef07c 100644
|
||||||
--- a/include/grub/err.h
|
--- a/include/grub/err.h
|
||||||
+++ b/include/grub/err.h
|
+++ b/include/grub/err.h
|
||||||
@@ -84,7 +84,10 @@ struct grub_error_saved
|
@@ -85,8 +85,12 @@ struct grub_error_saved
|
||||||
extern grub_err_t EXPORT_VAR(grub_errno);
|
extern grub_err_t EXPORT_VAR(grub_errno);
|
||||||
extern char EXPORT_VAR(grub_errmsg)[GRUB_MAX_ERRMSG];
|
extern char EXPORT_VAR(grub_errmsg)[GRUB_MAX_ERRMSG];
|
||||||
|
|
||||||
-grub_err_t EXPORT_FUNC(grub_error) (grub_err_t n, const char *fmt, ...);
|
-grub_err_t EXPORT_FUNC(grub_error) (grub_err_t n, const char *fmt, ...)
|
||||||
+grub_err_t EXPORT_FUNC(grub_error) (grub_err_t n, const char *file, const int line, const char *fmt, ...);
|
- __attribute__ ((format (GNU_PRINTF, 2, 3)));
|
||||||
|
+grub_err_t EXPORT_FUNC(grub_error) (grub_err_t n, const char *file, const int line, const char *fmt, ...)
|
||||||
|
+ __attribute__ ((format (GNU_PRINTF, 4, 5)));
|
||||||
+
|
+
|
||||||
+#define grub_error(n, fmt, ...) grub_error (n, __FILE__, __LINE__, fmt, ##__VA_ARGS__)
|
+#define grub_error(n, fmt, ...) grub_error (n, __FILE__, __LINE__, fmt, ##__VA_ARGS__)
|
||||||
|
+
|
||||||
+
|
+
|
||||||
void EXPORT_FUNC(grub_fatal) (const char *fmt, ...) __attribute__ ((noreturn));
|
void EXPORT_FUNC(grub_fatal) (const char *fmt, ...) __attribute__ ((noreturn));
|
||||||
void EXPORT_FUNC(grub_error_push) (void);
|
void EXPORT_FUNC(grub_error_push) (void);
|
40
0094-Make-reset-an-alias-for-the-reboot-command.patch
Normal file
40
0094-Make-reset-an-alias-for-the-reboot-command.patch
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Peter Jones <pjones@redhat.com>
|
||||||
|
Date: Fri, 31 Aug 2018 16:42:03 -0400
|
||||||
|
Subject: [PATCH] Make "reset" an alias for the "reboot" command.
|
||||||
|
|
||||||
|
I'm really tired of half the tools I get to use having one and the other half
|
||||||
|
having the other.
|
||||||
|
|
||||||
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
|
---
|
||||||
|
grub-core/commands/reboot.c | 11 +++++++----
|
||||||
|
1 file changed, 7 insertions(+), 4 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/grub-core/commands/reboot.c b/grub-core/commands/reboot.c
|
||||||
|
index 46d364c99a..f5cc228363 100644
|
||||||
|
--- a/grub-core/commands/reboot.c
|
||||||
|
+++ b/grub-core/commands/reboot.c
|
||||||
|
@@ -32,15 +32,18 @@ grub_cmd_reboot (grub_command_t cmd __attribute__ ((unused)),
|
||||||
|
grub_reboot ();
|
||||||
|
}
|
||||||
|
|
||||||
|
-static grub_command_t cmd;
|
||||||
|
+static grub_command_t reboot_cmd, reset_cmd;
|
||||||
|
|
||||||
|
GRUB_MOD_INIT(reboot)
|
||||||
|
{
|
||||||
|
- cmd = grub_register_command ("reboot", grub_cmd_reboot,
|
||||||
|
- 0, N_("Reboot the computer."));
|
||||||
|
+ reboot_cmd = grub_register_command ("reboot", grub_cmd_reboot,
|
||||||
|
+ 0, N_("Reboot the computer."));
|
||||||
|
+ reset_cmd = grub_register_command ("reset", grub_cmd_reboot,
|
||||||
|
+ 0, N_("Reboot the computer."));
|
||||||
|
}
|
||||||
|
|
||||||
|
GRUB_MOD_FINI(reboot)
|
||||||
|
{
|
||||||
|
- grub_unregister_command (cmd);
|
||||||
|
+ grub_unregister_command (reboot_cmd);
|
||||||
|
+ grub_unregister_command (reset_cmd);
|
||||||
|
}
|
134
0095-Add-a-version-command.patch
Normal file
134
0095-Add-a-version-command.patch
Normal file
@ -0,0 +1,134 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Peter Jones <pjones@redhat.com>
|
||||||
|
Date: Tue, 11 Sep 2018 14:20:37 -0400
|
||||||
|
Subject: [PATCH] Add a "version" command
|
||||||
|
|
||||||
|
This adds a command that shows you info about grub's version, the grub
|
||||||
|
target platform, the compiler version, and if you built with
|
||||||
|
--with-rpm-version=<string>, the rpm package version.
|
||||||
|
|
||||||
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
|
[rharwood: don't say GNU, commit message cleanup]
|
||||||
|
Signed-off-by: Robbie Harwood <rharwood@redhat.com>
|
||||||
|
---
|
||||||
|
configure.ac | 13 ++++++++++
|
||||||
|
grub-core/Makefile.core.def | 5 ++++
|
||||||
|
grub-core/commands/version.c | 56 ++++++++++++++++++++++++++++++++++++++++++++
|
||||||
|
config.h.in | 1 +
|
||||||
|
4 files changed, 75 insertions(+)
|
||||||
|
create mode 100644 grub-core/commands/version.c
|
||||||
|
|
||||||
|
diff --git a/configure.ac b/configure.ac
|
||||||
|
index 54462e0892..7b4e1854d3 100644
|
||||||
|
--- a/configure.ac
|
||||||
|
+++ b/configure.ac
|
||||||
|
@@ -284,6 +284,19 @@ AC_SUBST(target_cpu)
|
||||||
|
AC_SUBST(platform)
|
||||||
|
|
||||||
|
# Define default variables
|
||||||
|
+have_with_rpm_version=n
|
||||||
|
+AC_ARG_WITH([rpm_version],
|
||||||
|
+ AS_HELP_STRING([--with-rpm-version=VERSION],
|
||||||
|
+ [set the rpm package version [[guessed]]]),
|
||||||
|
+ [have_with_rpm_version=y],
|
||||||
|
+ [have_with_rpm_version=n])
|
||||||
|
+if test x$have_with_rpm_version = xy; then
|
||||||
|
+ rpm_version="$with_rpm_version"
|
||||||
|
+else
|
||||||
|
+ rpm_version=""
|
||||||
|
+fi
|
||||||
|
+GRUB_RPM_VERSION="$rpm_version"
|
||||||
|
+AC_SUBST(GRUB_RPM_VERSION)
|
||||||
|
|
||||||
|
have_with_bootdir=n
|
||||||
|
AC_ARG_WITH([bootdir],
|
||||||
|
diff --git a/grub-core/Makefile.core.def b/grub-core/Makefile.core.def
|
||||||
|
index 4e7d90da76..4f203533f5 100644
|
||||||
|
--- a/grub-core/Makefile.core.def
|
||||||
|
+++ b/grub-core/Makefile.core.def
|
||||||
|
@@ -579,6 +579,11 @@ image = {
|
||||||
|
enable = mips_loongson;
|
||||||
|
};
|
||||||
|
|
||||||
|
+module = {
|
||||||
|
+ name = version;
|
||||||
|
+ common = commands/version.c;
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
module = {
|
||||||
|
name = disk;
|
||||||
|
common = lib/disk.c;
|
||||||
|
diff --git a/grub-core/commands/version.c b/grub-core/commands/version.c
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000000..de0acb07ba
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/grub-core/commands/version.c
|
||||||
|
@@ -0,0 +1,56 @@
|
||||||
|
+/* version.c - Command to print the grub version and build info. */
|
||||||
|
+/*
|
||||||
|
+ * GRUB -- GRand Unified Bootloader
|
||||||
|
+ * Copyright (C) 2006,2007,2008 Free Software Foundation, Inc.
|
||||||
|
+ *
|
||||||
|
+ * GRUB 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 3 of the License, or
|
||||||
|
+ * (at your option) any later version.
|
||||||
|
+ *
|
||||||
|
+ * GRUB 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 GRUB. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
+ */
|
||||||
|
+
|
||||||
|
+#include <grub/dl.h>
|
||||||
|
+#include <grub/term.h>
|
||||||
|
+#include <grub/time.h>
|
||||||
|
+#include <grub/types.h>
|
||||||
|
+#include <grub/misc.h>
|
||||||
|
+#include <grub/extcmd.h>
|
||||||
|
+#include <grub/i18n.h>
|
||||||
|
+
|
||||||
|
+GRUB_MOD_LICENSE ("GPLv3+");
|
||||||
|
+
|
||||||
|
+static grub_err_t
|
||||||
|
+grub_cmd_version (grub_command_t cmd UNUSED, int argc, char **args UNUSED)
|
||||||
|
+{
|
||||||
|
+ if (argc != 0)
|
||||||
|
+ return grub_error (GRUB_ERR_BAD_ARGUMENT, N_("no arguments expected"));
|
||||||
|
+
|
||||||
|
+ grub_printf (_("GRUB version %s\n"), PACKAGE_VERSION);
|
||||||
|
+ grub_printf (_("Platform %s-%s\n"), GRUB_TARGET_CPU, GRUB_PLATFORM);
|
||||||
|
+ if (grub_strlen(GRUB_RPM_VERSION) != 0)
|
||||||
|
+ grub_printf (_("RPM package version %s\n"), GRUB_RPM_VERSION);
|
||||||
|
+ grub_printf (_("Compiler version %s\n"), __VERSION__);
|
||||||
|
+
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static grub_command_t cmd;
|
||||||
|
+
|
||||||
|
+GRUB_MOD_INIT(version)
|
||||||
|
+{
|
||||||
|
+ cmd = grub_register_command ("version", grub_cmd_version, NULL,
|
||||||
|
+ N_("Print version and build information."));
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+GRUB_MOD_FINI(version)
|
||||||
|
+{
|
||||||
|
+ grub_unregister_command (cmd);
|
||||||
|
+}
|
||||||
|
diff --git a/config.h.in b/config.h.in
|
||||||
|
index 9e8f9911b1..c7e316f0f1 100644
|
||||||
|
--- a/config.h.in
|
||||||
|
+++ b/config.h.in
|
||||||
|
@@ -59,6 +59,7 @@
|
||||||
|
|
||||||
|
#define GRUB_TARGET_CPU "@GRUB_TARGET_CPU@"
|
||||||
|
#define GRUB_PLATFORM "@GRUB_PLATFORM@"
|
||||||
|
+#define GRUB_RPM_VERSION "@GRUB_RPM_VERSION@"
|
||||||
|
|
||||||
|
#define RE_ENABLE_I18N 1
|
||||||
|
|
74
0096-Add-more-dprintf-and-nerf-dprintf-in-script.c.patch
Normal file
74
0096-Add-more-dprintf-and-nerf-dprintf-in-script.c.patch
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Peter Jones <pjones@redhat.com>
|
||||||
|
Date: Tue, 11 Sep 2018 15:58:29 -0400
|
||||||
|
Subject: [PATCH] Add more dprintf, and nerf dprintf in script.c
|
||||||
|
|
||||||
|
Signed-off-by: Peter Jones <pjones@redhat.com>
|
||||||
|
---
|
||||||
|
grub-core/disk/diskfilter.c | 3 +++
|
||||||
|
grub-core/disk/efi/efidisk.c | 1 +
|
||||||
|
grub-core/kern/device.c | 1 +
|
||||||
|
grub-core/script/script.c | 5 +++++
|
||||||
|
4 files changed, 10 insertions(+)
|
||||||
|
|
||||||
|
diff --git a/grub-core/disk/diskfilter.c b/grub-core/disk/diskfilter.c
|
||||||
|
index 0320115662..7cdffe3ebd 100644
|
||||||
|
--- a/grub-core/disk/diskfilter.c
|
||||||
|
+++ b/grub-core/disk/diskfilter.c
|
||||||
|
@@ -188,6 +188,8 @@ scan_disk (const char *name, int accept_diskfilter)
|
||||||
|
grub_disk_t disk;
|
||||||
|
static int scan_depth = 0;
|
||||||
|
|
||||||
|
+ grub_dprintf ("diskfilter", "scanning %s\n", name);
|
||||||
|
+
|
||||||
|
if (!accept_diskfilter && is_valid_diskfilter_name (name))
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
@@ -1212,6 +1214,7 @@ insert_array (grub_disk_t disk, const struct grub_diskfilter_pv_id *id,
|
||||||
|
the same. */
|
||||||
|
if (pv->disk && grub_disk_native_sectors (disk) >= pv->part_size)
|
||||||
|
return GRUB_ERR_NONE;
|
||||||
|
+ grub_dprintf ("diskfilter", "checking %s\n", disk->name);
|
||||||
|
pv->disk = grub_disk_open (disk->name);
|
||||||
|
if (!pv->disk)
|
||||||
|
return grub_errno;
|
||||||
|
diff --git a/grub-core/disk/efi/efidisk.c b/grub-core/disk/efi/efidisk.c
|
||||||
|
index f077b5f553..fe8ba6e6c9 100644
|
||||||
|
--- a/grub-core/disk/efi/efidisk.c
|
||||||
|
+++ b/grub-core/disk/efi/efidisk.c
|
||||||
|
@@ -855,6 +855,7 @@ grub_efidisk_get_device_name (grub_efi_handle_t *handle)
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
+ grub_dprintf ("efidisk", "getting disk for %s\n", device_name);
|
||||||
|
parent = grub_disk_open (device_name);
|
||||||
|
grub_free (dup_dp);
|
||||||
|
|
||||||
|
diff --git a/grub-core/kern/device.c b/grub-core/kern/device.c
|
||||||
|
index 73b8ecc0c0..f58b58c89d 100644
|
||||||
|
--- a/grub-core/kern/device.c
|
||||||
|
+++ b/grub-core/kern/device.c
|
||||||
|
@@ -34,6 +34,7 @@ grub_device_open (const char *name)
|
||||||
|
{
|
||||||
|
grub_device_t dev = 0;
|
||||||
|
|
||||||
|
+ grub_dprintf ("device", "opening device %s\n", name);
|
||||||
|
if (! name)
|
||||||
|
{
|
||||||
|
name = grub_env_get ("root");
|
||||||
|
diff --git a/grub-core/script/script.c b/grub-core/script/script.c
|
||||||
|
index ec4d4337c6..844e8343ca 100644
|
||||||
|
--- a/grub-core/script/script.c
|
||||||
|
+++ b/grub-core/script/script.c
|
||||||
|
@@ -22,6 +22,11 @@
|
||||||
|
#include <grub/parser.h>
|
||||||
|
#include <grub/mm.h>
|
||||||
|
|
||||||
|
+#ifdef grub_dprintf
|
||||||
|
+#undef grub_dprintf
|
||||||
|
+#endif
|
||||||
|
+#define grub_dprintf(no, fmt, ...)
|
||||||
|
+
|
||||||
|
/* It is not possible to deallocate the memory when a syntax error was
|
||||||
|
found. Because of that it is required to keep track of all memory
|
||||||
|
allocations. The memory is freed in case of an error, or assigned
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user