summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2020-10-07 08:08:02 -0400
committerNick Mathewson <nickm@torproject.org>2020-10-07 08:08:02 -0400
commit8505dd5e372a055014b9305171a5b4b707746120 (patch)
tree2842b86de8797a8335b65c65e2ce5496a186b90d
parent30c6b42d3447bb8c00eba7fc1c53cb5b2c5ecbc5 (diff)
parent902944448206d359d3f799ecf8a504bdff493272 (diff)
downloadtor-8505dd5e372a055014b9305171a5b4b707746120.tar.gz
tor-8505dd5e372a055014b9305171a5b4b707746120.zip
Merge branch 'maint-0.4.3' into maint-0.4.4
-rw-r--r--changes/ticket400733
-rw-r--r--src/core/mainloop/connection.c9
2 files changed, 11 insertions, 1 deletions
diff --git a/changes/ticket40073 b/changes/ticket40073
new file mode 100644
index 0000000000..30b028c042
--- /dev/null
+++ b/changes/ticket40073
@@ -0,0 +1,3 @@
+ o Minor bugfixes (relay configuration, crash):
+ - Avoid a fatal assert() when failing to create a listener connection for an
+ address that was in use. Fixes bug 40073; bugfix on 0.3.5.1-alpha.
diff --git a/src/core/mainloop/connection.c b/src/core/mainloop/connection.c
index fd5bf879c5..36b2c6ef63 100644
--- a/src/core/mainloop/connection.c
+++ b/src/core/mainloop/connection.c
@@ -3048,7 +3048,14 @@ retry_all_listeners(smartlist_t *new_conns, int close_all_noncontrol)
&skip, &addr_in_use);
}
- tor_assert(new_conn);
+ /* There are many reasons why we can't open a new listener port so in case
+ * we hit those, bail early so tor can stop. */
+ if (!new_conn) {
+ log_warn(LD_NET, "Unable to create listener port: %s:%d",
+ fmt_addr(&r->new_port->addr), r->new_port->port);
+ retval = -1;
+ break;
+ }
smartlist_add(new_conns, new_conn);