summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2018-07-12 14:20:56 -0400
committerNick Mathewson <nickm@torproject.org>2018-07-12 14:20:56 -0400
commit04512d9fcd03bde1cedfa09f208a4c410172fe22 (patch)
tree75f6ca2979e6741a2b77e5075cfd75362f72b06a
parent2d0e1cef20036412ed57c287553623293ab65031 (diff)
downloadtor-04512d9fcd03bde1cedfa09f208a4c410172fe22.tar.gz
tor-04512d9fcd03bde1cedfa09f208a4c410172fe22.zip
SOCKS: Always free username/password before setting them.
This fixes a memory leak found by fuzzing.
-rw-r--r--src/core/proto/proto_socks.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/src/core/proto/proto_socks.c b/src/core/proto/proto_socks.c
index 530436c41b..9cc9568a41 100644
--- a/src/core/proto/proto_socks.c
+++ b/src/core/proto/proto_socks.c
@@ -174,6 +174,7 @@ parse_socks4_request(const uint8_t *raw_data, socks_request_t *req,
goto end;
}
+ tor_free(req->username);
req->got_auth = 1;
req->username = tor_strdup(username);
req->usernamelen = usernamelen;
@@ -445,6 +446,7 @@ parse_socks5_userpass_auth(const uint8_t *raw_data, socks_request_t *req,
socks5_client_userpass_auth_getconstarray_passwd(trunnel_req);
if (usernamelen && username) {
+ tor_free(req->username);
req->username = tor_memdup_nulterm(username, usernamelen);
req->usernamelen = usernamelen;
@@ -452,6 +454,7 @@ parse_socks5_userpass_auth(const uint8_t *raw_data, socks_request_t *req,
}
if (passwordlen && password) {
+ tor_free(req->password);
req->password = tor_memdup_nulterm(password, passwordlen);
req->passwordlen = passwordlen;