aboutsummaryrefslogtreecommitdiffstats
path: root/tools
diff options
context:
space:
mode:
authorKevin Darbyshire-Bryant <ldir@darbyshire-bryant.me.uk>2021-05-16 11:46:32 +0100
committerPetr Štetiar <ynezz@true.cz>2021-06-10 17:09:35 +0200
commit27f4559281fb9f6a4d8ec5e054cea7f4c6b77820 (patch)
tree2979f413e03a0cd620fefd3b4d712bdd615a5bcc /tools
parentdd6f02a3f4b70c82b45e1156cbe1edc833f683b4 (diff)
downloadupstream-27f4559281fb9f6a4d8ec5e054cea7f4c6b77820.tar.gz
upstream-27f4559281fb9f6a4d8ec5e054cea7f4c6b77820.tar.bz2
upstream-27f4559281fb9f6a4d8ec5e054cea7f4c6b77820.zip
firmware-utils: fix coverity zytrx.c resource leak
fix coverity resource leak warning: *len = stat.st_size; mapped = mmap(NULL, stat.st_size, PROT_READ, MAP_SHARED, fd, 0); if (close(fd) < 0) CID 1484880: Resource leaks (RESOURCE_LEAK) Variable "mapped" going out of scope leaks the storage it points to. return NULL; return mapped; } Signed-off-by: Kevin Darbyshire-Bryant <ldir@darbyshire-bryant.me.uk> (cherry picked from commit baf2a50ef3cf34574e12d2ab1b23578310f0d527)
Diffstat (limited to 'tools')
-rw-r--r--tools/firmware-utils/src/zytrx.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/tools/firmware-utils/src/zytrx.c b/tools/firmware-utils/src/zytrx.c
index 302efc6010..7167679206 100644
--- a/tools/firmware-utils/src/zytrx.c
+++ b/tools/firmware-utils/src/zytrx.c
@@ -150,8 +150,10 @@ static void *map_input(const char *name, size_t *len)
}
*len = stat.st_size;
mapped = mmap(NULL, stat.st_size, PROT_READ, MAP_SHARED, fd, 0);
- if (close(fd) < 0)
+ if (close(fd) < 0) {
+ (void) munmap(mapped, stat.st_size);
return NULL;
+ }
return mapped;
}