|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
From 9418ba6d05feed6061f5343741b1bc56e7bde663 Mon Sep 17 00:00:00 2001
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
From: Karel Zak <kzak@redhat.com>
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
Date: Fri, 20 Dec 2019 15:05:33 +0100
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
Subject: [PATCH] agetty: keep freed issue file pointer zeroized
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
References: https://bugzilla.redhat.com/show_bug.cgi?id=1784536
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
Signed-off-by: Karel Zak <kzak@redhat.com>
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
---
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
term-utils/agetty.c | 15 +++++++++++----
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
1 file changed, 11 insertions(+), 4 deletions(-)
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
diff --git a/term-utils/agetty.c b/term-utils/agetty.c
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
index 3c20acc98..dfc4921f5 100644
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
--- a/term-utils/agetty.c
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
+++ b/term-utils/agetty.c
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
@@ -1820,8 +1820,12 @@ static int issuefile_read_stream(
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
if (fstat(fileno(f), &st) || !S_ISREG(st.st_mode))
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
return 1;
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
- if (!ie->output)
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
- ie->output = open_memstream(&ie->mem, &ie->mem_sz);
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
+ if (!ie->output) {
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
+ free(ie->mem);
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
+ ie->mem_sz = 0;
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
+ ie->mem = NULL;
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
+ ie->output = open_memstream(&ie->mem, &ie->mem_sz);
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
+ }
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
while ((c = getc(f)) != EOF) {
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
if (c == '\\')
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
@@ -1965,8 +1969,10 @@ done:
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
if (netlink_groups != 0)
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
open_netlink();
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
#endif
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
- if (ie->output)
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
+ if (ie->output) {
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
fclose(ie->output);
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
+ ie->output = NULL;
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
+ }
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
}
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
/* This is --show-issue backend, executed by normal user on the current
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
@@ -1985,7 +1991,8 @@ static void show_issue(struct options *op)
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
if (ie.mem_sz)
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
write_all(STDOUT_FILENO, ie.mem, ie.mem_sz);
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
-
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
+ if (ie.output)
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
+ fclose(ie.output);
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
free(ie.mem);
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
}
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
--
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
2.21.0
|
|
![](https://seccdn.libravatar.org/avatar/e0034d87af3e72eecdfa3848707ecc6cc2339078b68d48c05dbaf7e20bf477b2?s=16&d=retro) |
5972c3 |
|