[tor-commits] [tor/master] Write a comment to explain may_need_rebind condition
nickm at torproject.org
nickm at torproject.org
Tue Oct 16 21:29:54 UTC 2018
commit 89c4a3a0b6f824841ab03d39ca59acc73a80b728
Author: rl1987 <rl1987 at sdf.lonestar.org>
Date: Mon Oct 15 16:13:22 2018 +0300
Write a comment to explain may_need_rebind condition
---
src/core/mainloop/connection.c | 9 +++++++++
1 file changed, 9 insertions(+)
diff --git a/src/core/mainloop/connection.c b/src/core/mainloop/connection.c
index 5ebfac6be..5c0799fbe 100644
--- a/src/core/mainloop/connection.c
+++ b/src/core/mainloop/connection.c
@@ -2797,6 +2797,15 @@ retry_listener_ports(smartlist_t *old_conns,
break;
}
#ifdef ENABLE_LISTENER_REBIND
+ /* Rebinding may be needed if all of the following are true:
+ * 1) Address family is the same in old and new listeners.
+ * 2) Port number matches exactly (numeric value is the same).
+ * 3) *One* of listeners (either old one or new one) has a
+ * wildcard IP address (0.0.0.0 or [::]).
+ *
+ * These are the exact conditions for a first bind() syscall
+ * to fail with EADDRINUSE.
+ */
const int may_need_rebind =
tor_addr_family(&wanted->addr) == tor_addr_family(&conn->addr) &&
port_matches_exact && bool_neq(tor_addr_is_null(&wanted->addr),
More information about the tor-commits
mailing list