diff options
author | Nick Mathewson <nickm@torproject.org> | 2017-08-04 12:26:35 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2017-08-04 12:26:35 -0400 |
commit | 89407bedf8980b9dd7a10b268b351e8b2938ac80 (patch) | |
tree | 014527f8ae273f5e01e813817f3fd2c5df0cc6cb /src/common | |
parent | bfe740f0658dc05e9cc624a46ae21bb098117197 (diff) | |
download | tor-89407bedf8980b9dd7a10b268b351e8b2938ac80.tar.gz tor-89407bedf8980b9dd7a10b268b351e8b2938ac80.zip |
Tweak usage of get_current_working_dir() for tor_malloc() paranoia.
We assume that tor_free() is not required to be compatible with
the platform malloc(), so we need to use a strdup here.
Diffstat (limited to 'src/common')
-rw-r--r-- | src/common/compat.c | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/src/common/compat.c b/src/common/compat.c index 8e3d97420a..f5991a640f 100644 --- a/src/common/compat.c +++ b/src/common/compat.c @@ -2350,7 +2350,15 @@ static char * alloc_getcwd(void) { #ifdef HAVE_GET_CURRENT_DIR_NAME - return get_current_dir_name(); + /* Glibc makes this nice and simple for us. */ + char *cwd = get_current_dir_name(); + char *result = NULL; + if (cwd) { + /* We make a copy here, in case tor_malloc() is not malloc(). */ + result = tor_strdup(cwd); + raw_free(cwd); // alias for free to avoid tripping check-spaces. + } + return result; #else size_t size = 1024; char *buf = NULL; |