[tor-commits] [obfsproxy/master] Don't use 'int' to store TCP ports. 'uint16_t' is nicer.

nickm at torproject.org nickm at torproject.org
Mon Jan 16 20:35:53 UTC 2012


commit 4599120dd5e6ebba4fda2b1d4a9e912a638e7e8e
Author: George Kadianakis <desnacked at riseup.net>
Date:   Mon Jan 16 19:21:48 2012 +0200

    Don't use 'int' to store TCP ports. 'uint16_t' is nicer.
    
    'uint16_t' also makes our asserts look more reasonable.
---
 src/network.c |    7 ++++---
 src/socks.c   |    5 +++--
 src/socks.h   |    4 ++--
 3 files changed, 9 insertions(+), 7 deletions(-)

diff --git a/src/network.c b/src/network.c
index 4cdd059..a28f7b8 100644
--- a/src/network.c
+++ b/src/network.c
@@ -559,7 +559,7 @@ open_outbound(conn_t *conn, bufferevent_data_cb readcb)
    rather than bufferevent_socket_connect.
 */
 static conn_t *
-open_outbound_hostname(conn_t *conn, int af, const char *addr, int port)
+open_outbound_hostname(conn_t *conn, int af, const char *addr, uint16_t port)
 {
   struct event_base *base = bufferevent_get_base(conn->buffer);
   struct bufferevent *buf;
@@ -604,7 +604,7 @@ open_outbound_hostname(conn_t *conn, int af, const char *addr, int port)
   bufferevent_setcb(buf, downstream_read_cb, NULL, pending_socks_cb, newconn);
   if (bufferevent_socket_connect_hostname(buf, get_evdns_base(),
                                           af, addr, port) < 0) {
-    log_warn("%s: outbound connection to %s:%d failed: %s",
+    log_warn("%s: outbound connection to %s:%u failed: %s",
              conn->peername, addr, port,
              evutil_socket_error_to_string(EVUTIL_SOCKET_ERROR()));
     conn_free(newconn);
@@ -638,7 +638,8 @@ socks_read_cb(struct bufferevent *bev, void *arg)
       /* We shouldn't be here. */
       obfs_abort();
     } else if (status == ST_HAVE_ADDR) {
-      int af, r, port;
+      int af, r;
+      uint16_t port;
       const char *addr=NULL;
       r = socks_state_get_address(socks, &af, &addr, &port);
       obfs_assert(r==0);
diff --git a/src/socks.c b/src/socks.c
index 98cb678..e76a24e 100644
--- a/src/socks.c
+++ b/src/socks.c
@@ -569,7 +569,7 @@ int
 socks_state_get_address(const socks_state_t *state,
                         int *af_out,
                         const char **addr_out,
-                        int *port_out)
+                        uint16_t *port_out)
 {
   if (state->state != ST_HAVE_ADDR && state->state != ST_SENT_REPLY)
     return -1;
@@ -586,9 +586,10 @@ socks_state_get_address(const socks_state_t *state,
 int
 socks_state_set_address(socks_state_t *state, const struct sockaddr *sa)
 {
-  int port;
+  uint16_t port;
   if (sa->sa_family == AF_INET) {
     const struct sockaddr_in *sin = (const struct sockaddr_in *)sa;
+    obfs_assert((sin->sin_port >= 0) && (sin->sin_port <= 65535));
     port = sin->sin_port;
     if (evutil_inet_ntop(AF_INET, &sin->sin_addr, state->parsereq.addr,
                          sizeof(state->parsereq.addr)) == NULL)
diff --git a/src/socks.h b/src/socks.h
index 4e0bdfa..384838f 100644
--- a/src/socks.h
+++ b/src/socks.h
@@ -38,7 +38,7 @@ enum socks_status_t socks_state_get_status(const socks_state_t *state);
 int socks_state_get_address(const socks_state_t *state,
                             int *af_out,
                             const char **addr_out,
-                            int *port_out);
+                            uint16_t *port_out);
 int socks_state_set_address(socks_state_t *state, const struct sockaddr *sa);
 void socks_send_reply(socks_state_t *state, struct evbuffer *dest, int error);
 void socks5_send_reply(struct evbuffer *reply_dest,
@@ -91,7 +91,7 @@ void socks5_send_reply(struct evbuffer *reply_dest,
 struct parsereq {
   int af; /* Address family */
   char addr[255+1]; /* Address as string */
-  int port;
+  uint16_t port;
 };
 struct socks_state_t {
   enum socks_status_t state;





More information about the tor-commits mailing list