[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]
[or-cvs] Populate address field of listeners with an actually sane v...
Update of /home/or/cvsroot/tor/src/or
In directory moria:/tmp/cvs-serv12257/src/or
Modified Files:
connection.c
Log Message:
Populate address field of listeners with an actually sane value.
Index: connection.c
===================================================================
RCS file: /home/or/cvsroot/tor/src/or/connection.c,v
retrieving revision 1.383
retrieving revision 1.384
diff -u -d -r1.383 -r1.384
--- connection.c 14 Jul 2005 08:43:19 -0000 1.383
+++ connection.c 14 Jul 2005 22:56:17 -0000 1.384
@@ -454,6 +454,7 @@
connection_create_listener(const char *bindaddress, uint16_t bindport, int type)
{
struct sockaddr_in bindaddr; /* where to bind */
+ char *address = NULL;
connection_t *conn;
uint16_t usePort;
uint32_t addr;
@@ -463,7 +464,7 @@
#endif
memset(&bindaddr,0,sizeof(struct sockaddr_in));
- if (parse_addr_port(bindaddress, NULL, &addr, &usePort)<0) {
+ if (parse_addr_port(bindaddress, &address, &addr, &usePort)<0) {
log_fn(LOG_WARN, "Error parsing/resolving BindAddress %s",bindaddress);
return -1;
}
@@ -477,11 +478,11 @@
s = socket(PF_INET,SOCK_STREAM,IPPROTO_TCP);
if (s < 0) {
log_fn(LOG_WARN,"Socket creation failed.");
- return -1;
+ goto err;
} else if (!SOCKET_IS_POLLABLE(s)) {
log_fn(LOG_WARN,"Too many connections; can't create pollable listener.");
tor_close_socket(s);
- return -1;
+ goto err;
}
#ifndef MS_WINDOWS
@@ -495,26 +496,27 @@
if (bind(s,(struct sockaddr *)&bindaddr,sizeof(bindaddr)) < 0) {
log_fn(LOG_WARN,"Could not bind to port %u: %s",usePort,
tor_socket_strerror(tor_socket_errno(s)));
- return -1;
+ goto err;
}
if (listen(s,SOMAXCONN) < 0) {
log_fn(LOG_WARN,"Could not listen on port %u: %s",usePort,
tor_socket_strerror(tor_socket_errno(s)));
- return -1;
+ goto err;
}
set_socket_nonblocking(s);
conn = connection_new(type);
conn->s = s;
- conn->address = tor_strdup(bindaddress);
+ conn->address = address;
+ address = NULL;
conn->port = usePort;
if (connection_add(conn) < 0) { /* no space, forget it */
log_fn(LOG_WARN,"connection_add failed. Giving up.");
connection_free(conn);
- return -1;
+ goto err;
}
log_fn(LOG_DEBUG,"%s listening on port %u.",conn_type_to_string(type), usePort);
@@ -523,6 +525,10 @@
connection_start_reading(conn);
return 0;
+
+ err:
+ tor_free(address);
+ return -1;
}
/** Do basic sanity checking on a newly received socket. Return 0