summaryrefslogtreecommitdiffstats
path: root/meta/recipes-bsp/grub/files/0029-normal-completion-Fix-leaking-of-memory-when-process.patch
diff options
context:
space:
mode:
Diffstat (limited to 'meta/recipes-bsp/grub/files/0029-normal-completion-Fix-leaking-of-memory-when-process.patch')
-rw-r--r--meta/recipes-bsp/grub/files/0029-normal-completion-Fix-leaking-of-memory-when-process.patch52
1 files changed, 52 insertions, 0 deletions
diff --git a/meta/recipes-bsp/grub/files/0029-normal-completion-Fix-leaking-of-memory-when-process.patch b/meta/recipes-bsp/grub/files/0029-normal-completion-Fix-leaking-of-memory-when-process.patch
new file mode 100644
index 0000000000..8a26e5bc5b
--- /dev/null
+++ b/meta/recipes-bsp/grub/files/0029-normal-completion-Fix-leaking-of-memory-when-process.patch
@@ -0,0 +1,52 @@
1From 2367049d2021e00d82d19cee923e06a4b04ebc30 Mon Sep 17 00:00:00 2001
2From: Darren Kenny <darren.kenny@oracle.com>
3Date: Fri, 4 Dec 2020 18:56:48 +0000
4Subject: [PATCH] normal/completion: Fix leaking of memory when processing a
5 completion
6
7It is possible for the code to reach the end of the function without
8freeing the memory allocated to argv and argc still to be 0.
9
10We should always call grub_free(argv). The grub_free() will handle
11a NULL argument correctly if it reaches that code without the memory
12being allocated.
13
14Fixes: CID 96672
15
16Signed-off-by: Darren Kenny <darren.kenny@oracle.com>
17Reviewed-by: Daniel Kiper <daniel.kiper@oracle.com>
18
19Upstream-Status: Backport [https://git.savannah.gnu.org/cgit/grub.git/commit/?id=9213575b7a95b514bce80be5964a28d407d7d56d]
20Signed-off-by: Marta Rybczynska <marta.rybczynska@huawei.com>
21---
22 grub-core/normal/completion.c | 10 ++++------
23 1 file changed, 4 insertions(+), 6 deletions(-)
24
25diff --git a/grub-core/normal/completion.c b/grub-core/normal/completion.c
26index 5961028..46e473c 100644
27--- a/grub-core/normal/completion.c
28+++ b/grub-core/normal/completion.c
29@@ -400,8 +400,8 @@ char *
30 grub_normal_do_completion (char *buf, int *restore,
31 void (*hook) (const char *, grub_completion_type_t, int))
32 {
33- int argc;
34- char **argv;
35+ int argc = 0;
36+ char **argv = NULL;
37
38 /* Initialize variables. */
39 match = 0;
40@@ -516,10 +516,8 @@ grub_normal_do_completion (char *buf, int *restore,
41
42 fail:
43 if (argc != 0)
44- {
45- grub_free (argv[0]);
46- grub_free (argv);
47- }
48+ grub_free (argv[0]);
49+ grub_free (argv);
50 grub_free (match);
51 grub_errno = GRUB_ERR_NONE;
52