]> git.ipfire.org Git - thirdparty/tor.git/commitdiff
Fix a rare memory leak in rend_cache_store
authorNick Mathewson <nickm@torproject.org>
Fri, 1 Jul 2011 15:52:39 +0000 (11:52 -0400)
committerNick Mathewson <nickm@torproject.org>
Fri, 1 Jul 2011 16:54:19 +0000 (12:54 -0400)
When we rejected a descriptor for not being the one we wanted, we
were letting the parsed descriptor go out of scope.

Found by Coverity; CID # 30.

Bugfix on 0.2.1.26.

(No changes file yet, since this is not in any 0.2.1.x release.)

src/or/rendcommon.c

index 8727a70c2ea43d93de5f405ee4911261df457fcb..e0c101e1ee27eed5200e5fd8bc4f2f5b99dc7360 100644 (file)
@@ -1077,6 +1077,7 @@ rend_cache_store(const char *desc, size_t desc_len, int published,
     log_warn(LD_REND, "Received service descriptor for service ID %s; "
              "expected descriptor for service ID %s.",
              query, safe_str(service_id));
+    rend_service_descriptor_free(parsed);
     return -2;
   }
   now = time(NULL);