|
|
38ab4d |
From 7bb264df83a5e1f6182bb73594a058c1d3b7dc29 Mon Sep 17 00:00:00 2001
|
|
|
5fb29d |
From: Peter Jones <pjones@redhat.com>
|
|
|
5fb29d |
Date: Wed, 10 Sep 2014 15:32:59 -0400
|
|
|
38ab4d |
Subject: [PATCH 04/31] Don't leak our socket's fd when determining network
|
|
|
5fb29d |
info.
|
|
|
5fb29d |
|
|
|
5fb29d |
Covscan again.
|
|
|
5fb29d |
|
|
|
5fb29d |
Signed-off-by: Peter Jones <pjones@redhat.com>
|
|
|
5fb29d |
---
|
|
|
5fb29d |
src/lib/efi.c | 8 +++++++-
|
|
|
5fb29d |
1 file changed, 7 insertions(+), 1 deletion(-)
|
|
|
5fb29d |
|
|
|
5fb29d |
diff --git a/src/lib/efi.c b/src/lib/efi.c
|
|
|
5fb29d |
index 6b25dfe..8ba0e54 100644
|
|
|
5fb29d |
--- a/src/lib/efi.c
|
|
|
5fb29d |
+++ b/src/lib/efi.c
|
|
|
5fb29d |
@@ -631,13 +631,16 @@ make_net_load_option(char *iface, uint8_t *buf, size_t size)
|
|
|
5fb29d |
err = ioctl(fd, SIOCETHTOOL, &ifr);
|
|
|
5fb29d |
if (err < 0) {
|
|
|
5fb29d |
perror("Cannot get driver information");
|
|
|
5fb29d |
+ close(fd);
|
|
|
5fb29d |
return -1;
|
|
|
5fb29d |
}
|
|
|
5fb29d |
|
|
|
5fb29d |
if (strncmp(drvinfo.bus_info, "virtio", 6) == 0) {
|
|
|
5fb29d |
err = get_virt_pci(drvinfo.bus_info, &bus, &slot, &func);
|
|
|
5fb29d |
- if (err < 0)
|
|
|
5fb29d |
+ if (err < 0) {
|
|
|
5fb29d |
+ close(fd);
|
|
|
5fb29d |
return err;
|
|
|
5fb29d |
+ }
|
|
|
5fb29d |
} else {
|
|
|
5fb29d |
/* The domain part was added in 2.6 kernels.
|
|
|
5fb29d |
* Test for that first. */
|
|
|
5fb29d |
@@ -648,6 +651,7 @@ make_net_load_option(char *iface, uint8_t *buf, size_t size)
|
|
|
5fb29d |
&bus, &slot, &func);
|
|
|
5fb29d |
if (err != 3) {
|
|
|
5fb29d |
perror("Couldn't parse device location string.");
|
|
|
5fb29d |
+ close(fd);
|
|
|
5fb29d |
return -1;
|
|
|
5fb29d |
}
|
|
|
5fb29d |
}
|
|
|
5fb29d |
@@ -655,9 +659,11 @@ make_net_load_option(char *iface, uint8_t *buf, size_t size)
|
|
|
5fb29d |
|
|
|
5fb29d |
err = ioctl(fd, SIOCGIFHWADDR, &ifr);
|
|
|
5fb29d |
if (err < 0) {
|
|
|
5fb29d |
+ close(fd);
|
|
|
5fb29d |
perror("Cannot get hardware address.");
|
|
|
5fb29d |
return -1;
|
|
|
5fb29d |
}
|
|
|
5fb29d |
+ close(fd);
|
|
|
5fb29d |
|
|
|
5fb29d |
buf_offset = 0;
|
|
|
5fb29d |
needed = make_acpi_device_path(opts.acpi_hid, opts.acpi_uid, buf,
|
|
|
5fb29d |
--
|
|
|
38ab4d |
2.7.4
|
|
|
5fb29d |
|