[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]

[tor-commits] [torsocks/master] Fix: handle hints being NULL in getaddrinfo



commit ec15af6e76a541caaf69ffdbae248d1712f69d31
Author: David Goulet <dgoulet@xxxxxxxxx>
Date:   Thu Feb 20 11:41:34 2014 +0000

    Fix: handle hints being NULL in getaddrinfo
    
    Signed-off-by: David Goulet <dgoulet@xxxxxxxxx>
---
 src/lib/getaddrinfo.c |   17 +++++++++++++++++
 1 file changed, 17 insertions(+)

diff --git a/src/lib/getaddrinfo.c b/src/lib/getaddrinfo.c
index a0f5595..da9d4ed 100644
--- a/src/lib/getaddrinfo.c
+++ b/src/lib/getaddrinfo.c
@@ -48,6 +48,22 @@ LIBC_GETADDRINFO_RET_TYPE tsocks_getaddrinfo(LIBC_GETADDRINFO_SIG)
 		goto error;
 	}
 
+	/*
+	 * Quoting the getaddrinfo(3) man page:
+	 *
+	 * All  the  other  fields  in  the  structure pointed to by hints must
+	 * contain either 0 or a NULL pointer, as appropriate.  Specifying  hints
+	 * as  NULL  is equivalent  to  setting  ai_socktype  and  ai_protocol  to
+	 * 0;  ai_family to AF_UNSPEC; and ai_flags to (AI_V4MAPPED |
+	 * AI_ADDRCONFIG).
+	 *
+	 * This means that for sure the ai_family will be treated as AF_UNSPEC.
+	 */
+	if (!hints) {
+		tmp_node = node;
+		goto libc_call;
+	}
+
 	/* Use right domain for the next step. */
 	switch (hints->ai_family) {
 	default:
@@ -83,6 +99,7 @@ LIBC_GETADDRINFO_RET_TYPE tsocks_getaddrinfo(LIBC_GETADDRINFO_SIG)
 		DBG("[getaddrinfo] Node %s will be passed to the libc call", tmp_node);
 	}
 
+libc_call:
 	ret = tsocks_libc_getaddrinfo(tmp_node, service, hints, res);
 	if (ret) {
 		goto error;



_______________________________________________
tor-commits mailing list
tor-commits@xxxxxxxxxxxxxxxxxxxx
https://lists.torproject.org/cgi-bin/mailman/listinfo/tor-commits