diff options
author | Sebastian Hahn <sebastian@torproject.org> | 2011-03-05 15:20:55 +0100 |
---|---|---|
committer | Sebastian Hahn <sebastian@torproject.org> | 2011-03-05 16:58:20 +0100 |
commit | f83debb51d7fa4a1827967d8bea145636c855f89 (patch) | |
tree | 3fcedc47a6f0e11bacd5540c6eb6de787988a414 /src/common | |
parent | 865ea5d26361802d53c586d27f249e5c2e924538 (diff) | |
download | tor-f83debb51d7fa4a1827967d8bea145636c855f89.tar.gz tor-f83debb51d7fa4a1827967d8bea145636c855f89.zip |
Fix setting target port in get_interface_address6
We want to use the discard port correctly, so a htons() was missing.
Also we need to set it correctly depending on address family.
Review provided by danieldg
Diffstat (limited to 'src/common')
-rw-r--r-- | src/common/address.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/src/common/address.c b/src/common/address.c index 90beae0da3..a2780fb051 100644 --- a/src/common/address.c +++ b/src/common/address.c @@ -1031,18 +1031,20 @@ get_interface_address6(int severity, sa_family_t family, tor_addr_t *addr) memset(addr, 0, sizeof(tor_addr_t)); memset(&target_addr, 0, sizeof(target_addr)); - /* Use the "discard" service port */ - ((struct sockaddr_in*)&target_addr)->sin_port = 9; /* Don't worry: no packets are sent. We just need to use a real address * on the actual Internet. */ if (family == AF_INET6) { struct sockaddr_in6 *sin6 = (struct sockaddr_in6*)&target_addr; + /* Use the "discard" service port */ + sin6->sin6_port = htons(9); sock = tor_open_socket(PF_INET6,SOCK_DGRAM,IPPROTO_UDP); addr_len = (socklen_t)sizeof(struct sockaddr_in6); sin6->sin6_family = AF_INET6; S6_ADDR16(sin6->sin6_addr)[0] = htons(0x2002); /* 2002:: */ } else if (family == AF_INET) { struct sockaddr_in *sin = (struct sockaddr_in*)&target_addr; + /* Use the "discard" service port */ + sin->sin_port = htons(9); sock = tor_open_socket(PF_INET,SOCK_DGRAM,IPPROTO_UDP); addr_len = (socklen_t)sizeof(struct sockaddr_in); sin->sin_family = AF_INET; |