1 /*
   2  * CDDL HEADER START
   3  *
   4  * The contents of this file are subject to the terms of the
   5  * Common Development and Distribution License (the "License").
   6  * You may not use this file except in compliance with the License.
   7  *
   8  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
   9  * or http://www.opensolaris.org/os/licensing.
  10  * See the License for the specific language governing permissions
  11  * and limitations under the License.
  12  *
  13  * When distributing Covered Code, include this CDDL HEADER in each
  14  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
  15  * If applicable, add the following below this CDDL HEADER, with the
  16  * fields enclosed by brackets "[]" replaced with your own identifying
  17  * information: Portions Copyright [yyyy] [name of copyright owner]
  18  *
  19  * CDDL HEADER END
  20  */
  21 /*      Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T     */
  22 /*        All Rights Reserved   */
  23 
  24 
  25 /*
  26  * Copyright 2014 Garrett D'Amore <garrett@damore.org>
  27  *
  28  * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
  29  * Use is subject to license terms.
  30  */
  31 
  32 #ifndef _SYS_DIRENT_H
  33 #define _SYS_DIRENT_H
  34 
  35 #include <sys/feature_tests.h>
  36 
  37 #ifdef  __cplusplus
  38 extern "C" {
  39 #endif
  40 
  41 /*
  42  * File-system independent directory entry.
  43  */
  44 typedef struct dirent {
  45         ino_t           d_ino;          /* "inode number" of entry */
  46         off_t           d_off;          /* offset of disk directory entry */
  47         unsigned short  d_reclen;       /* length of this record */
  48         char            d_name[1];      /* name of file */
  49 } dirent_t;
  50 
  51 #if defined(_SYSCALL32)
  52 
  53 /* kernel's view of user ILP32 dirent */
  54 
  55 typedef struct dirent32 {
  56         ino32_t         d_ino;          /* "inode number" of entry */
  57         off32_t         d_off;          /* offset of disk directory entry */
  58         uint16_t        d_reclen;       /* length of this record */
  59         char            d_name[1];      /* name of file */
  60 } dirent32_t;
  61 
  62 #endif  /* _SYSCALL32 */
  63 
  64 #ifdef  _LARGEFILE64_SOURCE
  65 
  66 /*
  67  * transitional large file interface version AND kernel internal version
  68  */
  69 typedef struct dirent64 {
  70         ino64_t         d_ino;          /* "inode number" of entry */
  71         off64_t         d_off;          /* offset of disk directory entry */
  72         unsigned short  d_reclen;       /* length of this record */
  73         char            d_name[1];      /* name of file */
  74 } dirent64_t;
  75 
  76 #endif  /* _LARGEFILE64_SOURCE */
  77 
  78 #if !defined(__XOPEN_OR_POSIX) || defined(__EXTENSIONS__)
  79 #if defined(_KERNEL)
  80 #define DIRENT64_RECLEN(namelen)        \
  81         ((offsetof(dirent64_t, d_name[0]) + 1 + (namelen) + 7) & ~ 7)
  82 #define DIRENT64_NAMELEN(reclen)        \
  83         ((reclen) - (offsetof(dirent64_t, d_name[0])))
  84 #define DIRENT32_RECLEN(namelen)        \
  85         ((offsetof(dirent32_t, d_name[0]) + 1 + (namelen) + 3) & ~ 3)
  86 #define DIRENT32_NAMELEN(reclen)        \
  87         ((reclen) - (offsetof(dirent32_t, d_name[0])))
  88 #endif
  89 
  90 /*
  91  * This is the maximum number of bytes that getdents(2) will store in
  92  * user-supplied dirent buffers.
  93  */
  94 #define MAXGETDENTS_SIZE        (64 * 1024)
  95 
  96 #if !defined(_KERNEL)
  97 
  98 /*
  99  * large file compilation environment setup
 100  *
 101  * In the LP64 compilation environment, map large file interfaces
 102  * back to native versions where possible. (This only works because
 103  * a 'struct dirent' == 'struct dirent64').
 104  */
 105 
 106 #if !defined(_LP64) && _FILE_OFFSET_BITS == 64
 107 #ifdef  __PRAGMA_REDEFINE_EXTNAME
 108 #pragma redefine_extname        getdents        getdents64
 109 #else
 110 #define getdents                getdents64
 111 #endif
 112 #endif  /* !_LP64 && _FILE_OFFSET_BITS == 64 */
 113 
 114 #if defined(_LP64) && defined(_LARGEFILE64_SOURCE)
 115 #ifdef  __PRAGMA_REDEFINE_EXTNAME
 116 #pragma redefine_extname        getdents64      getdents
 117 #else
 118 #define getdents64              getdents
 119 #define dirent64                dirent
 120 #define dirent64_t              dirent_t
 121 #endif
 122 #endif  /* _LP64 && _LARGEFILE64_SOURCE */
 123 
 124 extern int getdents(int, struct dirent *, size_t);
 125 
 126 /* N.B.: transitional large file interface version deliberately not provided */
 127 
 128 #endif /* !defined(_KERNEL) */
 129 #endif /* !defined(__XOPEN_OR_POSIX) || defined(__EXTENSIONS__) */
 130 
 131 #ifdef  __cplusplus
 132 }
 133 #endif
 134 
 135 #endif  /* _SYS_DIRENT_H */