summaryrefslogtreecommitdiffstats
path: root/utils/exportfs/exportfs.c
diff options
context:
space:
mode:
authorChuck Lever <chuck.lever@oracle.com>2010-09-16 14:17:08 -0400
committerSteve Dickson <steved@redhat.com>2010-09-16 14:33:51 -0400
commit6f189dae5eb38800c8ae3e2d5c098d11fb44d7d5 (patch)
tree32c8a5afb6bbd635f0d065cc64ca819aa7a90dd8 /utils/exportfs/exportfs.c
parent10a6b17d3588647ab5e1ee81ba40f1ce12a5184d (diff)
downloadnfs-utils-6f189dae5eb38800c8ae3e2d5c098d11fb44d7d5.tar.gz
nfs-utils-6f189dae5eb38800c8ae3e2d5c098d11fb44d7d5.tar.xz
nfs-utils-6f189dae5eb38800c8ae3e2d5c098d11fb44d7d5.zip
exportfs: Enable IPv6 support in matchhostname()
To gain IPv6 support in matchhostname(), simply replace the socket address comparison helpers with the generic versions that can handle IPv4 and IPv6. host_addrinfo() (called by matchhostname()) returns IPv6 addresses only if IPv6 support is enabled. Signed-off-by: Chuck Lever <chuck.lever@oracle.com> Signed-off-by: Steve Dickson <steved@redhat.com>
Diffstat (limited to 'utils/exportfs/exportfs.c')
-rw-r--r--utils/exportfs/exportfs.c23
1 files changed, 2 insertions, 21 deletions
diff --git a/utils/exportfs/exportfs.c b/utils/exportfs/exportfs.c
index 8496d82..b78957f 100644
--- a/utils/exportfs/exportfs.c
+++ b/utils/exportfs/exportfs.c
@@ -26,6 +26,7 @@
#include <netdb.h>
#include <errno.h>
+#include "sockaddr.h"
#include "misc.h"
#include "nfslib.h"
#include "exportfs.h"
@@ -443,26 +444,6 @@ is_hostname(const char *sp)
return true;
}
-static _Bool
-compare_sockaddrs4(const struct sockaddr *sa1, const struct sockaddr *sa2)
-{
- const struct sockaddr_in *sin1 = (const struct sockaddr_in *)sa1;
- const struct sockaddr_in *sin2 = (const struct sockaddr_in *)sa2;
- return sin1->sin_addr.s_addr == sin2->sin_addr.s_addr;
-}
-
-static _Bool
-compare_sockaddrs(const struct sockaddr *sa1, const struct sockaddr *sa2)
-{
- if (sa1->sa_family == sa2->sa_family)
- switch (sa1->sa_family) {
- case AF_INET:
- return compare_sockaddrs4(sa1, sa2);
- }
-
- return false;
-}
-
static int
matchhostname(const char *hostname1, const char *hostname2)
{
@@ -493,7 +474,7 @@ matchhostname(const char *hostname1, const char *hostname2)
for (ai1 = results1; ai1 != NULL; ai1 = ai1->ai_next)
for (ai2 = results2; ai2 != NULL; ai2 = ai2->ai_next)
- if (compare_sockaddrs(ai1->ai_addr, ai2->ai_addr)) {
+ if (nfs_compare_sockaddr(ai1->ai_addr, ai2->ai_addr)) {
result = 1;
break;
}