summaryrefslogtreecommitdiff
path: root/c++tools
diff options
context:
space:
mode:
authorJonathan Wakely <jwakely@redhat.com>2021-10-21 22:32:23 +0100
committerJonathan Wakely <jwakely@redhat.com>2021-10-26 18:16:31 +0100
commitc9bf4d4354b942af00193924cb59c4c6ab9cc4b5 (patch)
tree1a7a061fe92252fd71adea9385e9ee07749185f0 /c++tools
parent7d37abedf58d664ccb9c06272303a10021ee36a7 (diff)
downloadgcc-c9bf4d4354b942af00193924cb59c4c6ab9cc4b5.tar.gz
c++tools: Fix memory leak
The allocated memory is not freed when returning early due to an error. c++tools/ChangeLog: * resolver.cc (module_resolver::read_tuple_file): Use unique_ptr to ensure memory is freed before returning.
Diffstat (limited to 'c++tools')
-rw-r--r--c++tools/resolver.cc14
1 files changed, 8 insertions, 6 deletions
diff --git a/c++tools/resolver.cc b/c++tools/resolver.cc
index 421fdaa55fe..a1837b3ee10 100644
--- a/c++tools/resolver.cc
+++ b/c++tools/resolver.cc
@@ -23,6 +23,7 @@ along with GCC; see the file COPYING3. If not see
#include "resolver.h"
// C++
#include <algorithm>
+#include <memory>
// C
#include <cstring>
// OS
@@ -114,10 +115,17 @@ module_resolver::read_tuple_file (int fd, char const *prefix, bool force)
buffer = mmap (nullptr, stat.st_size, PROT_READ, MAP_PRIVATE, fd, 0);
if (buffer == MAP_FAILED)
return -errno;
+ struct Deleter {
+ void operator()(void* p) const { munmap(p, size); }
+ size_t size;
+ };
+ std::unique_ptr<void, Deleter> guard(buffer, Deleter{(size_t)stat.st_size});
#else
buffer = xmalloc (stat.st_size);
if (!buffer)
return -errno;
+ struct Deleter { void operator()(void* p) const { free(p); } };
+ std::unique_ptr<void, Deleter> guard(buffer);
if (read (fd, buffer, stat.st_size) != stat.st_size)
return -errno;
#endif
@@ -179,12 +187,6 @@ module_resolver::read_tuple_file (int fd, char const *prefix, bool force)
}
}
-#if MAPPED_READING
- munmap (buffer, stat.st_size);
-#else
- free (buffer);
-#endif
-
return 0;
}