Loading...
gen/FreeBSD/readdir.c Libc-1725.40.4 Libc-498
--- Libc/Libc-1725.40.4/gen/FreeBSD/readdir.c
+++ Libc/Libc-498/gen/FreeBSD/readdir.c
@@ -10,6 +10,10 @@
  * 2. Redistributions in binary form must reproduce the above copyright
  *    notice, this list of conditions and the following disclaimer in the
  *    documentation and/or other materials provided with the distribution.
+ * 3. All advertising materials mentioning features or use of this software
+ *    must display the following acknowledgement:
+ *	This product includes software developed by the University of
+ *	California, Berkeley and its contributors.
  * 4. Neither the name of the University nor the names of its contributors
  *    may be used to endorse or promote products derived from this software
  *    without specific prior written permission.
@@ -31,87 +35,39 @@
 static char sccsid[] = "@(#)readdir.c	8.3 (Berkeley) 9/29/94";
 #endif /* LIBC_SCCS and not lint */
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD$");
+__FBSDID("$FreeBSD: src/lib/libc/gen/readdir.c,v 1.11 2002/02/26 21:39:32 alfred Exp $");
 
 #include "namespace.h"
 #include <sys/param.h>
 #include <dirent.h>
 #include <errno.h>
-#include <stdlib.h>
 #include <string.h>
-#include <unistd.h>
 #include <pthread.h>
 #include "un-namespace.h"
 
 #include "libc_private.h"
-#include "telldir.h"
 
 /*
  * get next entry in a directory.
  */
 struct dirent *
-_readdir_unlocked(DIR *dirp, int skip)
+_readdir_unlocked(dirp)
+	DIR *dirp;
 {
 	struct dirent *dp;
-	long initial_seek;
-	long initial_loc = 0;
 
 	for (;;) {
 		if (dirp->dd_loc >= dirp->dd_size) {
-			if (dirp->dd_flags & (__DTF_READALL | __DTF_ATEND))
+			if (dirp->dd_flags & __DTF_READALL)
 				return (NULL);
-			initial_loc = dirp->dd_loc;
-			dirp->dd_flags &= ~__DTF_SKIPREAD;
 			dirp->dd_loc = 0;
 		}
-		if (dirp->dd_loc == 0 &&
-		    !(dirp->dd_flags & (__DTF_READALL | __DTF_ATEND | __DTF_SKIPREAD))) {
-			if (dirp->dd_len == READDIR_INITIAL_SIZE) {
-				/*
-				 * If we need to read more, and we still have the original size,
-				 * then grow the internal buffer to a large size to amortize
-				 * the cost of __getdirentries64 calls.
-				 */
-				int len = READDIR_LARGE_SIZE;
-				char *buf = malloc(len);
-				if (buf) {
-					free(dirp->dd_buf);
-					dirp->dd_buf = buf;
-					dirp->dd_len = len;
-				}
-			}
-#if __DARWIN_64_BIT_INO_T
-			/*
-			 * sufficiently recent kernels when the buffer is large enough,
-			 * will use the last bytes of the buffer to return status.
-			 *
-			 * To support older kernels:
-			 * - make sure it's 0 initialized
-			 * - make sure it's past `dd_size` before reading it
-			 */
-			getdirentries64_flags_t *gdeflags =
-			    (getdirentries64_flags_t *)(dirp->dd_buf + dirp->dd_len -
-			    sizeof(getdirentries64_flags_t));
-			*gdeflags = 0;
-			initial_seek = dirp->dd_td->seekoff;
-			dirp->dd_size = (long)__getdirentries64(dirp->dd_fd,
-			    dirp->dd_buf, dirp->dd_len, &dirp->dd_td->seekoff);
-			if (dirp->dd_size >= 0 &&
-			    dirp->dd_size <= dirp->dd_len - sizeof(getdirentries64_flags_t)) {
-				if (*gdeflags & GETDIRENTRIES64_EOF) {
-					dirp->dd_flags |= __DTF_ATEND;
-				}
-			}
-#else /* !__DARWIN_64_BIT_INO_T */
-			initial_seek = dirp->dd_seek;
+		if (dirp->dd_loc == 0 && !(dirp->dd_flags & __DTF_READALL)) {
 			dirp->dd_size = _getdirentries(dirp->dd_fd,
 			    dirp->dd_buf, dirp->dd_len, &dirp->dd_seek);
-#endif /* __DARWIN_64_BIT_INO_T */
 			if (dirp->dd_size <= 0)
 				return (NULL);
-			_fixtelldir(dirp, initial_seek, initial_loc);
 		}
-		dirp->dd_flags &= ~__DTF_SKIPREAD;
 		dp = (struct dirent *)(dirp->dd_buf + dirp->dd_loc);
 		if ((long)dp & 03L)	/* bogus pointer check */
 			return (NULL);
@@ -119,7 +75,7 @@
 		    dp->d_reclen > dirp->dd_len + 1 - dirp->dd_loc)
 			return (NULL);
 		dirp->dd_loc += dp->d_reclen;
-		if (dp->d_ino == 0 && skip)
+		if (dp->d_ino == 0)
 			continue;
 		if (dp->d_type == DT_WHT && (dirp->dd_flags & DTF_HIDEW))
 			continue;
@@ -128,22 +84,26 @@
 }
 
 struct dirent *
-readdir(DIR *dirp)
+readdir(dirp)
+	DIR *dirp;
 {
 	struct dirent	*dp;
 
 	if (__isthreaded) {
-		_pthread_mutex_lock(&dirp->dd_lock);
-		dp = _readdir_unlocked(dirp, 1);
-		_pthread_mutex_unlock(&dirp->dd_lock);
+		_pthread_mutex_lock((pthread_mutex_t *)&dirp->dd_lock);
+		dp = _readdir_unlocked(dirp);
+		_pthread_mutex_unlock((pthread_mutex_t *)&dirp->dd_lock);
 	}
 	else
-		dp = _readdir_unlocked(dirp, 1);
+		dp = _readdir_unlocked(dirp);
 	return (dp);
 }
 
 int
-readdir_r(DIR *dirp, struct dirent *entry, struct dirent **result)
+readdir_r(dirp, entry, result)
+	DIR *dirp;
+	struct dirent *entry;
+	struct dirent **result;
 {
 	struct dirent *dp;
 	int saved_errno;
@@ -151,12 +111,12 @@
 	saved_errno = errno;
 	errno = 0;
 	if (__isthreaded) {
-		_pthread_mutex_lock(&dirp->dd_lock);
-		if ((dp = _readdir_unlocked(dirp, 1)) != NULL)
+		_pthread_mutex_lock((pthread_mutex_t *)&dirp->dd_lock);
+		if ((dp = _readdir_unlocked(dirp)) != NULL)
 			memcpy(entry, dp, _GENERIC_DIRSIZ(dp));
-		_pthread_mutex_unlock(&dirp->dd_lock);
+		_pthread_mutex_unlock((pthread_mutex_t *)&dirp->dd_lock);
 	}
-	else if ((dp = _readdir_unlocked(dirp, 1)) != NULL)
+	else if ((dp = _readdir_unlocked(dirp)) != NULL)
 		memcpy(entry, dp, _GENERIC_DIRSIZ(dp));
 
 	if (errno != 0) {