aboutsummaryrefslogtreecommitdiff
path: root/net/mtr/files
diff options
context:
space:
mode:
authorSunpoet Po-Chuan Hsieh <sunpoet@FreeBSD.org>2016-11-22 18:43:09 +0000
committerSunpoet Po-Chuan Hsieh <sunpoet@FreeBSD.org>2016-11-22 18:43:09 +0000
commit73660190c6ec196799c0ccd66307beb701a9b15b (patch)
treeee9ceecbbdfff68164209db0f1ef79a9fc32237d /net/mtr/files
parent9fb71cbf42b43f826220e98c0ae6e301dd1cbfac (diff)
- Fix build with IPV6 disabled
Obtained from: https://github.com/traviscross/mtr/commit/3d1352ca93efca2f8c4be7ccd16cbe2472b4fff0 PR: 214731 [1] Submitted by: <sergey@akhmatov.ru> [1], Iain Grant <iain.grant@stream-technologies.com> (via email)
Notes
Notes: svn path=/head/; revision=426848
Diffstat (limited to 'net/mtr/files')
-rw-r--r--net/mtr/files/patch-net.c66
1 files changed, 66 insertions, 0 deletions
diff --git a/net/mtr/files/patch-net.c b/net/mtr/files/patch-net.c
new file mode 100644
index 000000000000..a9143eaf54d3
--- /dev/null
+++ b/net/mtr/files/patch-net.c
@@ -0,0 +1,66 @@
+--- net.c.orig 2016-08-01 13:07:58 UTC
++++ net.c
+@@ -320,9 +320,11 @@ void net_send_tcp(int index)
+ struct sockaddr_storage local;
+ struct sockaddr_storage remote;
+ struct sockaddr_in *local4 = (struct sockaddr_in *) &local;
+- struct sockaddr_in6 *local6 = (struct sockaddr_in6 *) &local;
+ struct sockaddr_in *remote4 = (struct sockaddr_in *) &remote;
++#ifdef ENABLE_IPV6
++ struct sockaddr_in6 *local6 = (struct sockaddr_in6 *) &local;
+ struct sockaddr_in6 *remote6 = (struct sockaddr_in6 *) &remote;
++#endif
+ socklen_t len;
+
+ ttl = index + 1;
+@@ -437,9 +439,11 @@ void net_send_sctp(int index)
+ struct sockaddr_storage local;
+ struct sockaddr_storage remote;
+ struct sockaddr_in *local4 = (struct sockaddr_in *) &local;
+- struct sockaddr_in6 *local6 = (struct sockaddr_in6 *) &local;
+ struct sockaddr_in *remote4 = (struct sockaddr_in *) &remote;
++#ifdef ENABLE_IPV6
++ struct sockaddr_in6 *local6 = (struct sockaddr_in6 *) &local;
+ struct sockaddr_in6 *remote6 = (struct sockaddr_in6 *) &remote;
++#endif
+ socklen_t len;
+
+ ttl = index + 1;
+@@ -726,8 +730,12 @@ void net_send_query(int index)
+
+ /* sendto() assumes packet length includes the IPv4 header but not the
+ IPv6 header. */
+- spacketsize = abs(packetsize) -
+- ( ( af == AF_INET ) ? 0 : sizeof (struct ip6_hdr) );
++ spacketsize = abs(packetsize)
++#ifdef ENABLE_IPV6
++ - ( ( af == AF_INET ) ? 0 : sizeof (struct ip6_hdr) )
++#endif
++ ;
++
+ rv = sendto(sendsock, packet, spacketsize, 0, remotesockaddr, salen);
+ if (first && (rv < 0) && ((errno == EINVAL) || (errno == EMSGSIZE))) {
+ /* Try the first packet again using host byte order. */
+@@ -1529,17 +1537,17 @@ void net_reset(void)
+
+ int net_set_interfaceaddress_udp()
+ {
++ struct sockaddr_in * sa4;
++ struct sockaddr_storage remote;
++ struct sockaddr_in *remote4 = (struct sockaddr_in *) &remote;
+ #ifdef ENABLE_IPV6
+ struct sockaddr_storage name_struct;
++ struct sockaddr_in6 * sa6;
++ struct sockaddr_in6 *remote6 = (struct sockaddr_in6 *) &remote;
+ #else
+ struct sockaddr_in name_struct;
+ #endif
+- struct sockaddr_in * sa4;
+- struct sockaddr_in6 * sa6;
+ struct sockaddr * name = (struct sockaddr *) &name_struct;
+- struct sockaddr_storage remote;
+- struct sockaddr_in *remote4 = (struct sockaddr_in *) &remote;
+- struct sockaddr_in6 *remote6 = (struct sockaddr_in6 *) &remote;
+ socklen_t len;
+ int s;
+