about summary refs log tree commit diff
path: root/nscd/nscd_getgr_r.c
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>1998-07-25 18:02:26 +0000
committerUlrich Drepper <drepper@redhat.com>1998-07-25 18:02:26 +0000
commit6730873037b6afad1504bb237399c343cce18451 (patch)
treecb31093b70d4dfbf5f1c77482720bf871261b8c5 /nscd/nscd_getgr_r.c
parent264d5b944dca563c8b948392942d1ea33d221723 (diff)
downloadglibc-6730873037b6afad1504bb237399c343cce18451.tar.gz
glibc-6730873037b6afad1504bb237399c343cce18451.tar.xz
glibc-6730873037b6afad1504bb237399c343cce18451.zip
Update.
1998-07-25  Ulrich Drepper  <drepper@cygnus.com>

	* sysdeps/i386/bits/byteswap.h (__bswap_64): Change __v to __w to
	prevent conflict with __bswap_32.
Diffstat (limited to 'nscd/nscd_getgr_r.c')
-rw-r--r--nscd/nscd_getgr_r.c13
1 files changed, 12 insertions, 1 deletions
diff --git a/nscd/nscd_getgr_r.c b/nscd/nscd_getgr_r.c
index 9b3022c764..85ebb0dc60 100644
--- a/nscd/nscd_getgr_r.c
+++ b/nscd/nscd_getgr_r.c
@@ -232,7 +232,18 @@ __nscd_getgr_r (const char *key, request_type type, struct group *resultbuf,
 	      *p++ = '\0';
 	    }
 
-	  if (__readv (sock, vec, gr_resp.gr_mem_len) != total_len)
+	  while (i > UIO_MAXIOV)
+	    {
+	      if (__readv (sock, vec, UIO_MAXIOV) != total_len)
+		{
+		  __close (sock);
+		  return -1;
+		}
+	      vec += UIO_MAXIOV;
+	      i -= UIO_MAXIOV;
+	    }
+
+	  if (__readv (sock, vec, i) != total_len)
 	    {
 	      __close (sock);
 	      return -1;