summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2018-07-03 13:31:18 -0400
committerNick Mathewson <nickm@torproject.org>2018-07-03 13:31:18 -0400
commit5b0820702a213226d2cce47dae1da5e72a16bc82 (patch)
tree89c9d21c239f523b3c4834ee1a8563cf2ba93480
parent9b060547ce3dec290ce4a02f9aa54d11b0939e0b (diff)
parent32d9d69350f7fac564f4f4a245c57edd2e5c309a (diff)
downloadtor-5b0820702a213226d2cce47dae1da5e72a16bc82.tar.gz
tor-5b0820702a213226d2cce47dae1da5e72a16bc82.zip
Merge branch 'maint-0.3.4' into release-0.3.4
-rw-r--r--changes/bug265683
-rw-r--r--src/or/connection.c5
2 files changed, 7 insertions, 1 deletions
diff --git a/changes/bug26568 b/changes/bug26568
new file mode 100644
index 0000000000..0c4c05d043
--- /dev/null
+++ b/changes/bug26568
@@ -0,0 +1,3 @@
+ o Minor bugfixes (controller):
+ - Report the port correctly when a port is configured to bind to "auto".
+ Fixes bug 26568; bugfix on 0.3.4.1-alpha.
diff --git a/src/or/connection.c b/src/or/connection.c
index 5185b45b14..7283a81043 100644
--- a/src/or/connection.c
+++ b/src/or/connection.c
@@ -1260,12 +1260,15 @@ connection_listener_new(const struct sockaddr *listensockaddr,
gotPort = usePort;
} else {
tor_addr_t addr2;
- if (tor_addr_from_getsockname(&addr2, s)<0) {
+ struct sockaddr_storage ss;
+ socklen_t ss_len=sizeof(ss);
+ if (getsockname(s, (struct sockaddr*)&ss, &ss_len)<0) {
log_warn(LD_NET, "getsockname() couldn't learn address for %s: %s",
conn_type_to_string(type),
tor_socket_strerror(tor_socket_errno(s)));
gotPort = 0;
}
+ tor_addr_from_sockaddr(&addr2, (struct sockaddr*)&ss, &gotPort);
}
#ifdef HAVE_SYS_UN_H
/*