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

[or-cvs] r17851: {tor} Only set sin_len/sin6_len when they exist. (in tor/trunk: . src/common src/or)



Author: nickm
Date: 2009-01-02 15:57:10 -0500 (Fri, 02 Jan 2009)
New Revision: 17851

Modified:
   tor/trunk/configure.in
   tor/trunk/src/common/address.c
   tor/trunk/src/or/eventdns.c
Log:
Only set sin_len/sin6_len when they exist.

Modified: tor/trunk/configure.in
===================================================================
--- tor/trunk/configure.in	2009-01-02 20:46:32 UTC (rev 17850)
+++ tor/trunk/configure.in	2009-01-02 20:57:10 UTC (rev 17851)
@@ -446,7 +446,7 @@
 #endif
 #endif
 ])
-AC_CHECK_MEMBERS([struct in6_addr.s6_addr32, struct in6_addr.s6_addr16], , ,
+AC_CHECK_MEMBERS([struct in6_addr.s6_addr32, struct in6_addr.s6_addr16, struct sockaddr_in.sin_len, struct sockaddr_in6.sin6_len], , ,
 [#ifdef HAVE_SYS_TYPES_H
 #include <sys/types.h>
 #endif

Modified: tor/trunk/src/common/address.c
===================================================================
--- tor/trunk/src/common/address.c	2009-01-02 20:46:32 UTC (rev 17850)
+++ tor/trunk/src/common/address.c	2009-01-02 20:57:10 UTC (rev 17851)
@@ -69,7 +69,9 @@
       return -1;
     sin = (struct sockaddr_in *)sa_out;
     memset(sin, 0, sizeof(struct sockaddr_in));
+#ifdef HAVE_STRUCT_SOCKADDR_IN_SIN_LEN
     sin->sin_len = sizeof(struct sockaddr_in);
+#endif
     sin->sin_family = AF_INET;
     sin->sin_port = htons(port);
     sin->sin_addr.s_addr = tor_addr_to_ipv4n(a);
@@ -80,7 +82,9 @@
       return -1;
     sin6 = (struct sockaddr_in6 *)sa_out;
     memset(sin6, 0, sizeof(struct sockaddr_in6));
+#ifdef HAVE_STRUCT_SOCKADDR_IN6_SIN6_LEN
     sin6->sin6_len = sizeof(struct sockaddr_in6);
+#endif
     sin6->sin6_family = AF_INET6;
     sin6->sin6_port = htons(port);
     memcpy(&sin6->sin6_addr, tor_addr_to_in6(a), sizeof(struct in6_addr));

Modified: tor/trunk/src/or/eventdns.c
===================================================================
--- tor/trunk/src/or/eventdns.c	2009-01-02 20:46:32 UTC (rev 17850)
+++ tor/trunk/src/or/eventdns.c	2009-01-02 20:57:10 UTC (rev 17851)
@@ -2302,7 +2302,9 @@
 	struct sockaddr_in sin;
 	memset(&sin, 0, sizeof(sin));
 	sin.sin_family = AF_INET;
+#ifdef HAVE_STRUCT_SOCKADDR_IN_SIN_LEN
 	sin.sin_len = sizeof(sin);
+#endif
 	sin.sin_addr.s_addr = htonl(address);
 	sin.sin_port = 53;
 	return _evdns_nameserver_add_impl((struct sockaddr*) &sin, sizeof(sin));
@@ -2381,7 +2383,9 @@
 	if (is_ipv6) {
 		struct sockaddr_in6 sin6;
 		memset(&sin6, 0, sizeof(sin6));
+#ifdef HAVE_STRUCT_SOCKADDR_IN6_SIN6_LEN
 		sin6.sin6_len = sizeof(sin6);
+#endif
 		sin6.sin6_family = AF_INET6;
 		sin6.sin6_port = htons(port);
 		if (1 != tor_inet_pton(AF_INET6, addr_part, &sin6.sin6_addr)) {
@@ -2393,7 +2397,9 @@
 	} else {
 		struct sockaddr_in sin;
 		memset(&sin, 0, sizeof(sin));
+#ifdef HAVE_STRUCT_SOCKADDR_IN_SIN_LEN
 		sin.sin_len = sizeof(sin);
+#endif
 		sin.sin_family = AF_INET;
 		sin.sin_port = htons(port);
 		if (!inet_aton(addr_part, &sin.sin_addr)) {