mirror of
https://src.fedoraproject.org/rpms/grub2.git
synced 2024-11-24 14:32:58 +00:00
11b49b804e
- Don't build the grub2-efi-ia32-* packages on i686 (pjones) - Add efi-export-env and efi-load-env commands (pjones) - Make it possible to subtract conditions from debug= (pjones) - Try to set -fPIE and friends on libgnu.a (pjones) - Add more options to blscfg command to make it more flexible - Add support for prepend early initrds to the BLS entries - Fix grub.cfg-XXX look up when booting over TFTP Signed-off-by: Javier Martinez Canillas <javierm@redhat.com>
42 lines
1.6 KiB
Diff
42 lines
1.6 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Masayoshi Mizuma <m.mizuma@jp.fujitsu.com>
|
|
Date: Tue, 18 Dec 2018 21:27:45 -0500
|
|
Subject: [PATCH] Fix the looking up grub.cfg-XXX while tftp booting.
|
|
|
|
Currently, grub doesn't look up grub.cfg-UUID, grub.cfg-MAC and grub.cfg-IP
|
|
while the boot is from tftp. That is because the uuid size is got by
|
|
grub_snprintf(, 0, ,), but the grub_snprintf() always returns 0,
|
|
so grub judges there's no available uuid in the client and give up
|
|
the looking up grub.cfg-XXX.
|
|
|
|
This issue can be fixed by changing grub_snprintf(, 0, ,) behaivior
|
|
to like as snprintf() from glibc, however, somewhere may expect
|
|
such argument as the error, so it's risky.
|
|
|
|
Let's use sizeof() and grub_strlen() to calculate the uuid size
|
|
instead of grub_snprintf().
|
|
|
|
Resolves: rhbz#1658500
|
|
---
|
|
grub-core/net/net.c | 8 +++-----
|
|
1 file changed, 3 insertions(+), 5 deletions(-)
|
|
|
|
diff --git a/grub-core/net/net.c b/grub-core/net/net.c
|
|
index a011b940100..19ff2d486a1 100644
|
|
--- a/grub-core/net/net.c
|
|
+++ b/grub-core/net/net.c
|
|
@@ -1942,11 +1942,9 @@ grub_net_search_configfile (char *config)
|
|
char *client_uuid_var;
|
|
grub_size_t client_uuid_var_size;
|
|
|
|
- client_uuid_var_size = grub_snprintf (NULL, 0,
|
|
- "net_%s_clientuuid", inf->name);
|
|
- if (client_uuid_var_size <= 0)
|
|
- continue;
|
|
- client_uuid_var_size += 1;
|
|
+ client_uuid_var_size = sizeof ("net_") + grub_strlen (inf->name) +
|
|
+ sizeof ("_clientuuid") + 1;
|
|
+
|
|
client_uuid_var = grub_malloc(client_uuid_var_size);
|
|
if (!client_uuid_var)
|
|
continue;
|