(authunix_create_default): Don't allocate huge arrays on the stack.
[kopensolaris-gnu/glibc.git] / sunrpc / clnt_gen.c
index 1a2cc91..c7468f4 100644 (file)
@@ -35,7 +35,6 @@
 #include <string.h>
 #include <rpc/rpc.h>
 #include <sys/socket.h>
-#include <sys/errno.h>
 #include <netdb.h>
 
 /*
@@ -66,22 +65,28 @@ clnt_create (const char *hostname, u_long prog, u_long vers,
       sun.sun_family = AF_UNIX;
       strcpy (sun.sun_path, hostname);
       sock = RPC_ANYSOCK;
-      client = clntunix_create (&sun, prog, vers, &sock, 0, 0);
+      client = INTUSE(clntunix_create) (&sun, prog, vers, &sock, 0, 0);
       if (client == NULL)
        return NULL;
+#if 0
+      /* This is not wanted.  This would disable the user from having
+        a timeout in the clnt_call() call.  Only a call to cnlt_control()
+        by the user should set the timeout value.  */
       tv.tv_sec = 25;
       tv.tv_usec = 0;
       clnt_control (client, CLSET_TIMEOUT, (char *)&tv);
+#endif
       return client;
     }
 
   hstbuflen = 1024;
   hsttmpbuf = __alloca (hstbuflen);
   while (__gethostbyname_r (hostname, &hostbuf, hsttmpbuf, hstbuflen,
-                           &h, &herr) < 0)
+                           &h, &herr) != 0
+        || h == NULL)
     if (herr != NETDB_INTERNAL || errno != ERANGE)
       {
-       rpc_createerr.cf_stat = RPC_UNKNOWNHOST;
+       get_rpc_createerr().cf_stat = RPC_UNKNOWNHOST;
        return NULL;
       }
     else
@@ -96,23 +101,25 @@ clnt_create (const char *hostname, u_long prog, u_long vers,
       /*
        * Only support INET for now
        */
-      rpc_createerr.cf_stat = RPC_SYSTEMERROR;
-      rpc_createerr.cf_error.re_errno = EAFNOSUPPORT;
+      struct rpc_createerr *ce = &get_rpc_createerr ();
+      ce->cf_stat = RPC_SYSTEMERROR;
+      ce->cf_error.re_errno = EAFNOSUPPORT;
       return NULL;
     }
   sin.sin_family = h->h_addrtype;
   sin.sin_port = 0;
   __bzero (sin.sin_zero, sizeof (sin.sin_zero));
-  bcopy (h->h_addr, (char *) &sin.sin_addr, h->h_length);
+  memcpy ((char *) &sin.sin_addr, h->h_addr, h->h_length);
 
   prtbuflen = 1024;
   prttmpbuf = __alloca (prtbuflen);
-  while (__getprotobyname_r (proto, &protobuf, prttmpbuf, prtbuflen, &p)
-        < 0)
+  while (__getprotobyname_r (proto, &protobuf, prttmpbuf, prtbuflen, &p) != 0
+        || p == NULL)
     if (errno != ERANGE)
       {
-       rpc_createerr.cf_stat = RPC_UNKNOWNPROTO;
-       rpc_createerr.cf_error.re_errno = EPFNOSUPPORT;
+       struct rpc_createerr *ce = &get_rpc_createerr ();
+       ce->cf_stat = RPC_UNKNOWNPROTO;
+       ce->cf_error.re_errno = EPFNOSUPPORT;
        return NULL;
       }
     else
@@ -128,28 +135,42 @@ clnt_create (const char *hostname, u_long prog, u_long vers,
     case IPPROTO_UDP:
       tv.tv_sec = 5;
       tv.tv_usec = 0;
-      client = clntudp_create (&sin, prog, vers, tv, &sock);
+      client = INTUSE(clntudp_create) (&sin, prog, vers, tv, &sock);
       if (client == NULL)
        {
          return NULL;
        }
+#if 0
+      /* This is not wanted.  This would disable the user from having
+        a timeout in the clnt_call() call.  Only a call to cnlt_control()
+        by the user should set the timeout value.  */
       tv.tv_sec = 25;
       clnt_control (client, CLSET_TIMEOUT, (char *)&tv);
+#endif
       break;
     case IPPROTO_TCP:
-      client = clnttcp_create (&sin, prog, vers, &sock, 0, 0);
+      client = INTUSE(clnttcp_create) (&sin, prog, vers, &sock, 0, 0);
       if (client == NULL)
        {
          return NULL;
        }
+#if 0
+      /* This is not wanted.  This would disable the user from having
+        a timeout in the clnt_call() call.  Only a call to cnlt_control()
+        by the user should set the timeout value.  */
       tv.tv_sec = 25;
       tv.tv_usec = 0;
       clnt_control (client, CLSET_TIMEOUT, (char *)&tv);
+#endif
       break;
     default:
-      rpc_createerr.cf_stat = RPC_SYSTEMERROR;
-      rpc_createerr.cf_error.re_errno = EPFNOSUPPORT;
+      {
+       struct rpc_createerr *ce = &get_rpc_createerr ();
+       ce->cf_stat = RPC_SYSTEMERROR;
+       ce->cf_error.re_errno = EPFNOSUPPORT;
+      }
       return (NULL);
     }
   return client;
 }
+INTDEF (clnt_create)