Merge remote-tracking branch 'tvdw/from-the-archive'

This commit is contained in:
Nick Mathewson 2015-01-06 13:44:13 -05:00
commit 082bfd3b55

View File

@ -94,7 +94,7 @@ addressmap_ent_free(void *_ent)
tor_free(ent); tor_free(ent);
} }
/** Free storage held by a virtaddress_entry_t* entry in <b>ent</b>. */ /** Free storage held by a virtaddress_entry_t* entry in <b>_ent</b>. */
static void static void
addressmap_virtaddress_ent_free(void *_ent) addressmap_virtaddress_ent_free(void *_ent)
{ {
@ -104,11 +104,13 @@ addressmap_virtaddress_ent_free(void *_ent)
ent = _ent; ent = _ent;
tor_free(ent->ipv4_address); tor_free(ent->ipv4_address);
tor_free(ent->ipv6_address);
tor_free(ent->hostname_address); tor_free(ent->hostname_address);
tor_free(ent); tor_free(ent);
} }
/** Free storage held by a virtaddress_entry_t* entry in <b>ent</b>. */ /** Remove <b>address</b> (which must map to <b>ent</b>) from the
* virtual address map. */
static void static void
addressmap_virtaddress_remove(const char *address, addressmap_entry_t *ent) addressmap_virtaddress_remove(const char *address, addressmap_entry_t *ent)
{ {
@ -120,9 +122,11 @@ addressmap_virtaddress_remove(const char *address, addressmap_entry_t *ent)
if (ve) { if (ve) {
if (!strcmp(address, ve->ipv4_address)) if (!strcmp(address, ve->ipv4_address))
tor_free(ve->ipv4_address); tor_free(ve->ipv4_address);
if (!strcmp(address, ve->ipv6_address))
tor_free(ve->ipv6_address);
if (!strcmp(address, ve->hostname_address)) if (!strcmp(address, ve->hostname_address))
tor_free(ve->hostname_address); tor_free(ve->hostname_address);
if (!ve->ipv4_address && !ve->hostname_address) { if (!ve->ipv4_address && !ve->ipv6_address && !ve->hostname_address) {
tor_free(ve); tor_free(ve);
strmap_remove(virtaddress_reversemap, ent->new_address); strmap_remove(virtaddress_reversemap, ent->new_address);
} }
@ -131,7 +135,7 @@ addressmap_virtaddress_remove(const char *address, addressmap_entry_t *ent)
} }
/** Remove <b>ent</b> (which must be mapped to by <b>address</b>) from the /** Remove <b>ent</b> (which must be mapped to by <b>address</b>) from the
* client address maps. */ * client address maps, and then free it. */
static void static void
addressmap_ent_remove(const char *address, addressmap_entry_t *ent) addressmap_ent_remove(const char *address, addressmap_entry_t *ent)
{ {
@ -496,7 +500,7 @@ addressmap_have_mapping(const char *address, int update_expiry)
* equal to <b>address</b>, or any address ending with a period followed by * equal to <b>address</b>, or any address ending with a period followed by
* <b>address</b>. If <b>wildcard_addr</b> and <b>wildcard_new_addr</b> are * <b>address</b>. If <b>wildcard_addr</b> and <b>wildcard_new_addr</b> are
* both true, the mapping will rewrite addresses that end with * both true, the mapping will rewrite addresses that end with
* ".<b>address</b>" into ones that end with ".<b>new_address</b>." * ".<b>address</b>" into ones that end with ".<b>new_address</b>".
* *
* If <b>new_address</b> is NULL, or <b>new_address</b> is equal to * If <b>new_address</b> is NULL, or <b>new_address</b> is equal to
* <b>address</b> and <b>wildcard_addr</b> is equal to * <b>address</b> and <b>wildcard_addr</b> is equal to
@ -535,9 +539,9 @@ addressmap_register(const char *address, char *new_address, time_t expires,
if (expires > 1) { if (expires > 1) {
log_info(LD_APP,"Temporary addressmap ('%s' to '%s') not performed, " log_info(LD_APP,"Temporary addressmap ('%s' to '%s') not performed, "
"since it's already mapped to '%s'", "since it's already mapped to '%s'",
safe_str_client(address), safe_str_client(address),
safe_str_client(new_address), safe_str_client(new_address),
safe_str_client(ent->new_address)); safe_str_client(ent->new_address));
tor_free(new_address); tor_free(new_address);
return; return;
} }
@ -839,8 +843,8 @@ get_random_virtual_addr(const virtual_addr_conf_t *conf, tor_addr_t *addr_out)
} }
/** Return a newly allocated string holding an address of <b>type</b> /** Return a newly allocated string holding an address of <b>type</b>
* (one of RESOLVED_TYPE_{IPV4|HOSTNAME}) that has not yet been mapped, * (one of RESOLVED_TYPE_{IPV4|IPV6|HOSTNAME}) that has not yet been
* and that is very unlikely to be the address of any real host. * mapped, and that is very unlikely to be the address of any real host.
* *
* May return NULL if we have run out of virtual addresses. * May return NULL if we have run out of virtual addresses.
*/ */