aboutsummaryrefslogtreecommitdiffstats
path: root/security/nmap/files
diff options
context:
space:
mode:
authorwxs <wxs@FreeBSD.org>2009-04-21 23:36:56 +0800
committerwxs <wxs@FreeBSD.org>2009-04-21 23:36:56 +0800
commit9224724d47c8d44823be38f0ba6928da3a644b7b (patch)
tree71a1a25903195e75e50272f025437e7a422afdc7 /security/nmap/files
parent2d3b23b2d1e6b2368da4e724e040d7e8384311d2 (diff)
downloadfreebsd-ports-gnome-9224724d47c8d44823be38f0ba6928da3a644b7b.tar.gz
freebsd-ports-gnome-9224724d47c8d44823be38f0ba6928da3a644b7b.tar.zst
freebsd-ports-gnome-9224724d47c8d44823be38f0ba6928da3a644b7b.zip
- Add patch to work around versions of FreeBSD with broken
getaddrinfo(3) (7.1 and earlier, and -CURRENT before the end of March 2009). PR: ports/133779 Submitted by: Daniel Roethlisberger <daniel@roe.ch> (maintainer)
Diffstat (limited to 'security/nmap/files')
-rw-r--r--security/nmap/files/patch-ncat__ncat_core.c33
1 files changed, 33 insertions, 0 deletions
diff --git a/security/nmap/files/patch-ncat__ncat_core.c b/security/nmap/files/patch-ncat__ncat_core.c
new file mode 100644
index 000000000000..ccab94e0c19e
--- /dev/null
+++ b/security/nmap/files/patch-ncat__ncat_core.c
@@ -0,0 +1,33 @@
+--- ncat/ncat_core.c.orig 2009-04-02 04:57:42.000000000 +0200
++++ ncat/ncat_core.c 2009-04-16 14:12:39.000000000 +0200
+@@ -11,6 +11,7 @@
+ #include <netinet/in.h>
+ #include <arpa/inet.h>
+ #endif
++#include <sys/param.h>
+ #include <stdlib.h>
+ #include <string.h>
+ #include <stdio.h>
+@@ -96,13 +97,22 @@
+ rc = Snprintf(portbuf, sizeof(portbuf), "%hu", port);
+ assert(rc >= 0 && rc < sizeof(portbuf));
+
++#if (defined(__FreeBSD_version) && (__FreeBSD_version < 800075) \
++ && ((__FreeBSD_version > 800000) || (__FreeBSD_version < 702000)))
++ rc = getaddrinfo(hostname, "domain", &hints, &result);
++#else
+ rc = getaddrinfo(hostname, portbuf, &hints, &result);
++#endif
+ if (rc != 0 || result == NULL)
+ return 0;
+ assert(result->ai_addrlen > 0 && result->ai_addrlen <= (int) sizeof(struct sockaddr_storage));
+ *sslen = result->ai_addrlen;
+ memcpy(ss, result->ai_addr, *sslen);
+ freeaddrinfo(result);
++#if (defined(__FreeBSD_version) && (__FreeBSD_version < 800075) \
++ && ((__FreeBSD_version > 800000) || (__FreeBSD_version < 702000)))
++ ((struct sockaddr_in *)ss)->sin_port = htons(port);
++#endif
+ return 1;
+ }
+