4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License, Version 1.0 only
6 * (the "License"). You may not use this file except in compliance
9 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10 * or http://www.opensolaris.org/os/licensing.
11 * See the License for the specific language governing permissions
12 * and limitations under the License.
14 * When distributing Covered Code, include this CDDL HEADER in each
15 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16 * If applicable, add the following below this CDDL HEADER, with the
17 * fields enclosed by brackets "[]" replaced with your own identifying
18 * information: Portions Copyright [yyyy] [name of copyright owner]
23 * Copyright 2004 Sun Microsystems, Inc. All rights reserved.
24 * Use is subject to license terms.
27 /* Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T */
28 /* All Rights Reserved */
31 * University Copyright- Copyright (c) 1982, 1986, 1988
32 * The Regents of the University of California
35 * University Acknowledgment- Portions of this document are derived from
36 * software developed by the University of California, Berkeley, and its
43 #pragma ident "%Z%%M% %I% %E% SMI"
45 #include <sys/isa_defs.h>
46 #include <sys/int_types.h>
49 * This header file provides BSD compatibility for DIR and direct structures.
50 * The fields in the BSD DIR structure are identical to to the SVR4 DIR
51 * structure, except for the fact that the dd_buf field in SVR4 is not
52 * statically allocated.
53 * The BSD direct structure is similar (not identical) to the dirent
54 * structure. All fields of the direct structure can be obtained using
55 * the information provided by dirent.
56 * All routines manipulating DIR structures are compatible, only readdir
57 * is not. The BSD version of this routine returns a direct structure.
64 #if !defined(KERNEL) && !defined(DEV_BSIZE)
68 #define DIRBLKSIZ DIRBUF
71 #if _FILE_OFFSET_BITS == 32
73 ulong_t d_ino
; /* inode number of entry */
74 ushort_t d_reclen
; /* length of this record */
75 ushort_t d_namlen
; /* length of string in d_name */
76 char d_name
[MAXNAMLEN
+1]; /* name of entry */
78 #elif _FILE_OFFSET_BITS == 64
80 ino_t d_ino
; /* inode number of entry */
81 ushort_t d_reclen
; /* length of this record */
82 ushort_t d_namlen
; /* length of string in d_name */
83 char d_name
[MAXNAMLEN
+1]; /* name of entry */
86 #if defined(_LARGEFILE64_SOURCE)
88 ino64_t d_ino
; /* inode number of entry */
89 ushort_t d_reclen
; /* length of this record */
90 ushort_t d_namlen
; /* length of string in d_name */
91 char d_name
[MAXNAMLEN
+1]; /* name of entry */
96 * The macro DIRSIZ(dp) gives an amount of space required to represent
102 #if _FILE_OFFSET_BITS == 32
104 ((sizeof (struct direct) - sizeof ((dp)->d_name) + \
105 (strlen((dp)->d_name)+1) + 3) & ~3)
106 #elif _FILE_OFFSET_BITS == 64
108 ((sizeof (struct direct64) - sizeof ((dp)->d_name) + \
109 (strlen((dp)->d_name)+1) + 3) & ~3)
111 #if defined(_LARGEFILE64_SOURCE)
112 #define DIRSIZ64(dp) \
113 ((sizeof (struct direct64) - sizeof ((dp)->d_name) + \
114 (strlen((dp)->d_name)+1) + 3) & ~3)
119 * Definitions for library routines operating on directories.
121 typedef struct _dirdesc
{
132 #if defined(_LP64) && defined(_LARGEFILE64_SOURCE)
133 #ifdef __PRAGMA_REDEFINE_EXTNAME
134 #pragma redefine_extname readdir64 readdir
135 #pragma redefine_extname scandir64 scandir
136 #pragma redefine_extname alphasort64 alphasort
138 #define readdir64 readdir
139 #define scandir64 scandir
140 #define alphasort64 alphasort
141 #define direct64 direct
145 #if !defined(_LP64) && (_FILE_OFFSET_BITS == 64)
146 #ifdef __PRAGMA_REDEFINE_EXTNAME
147 #pragma redefine_extname readdir readdir64
148 #pragma redefine_extname scandir scandir64
149 #pragma redefine_extname alphasort alphasort64
151 #define readdir readdir64
152 #define scandir scandir64
153 #define alphasort alphasort64
154 #define direct direct64
158 #if defined(__STDC__)
159 extern DIR *opendir(const char *);
160 extern struct direct
*readdir(DIR *);
161 extern long telldir(DIR *);
162 extern void seekdir(DIR *, long);
163 extern int scandir(char *, struct direct
*(*[]),
164 int (*)(struct direct
*),
165 int (*)(struct direct
**, struct direct
**));
166 extern int alphasort(struct direct
**, struct direct
**);
167 extern void rewinddir(DIR *);
168 extern int closedir(DIR *);
170 extern DIR *opendir();
171 extern struct direct
*readdir();
172 extern long telldir();
173 extern void seekdir();
174 extern int scandir();
175 extern int alphasort();
176 extern void rewinddir();
177 extern void closedir();
180 #if defined(_LARGEFILE64_SOURCE) && !((_FILE_OFFSET_BITS == 64) && \
181 !defined(__PRAGMA_REDEFINE_EXTNAME))
182 #if defined(__STDC__)
183 extern struct direct64
*readdir64(DIR *);
184 extern int scandir64(char *, struct direct64
*(*[]),
185 int (*)(struct direct64
*),
186 int (*)(struct direct64
**, struct direct64
**));
187 extern int alphasort64(struct direct64
**, struct direct64
**);
189 extern struct direct64
*readdir64();
190 extern int scandir64();
191 extern int alphasort64();
193 #endif /* _LARGEFILE64_SOURCE... */
195 #define rewinddir(dirp) seekdir((dirp), 0)
203 #endif /* _SYS_DIR_H */