diff options
author | Nick Mathewson <nickm@torproject.org> | 2008-08-05 20:08:19 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2008-08-05 20:08:19 +0000 |
commit | 960a0f0a994ba23480e14ffe5179160194fd9616 (patch) | |
tree | 250494775699fda2f0f543a350b02e89c5a77a03 /src/or/dns.c | |
parent | 750bb795ac1fcb5b76b6488690400c77fbff0a3f (diff) | |
download | tor-960a0f0a994ba23480e14ffe5179160194fd9616.tar.gz tor-960a0f0a994ba23480e14ffe5179160194fd9616.zip |
r17641@31-33-44: nickm | 2008-08-05 16:07:53 -0400
Initial conversion of uint32_t addr to tor_addr_t addr in connection_t and related types. Most of the Tor wire formats using these new types are in, but the code to generate and use it is not. This is a big patch. Let me know what it breaks for you.
svn:r16435
Diffstat (limited to 'src/or/dns.c')
-rw-r--r-- | src/or/dns.c | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/src/or/dns.c b/src/or/dns.c index 5af868b27b..16673e2d2a 100644 --- a/src/or/dns.c +++ b/src/or/dns.c @@ -78,6 +78,7 @@ typedef struct cached_resolve_t { uint32_t magic; char address[MAX_ADDRESSLEN]; /**< The hostname to be resolved. */ union { + /*XXXX021 Make this use a tor_addr_t OP6 */ uint32_t addr; /**< IPv4 addr for <b>address</b>. */ char *hostname; /**< Hostname for <b>address</b> (if a reverse lookup) */ } result; @@ -420,10 +421,11 @@ send_resolved_cell(edge_connection_t *conn, uint8_t answer_type) { case RESOLVED_TYPE_IPV4: buf[1] = 4; - set_uint32(buf+2, htonl(conn->_base.addr)); + set_uint32(buf+2, tor_addr_to_ipv4n(&conn->_base.addr)); set_uint32(buf+6, htonl(ttl)); buflen = 10; break; + /*XXXX021 IP6 need ipv6 implementation */ case RESOLVED_TYPE_ERROR_TRANSIENT: case RESOLVED_TYPE_ERROR: { @@ -644,7 +646,7 @@ dns_resolve_impl(edge_connection_t *exitconn, int is_resolve, /* first check if exitconn->_base.address is an IP. If so, we already * know the answer. */ if (tor_inet_aton(exitconn->_base.address, &in) != 0) { - exitconn->_base.addr = ntohl(in.s_addr); + tor_addr_from_ipv4n(&exitconn->_base.addr, in.s_addr); exitconn->address_ttl = DEFAULT_DNS_TTL; return 1; } @@ -714,7 +716,7 @@ dns_resolve_impl(edge_connection_t *exitconn, int is_resolve, tor_assert(is_resolve); *hostname_out = tor_strdup(resolve->result.hostname); } else { - exitconn->_base.addr = resolve->result.addr; + tor_addr_from_ipv4h(&exitconn->_base.addr, resolve->result.addr); } return 1; case CACHE_STATE_CACHED_FAILED: @@ -1017,7 +1019,7 @@ dns_found_answer(const char *address, uint8_t is_reverse, uint32_t addr, pendconn = pend->conn; /* don't pass complex things to the connection_mark_for_close macro */ assert_connection_ok(TO_CONN(pendconn),time(NULL)); - pendconn->_base.addr = addr; + tor_addr_from_ipv4h(&pendconn->_base.addr, addr); pendconn->address_ttl = ttl; if (outcome != DNS_RESOLVE_SUCCEEDED) { |