diff options
Diffstat (limited to 'libc/inet')
-rw-r--r-- | libc/inet/rpc/rcmd.c | 81 |
1 files changed, 60 insertions, 21 deletions
diff --git a/libc/inet/rpc/rcmd.c b/libc/inet/rpc/rcmd.c index a56b99ec0..20c572b45 100644 --- a/libc/inet/rpc/rcmd.c +++ b/libc/inet/rpc/rcmd.c @@ -37,16 +37,8 @@ static char sccsid[] = "@(#)rcmd.c 8.3 (Berkeley) 3/26/94"; #define __FORCE_GLIBC #include <features.h> -#include <sys/param.h> -#include <sys/poll.h> -#include <sys/socket.h> -#include <sys/stat.h> - -#include <netinet/in.h> -#include <arpa/inet.h> - -#include <ctype.h> #define __USE_GNU +#include <ctype.h> #include <stdio.h> #include <stdlib.h> #include <string.h> @@ -54,11 +46,17 @@ static char sccsid[] = "@(#)rcmd.c 8.3 (Berkeley) 3/26/94"; #include <alloca.h> #include <signal.h> #include <fcntl.h> -#include <netdb.h> #include <unistd.h> #include <pwd.h> - +#include <sys/param.h> +#include <sys/poll.h> +#include <sys/socket.h> +#include <sys/stat.h> #include <netdb.h> +#include <netinet/in.h> +#include <arpa/inet.h> + + /* hmm. uClibc seems to have that, but it doesn't work for some reason */ #define getc_unlocked getc @@ -94,16 +92,22 @@ int rcmd(ahost, rport, locuser, remuser, cmd, fd2p) pid = getpid(); #ifdef _LIBC_REENTRANT -#error "Fix the alloca stuff" hstbuflen = 1024; +#ifdef __UCLIBC_HAS_MMU__ tmphstbuf = alloca (hstbuflen); +#else + tmphstbuf = malloc (hstbuflen); +#endif - while (__gethostbyname_r (*ahost, &hostbuf, tmphstbuf, + while (gethostbyname_r (*ahost, &hostbuf, tmphstbuf, hstbuflen, &hp, &herr) != 0 || hp == NULL) { if (herr != NETDB_INTERNAL || errno != ERANGE) { __set_h_errno (herr); +#ifndef __UCLIBC_HAS_MMU__ + free(tmphstbuf); +#endif herror(*ahost); return -1; } @@ -111,9 +115,19 @@ int rcmd(ahost, rport, locuser, remuser, cmd, fd2p) { /* Enlarge the buffer. */ hstbuflen *= 2; +#ifdef __UCLIBC_HAS_MMU__ tmphstbuf = alloca (hstbuflen); +#else + if (tmphstbuf) { + free(tmphstbuf); + } + tmphstbuf = malloc (hstbuflen); +#endif } } +#ifndef __UCLIBC_HAS_MMU__ + free(tmphstbuf); +#endif #else /* call the non-reentrant version */ if ((hp = gethostbyname(*ahost)) == NULL) { return -1; @@ -292,22 +306,38 @@ int ruserok(rhost, superuser, ruser, luser) #endif #ifdef _LIBC_REENTRANT -#error "Fix the alloca stuff!" buflen = 1024; +#ifdef __UCLIBC_HAS_MMU__ buffer = alloca (buflen); +#else + buffer = malloc (buflen); +#endif - while (__gethostbyname_r (rhost, &hostbuf, buffer, + while (gethostbyname_r (rhost, &hostbuf, buffer, buflen, &hp, &herr) != 0 || hp == NULL) { - if (herr != NETDB_INTERNAL || errno != ERANGE) + if (herr != NETDB_INTERNAL || errno != ERANGE) { +#ifndef __UCLIBC_HAS_MMU__ + free(buffer); +#endif return -1; - else + } else { /* Enlarge the buffer. */ buflen *= 2; +#ifdef __UCLIBC_HAS_MMU__ buffer = alloca (buflen); +#else + if (buffer) { + free(buffer); + } + buffer = malloc (buflen); +#endif } } +#ifndef __UCLIBC_HAS_MMU__ + free(buffer); +#endif #else if ((hp = gethostbyname(rhost)) == NULL) { return -1; @@ -402,16 +432,25 @@ iruserok2 (raddr, superuser, ruser, luser, rhost) uid_t uid; #ifdef _LIBC_REENTRANT -#error "Fix the alloca stuff" size_t buflen = sysconf (_SC_GETPW_R_SIZE_MAX); - char *buffer = alloca (buflen); struct passwd pwdbuf; +#ifdef __UCLIBC_HAS_MMU__ + char *buffer = alloca (buflen); +#else + char *buffer = malloc (buflen); +#endif - if (__getpwnam_r (luser, &pwdbuf, buffer, + if (getpwnam_r (luser, &pwdbuf, buffer, buflen, &pwd) != 0 || pwd == NULL) { +#ifndef __UCLIBC_HAS_MMU__ + free(buffer); +#endif return -1; } +#ifndef __UCLIBC_HAS_MMU__ + free(buffer); +#endif #else if ((pwd = getpwnam(luser)) == NULL) return -1; @@ -519,7 +558,7 @@ __icheckhost (raddr, lhost, rhost) buffer = malloc(buflen); save_errno = errno; - while (__gethostbyname_r (lhost, &hostbuf, buffer, buflen, &hp, &herr) + while (gethostbyname_r (lhost, &hostbuf, buffer, buflen, &hp, &herr) != 0) { free(buffer); return (0); |