42 lines
1.0 KiB
Diff
42 lines
1.0 KiB
Diff
|
From 4dbf9c7e15420eb06540bb426bf36c434787e344 Mon Sep 17 00:00:00 2001
|
||
|
From: Yannick Brosseau <scientist@fb.com>
|
||
|
Date: Thu, 3 Jul 2014 13:55:19 -0700
|
||
|
Subject: [PATCH 1/9] Don't go past the last element of indexVars in
|
||
|
findEntryByPath
|
||
|
|
||
|
We add a chance of creating an infinite loop, because we
|
||
|
were reading memory past the last element of indexVars set to -1.
|
||
|
|
||
|
This issue was only apparent with -O2, probably because the way the
|
||
|
memory was initialized.
|
||
|
|
||
|
Signed-off-by: Yannick Brosseau <scientist@fb.com>
|
||
|
---
|
||
|
grubby.c | 8 +++++---
|
||
|
1 file changed, 5 insertions(+), 3 deletions(-)
|
||
|
|
||
|
diff --git a/grubby.c b/grubby.c
|
||
|
index 88a1f08..db91364 100644
|
||
|
--- a/grubby.c
|
||
|
+++ b/grubby.c
|
||
|
@@ -1959,11 +1959,13 @@ struct singleEntry * findEntryByPath(struct grubConfig * config,
|
||
|
}
|
||
|
|
||
|
indexVars[i + 1] = -1;
|
||
|
-
|
||
|
+
|
||
|
i = 0;
|
||
|
if (index) {
|
||
|
- while (i < *index) i++;
|
||
|
- if (indexVars[i] == -1) return NULL;
|
||
|
+ while (i < *index) {
|
||
|
+ i++;
|
||
|
+ if (indexVars[i] == -1) return NULL;
|
||
|
+ }
|
||
|
}
|
||
|
|
||
|
entry = findEntryByIndex(config, indexVars[i]);
|
||
|
--
|
||
|
1.9.3
|
||
|
|