]> git.decadent.org.uk Git - nfs-utils.git/blobdiff - support/export/client.c
libexport.a: Remove unused function client_checkaddr()
[nfs-utils.git] / support / export / client.c
index 833f4a9d954320565fce0aa6c01a83da8fa8ebd0..419a4a7d930f6999e8a0f26dc397fce2b3d5f899 100644 (file)
@@ -32,7 +32,6 @@ extern int    innetgr(char *netgr, char *host, char *, char *);
 static char    *add_name(char *old, const char *add);
 static void    client_init(nfs_client *clp, const char *hname,
                                        struct hostent *hp);
-static int     client_checkaddr(nfs_client *clp, struct in_addr addr);
 
 nfs_client     *clientlist[MCL_MAXTYPES] = { NULL, };
 
@@ -350,6 +349,27 @@ check_fqdn(const nfs_client *clp, const struct hostent *hp)
        return 0;
 }
 
+/*
+ * Check each address listed in @hp against the subnetwork or
+ * host address stored in @clp.  Return 1 if an address in @hp
+ * matches the host address stored in @clp, otherwise zero.
+ */
+static int
+check_subnetwork(const nfs_client *clp, const struct hostent *hp)
+{
+       struct in_addr addr;
+       char **ap;
+
+       for (ap = hp->h_addr_list; *ap; ap++) {
+               addr = *(struct in_addr *)*ap;
+
+               if (!((clp->m_addrlist[0].s_addr ^ addr.s_addr) &
+                     clp->m_addrlist[1].s_addr))
+                       return 1;
+       }
+       return 0;
+}
+
 /*
  * Match a host (given its hostent record) to a client record. This
  * is usually called from mountd.
@@ -365,11 +385,7 @@ client_check(nfs_client *clp, struct hostent *hp)
        case MCL_FQDN:
                return check_fqdn(clp, hp);
        case MCL_SUBNETWORK:
-               for (ap = hp->h_addr_list; *ap; ap++) {
-                       if (client_checkaddr(clp, *(struct in_addr *) *ap))
-                               return 1;
-               }
-               return 0;
+               return check_subnetwork(clp, hp);
        case MCL_WILDCARD:
                if (wildmat(hname, cname))
                        return 1;
@@ -431,17 +447,6 @@ client_check(nfs_client *clp, struct hostent *hp)
        return 0;
 }
 
-static int
-client_checkaddr(nfs_client *clp, struct in_addr addr)
-{
-       switch (clp->m_type) {
-       case MCL_SUBNETWORK:
-               return !((clp->m_addrlist[0].s_addr ^ addr.s_addr)
-                       & clp->m_addrlist[1].s_addr);
-       }
-       return 0;
-}
-
 int
 client_gettype(char *ident)
 {