public inbox for grub-devel@gnu.org
 help / color / mirror / Atom feed
* [PATCH] blsuki: Fix grub_errno leakage in blsuki_is_default_entry()
@ 2025-11-10  7:38 Michael Chang via Grub-devel
  2025-11-10 13:35 ` Sudhakar Kuppusamy
                   ` (3 more replies)
  0 siblings, 4 replies; 10+ messages in thread
From: Michael Chang via Grub-devel @ 2025-11-10  7:38 UTC (permalink / raw)
  To: The development of GNU GRUB; +Cc: Michael Chang

The grub_strtol() call in blsuki_is_default_entry() can set grub_errno
to GRUB_ERR_BAD_NUMBER if the input string cannot be converted into any
valid digits.

This errno value is currently left uncleared, which can lead to
unexpected behavior in subsequent logic that tests the result of a
function by checking grub_errno.

Clear grub_errno and return false when GRUB_ERR_BAD_NUMBER is set, as
this specific error should be ignored in this context.

Signed-off-by: Michael Chang <mchang@suse.com>
---
 grub-core/commands/blsuki.c | 6 ++++++
 1 file changed, 6 insertions(+)

diff --git a/grub-core/commands/blsuki.c b/grub-core/commands/blsuki.c
index 21d767f05..df25b6fbc 100644
--- a/grub-core/commands/blsuki.c
+++ b/grub-core/commands/blsuki.c
@@ -1510,6 +1510,12 @@ blsuki_is_default_entry (const char *def_entry, grub_blsuki_entry_t *entry, int
     return true;
 
   def_idx = grub_strtol (def_entry, &def_entry_end, 0);
+  if (grub_errno == GRUB_ERR_BAD_NUMBER)
+    {
+      grub_errno = GRUB_ERR_NONE;
+      return false;
+    }
+
   if (*def_entry_end != '\0' || def_idx < 0 || def_idx > GRUB_INT_MAX)
     return false;
 
-- 
2.51.1


_______________________________________________
Grub-devel mailing list
Grub-devel@gnu.org
https://lists.gnu.org/mailman/listinfo/grub-devel

^ permalink raw reply related	[flat|nested] 10+ messages in thread

end of thread, other threads:[~2025-11-11  4:38 UTC | newest]

Thread overview: 10+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
     [not found] <mailman.2112.1762781770.1058.grub-devel@gnu.org>
2025-11-10 15:04 ` [PATCH] blsuki: Fix grub_errno leakage in blsuki_is_default_entry() Avnish Chouhan
2025-11-11  4:37   ` Michael Chang via Grub-devel
2025-11-10  7:38 Michael Chang via Grub-devel
2025-11-10 13:35 ` Sudhakar Kuppusamy
2025-11-11  4:38   ` Michael Chang via Grub-devel
2025-11-10 14:55 ` Michael Lawnick via Grub-devel
2025-11-11  4:18   ` Michael Chang via Grub-devel
2025-11-10 17:26 ` Alec Brown via Grub-devel
2025-11-11  4:36   ` Michael Chang via Grub-devel
2025-11-11  4:21 ` Michael Chang via Grub-devel

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox