OpenCores
URL https://opencores.org/ocsvn/openrisc_me/openrisc_me/trunk

Subversion Repositories openrisc_me

[/] [openrisc/] [trunk/] [gnu-src/] [newlib-1.17.0/] [newlib/] [libc/] [posix/] [readdir_r.c] - Blame information for rev 438

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 148 jeremybenn
#ifndef HAVE_OPENDIR
2
 
3
/*
4
 * Copyright (c) 1983 Regents of the University of California.
5
 * All rights reserved.
6
 *
7
 * Redistribution and use in source and binary forms, with or without
8
 * modification, are permitted provided that the following conditions
9
 * are met:
10
 * 1. Redistributions of source code must retain the above copyright
11
 *    notice, this list of conditions and the following disclaimer.
12
 * 2. Redistributions in binary form must reproduce the above copyright
13
 *    notice, this list of conditions and the following disclaimer in the
14
 *    documentation and/or other materials provided with the distribution.
15
 * 3. All advertising materials mentioning features or use of this software
16
 *    must display the following acknowledgement:
17
 *      This product includes software developed by the University of
18
 *      California, Berkeley and its contributors.
19
 * 4. Neither the name of the University nor the names of its contributors
20
 *    may be used to endorse or promote products derived from this software
21
 *    without specific prior written permission.
22
 *
23
 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
24
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26
 * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
27
 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28
 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29
 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32
 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33
 * SUCH DAMAGE.
34
 */
35
 
36
/* this code is modified from readdir.c by Jeff Johnston, June 5, 2002 */
37
 
38
#if defined(LIBC_SCCS) && !defined(lint)
39
static char sccsid[] = "@(#)readdir.c   5.7 (Berkeley) 6/1/90";
40
#endif /* LIBC_SCCS and not lint */
41
 
42
#include <dirent.h>
43
#include <errno.h>
44
#include <string.h>
45
 
46
extern int getdents (int fd, void *dp, int count);
47
 
48
/*
49
 * get next entry in a directory using supplied dirent structure.
50
 */
51
int
52
_DEFUN(readdir_r, (dirp, dp, dpp),
53
        register DIR *dirp _AND
54
        struct dirent *dp _AND
55
        struct dirent **dpp) {
56
 
57
struct dirent *tmpdp;
58
 
59
#ifdef HAVE_DD_LOCK
60
  __lock_acquire_recursive(dirp->dd_lock);
61
#endif
62
 
63
  if (dirp->dd_fd == -1) {
64
    *dpp = NULL;
65
    return errno = EBADF;
66
  }
67
 
68
  for (;;) {
69
    if (dirp->dd_loc == 0) {
70
      dirp->dd_size = getdents (dirp->dd_fd,
71
                                dirp->dd_buf,
72
                                dirp->dd_len);
73
 
74
      if (dirp->dd_size <= 0) {
75
#ifdef HAVE_DD_LOCK
76
        __lock_release_recursive(dirp->dd_lock);
77
#endif
78
        *dpp = NULL;
79
        return errno;
80
      }
81
    }
82
    if (dirp->dd_loc >= dirp->dd_size) {
83
      dirp->dd_loc = 0;
84
      continue;
85
    }
86
    tmpdp = (struct dirent *)(dirp->dd_buf + dirp->dd_loc);
87
    memcpy (dp, tmpdp, sizeof(struct dirent));
88
 
89
    if (dp->d_reclen <= 0 ||
90
        dp->d_reclen > dirp->dd_len + 1 - dirp->dd_loc) {
91
#ifdef HAVE_DD_LOCK
92
      __lock_release_recursive(dirp->dd_lock);
93
#endif
94
      *dpp = NULL;
95
      return -1;
96
    }
97
    dirp->dd_loc += dp->d_reclen;
98
    if (dp->d_ino == 0)
99
      continue;
100
#ifdef HAVE_DD_LOCK
101
    __lock_release_recursive(dirp->dd_lock);
102
#endif
103
    *dpp = dp;
104
    return 0;
105
  }
106
}
107
 
108
#endif /* ! HAVE_OPENDIR */

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.