aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2006-10-20 01:10:28 +0000
committerTom Lane <tgl@sss.pgh.pa.us>2006-10-20 01:10:28 +0000
commit8a6ed093b4da90cf7b866d5143faede6f7ad772a (patch)
tree0865e45c43bd85014186369f35c0ad2b30faf2ba
parent62fc3b9929fc59ae964cc40da42330ee69b454e4 (diff)
downloadpostgresql-8a6ed093b4da90cf7b866d5143faede6f7ad772a.tar.gz
postgresql-8a6ed093b4da90cf7b866d5143faede6f7ad772a.zip
Back-patch second version of AIX getaddrinfo fix.
-rw-r--r--src/backend/libpq/ip.c37
1 files changed, 29 insertions, 8 deletions
diff --git a/src/backend/libpq/ip.c b/src/backend/libpq/ip.c
index 94f4d69c0ac..1aca19a1be9 100644
--- a/src/backend/libpq/ip.c
+++ b/src/backend/libpq/ip.c
@@ -8,7 +8,7 @@
*
*
* IDENTIFICATION
- * $PostgreSQL: pgsql/src/backend/libpq/ip.c,v 1.32.2.2 2006/10/19 17:26:37 tgl Exp $
+ * $PostgreSQL: pgsql/src/backend/libpq/ip.c,v 1.32.2.3 2006/10/20 01:10:28 tgl Exp $
*
* This file and the IPV6 implementation were initially provided by
* Nigel Kukard <nkukard@lbsd.net>, Linux Based Systems Design
@@ -67,6 +67,8 @@ int
pg_getaddrinfo_all(const char *hostname, const char *servname,
const struct addrinfo * hintp, struct addrinfo ** result)
{
+ int rc;
+
/* not all versions of getaddrinfo() zero *result on failure */
*result = NULL;
@@ -75,18 +77,37 @@ pg_getaddrinfo_all(const char *hostname, const char *servname,
return getaddrinfo_unix(servname, hintp, result);
#endif
+ /* NULL has special meaning to getaddrinfo(). */
+ rc = getaddrinfo((!hostname || hostname[0] == '\0') ? NULL : hostname,
+ servname, hintp, result);
+
#ifdef _AIX
/*
- * It seems AIX's getaddrinfo doesn't reliably zero sin_port when servname
- * is NULL, so force the issue.
+ * It seems some versions of AIX's getaddrinfo don't reliably zero
+ * sin_port when servname is NULL, so clean up after it.
*/
- if (servname == NULL)
- servname = "0";
+ if (servname == NULL && rc == 0)
+ {
+ struct addrinfo *addr;
+
+ for (addr = *result; addr; addr = addr->ai_next)
+ {
+ switch (addr->ai_family)
+ {
+ case AF_INET:
+ ((struct sockaddr_in *) addr->ai_addr)->sin_port = htons(0);
+ break;
+#ifdef HAVE_IPV6
+ case AF_INET6:
+ ((struct sockaddr_in6 *) addr->ai_addr)->sin6_port = htons(0);
+ break;
+#endif
+ }
+ }
+ }
#endif
- /* NULL has special meaning to getaddrinfo(). */
- return getaddrinfo((!hostname || hostname[0] == '\0') ? NULL : hostname,
- servname, hintp, result);
+ return rc;
}