]> git.saurik.com Git - apple/xnu.git/blobdiff - bsd/sys/types.h
xnu-2782.30.5.tar.gz
[apple/xnu.git] / bsd / sys / types.h
index 5822866459e88e8fd916a978c7b0b6c06ebeac8a..a9fc63938bb64e5600e8bf77eaa484b51d460213 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2000-2004 Apple Computer, Inc. All rights reserved.
+ * Copyright (c) 2000-2008 Apple Inc. All rights reserved.
  *
  * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
  * 
@@ -26,7 +26,7 @@
  * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
  */
 /* Copyright (c) 1995 NeXT Computer, Inc. All Rights Reserved */
-/*-
+/*
  * Copyright (c) 1982, 1986, 1991, 1993, 1994
  *     The Regents of the University of California.  All rights reserved.
  * (c) UNIX System Laboratories, Inc.
@@ -80,7 +80,7 @@
 
 #include <machine/endian.h>
 
-#ifndef _POSIX_C_SOURCE
+#if !defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE)
 typedef        unsigned char           u_char;
 typedef        unsigned short          u_short;
 typedef        unsigned int            u_int;
@@ -99,143 +99,90 @@ typedef    quad_t *                qaddr_t;
 typedef        char *                  caddr_t;        /* core address */
 typedef        int32_t                 daddr_t;        /* disk address */
 
-#ifndef _DEV_T
-typedef        __darwin_dev_t          dev_t;          /* device number */
-#define _DEV_T
-#endif
+#include <sys/_types/_dev_t.h>                 /* device number */
 
 typedef        u_int32_t               fixpt_t;        /* fixed point number */
 
-#ifndef _BLKCNT_T
-typedef        __darwin_blkcnt_t       blkcnt_t;
-#define        _BLKCNT_T
-#endif
+#include <sys/_types/_blkcnt_t.h>
+#include <sys/_types/_blksize_t.h>
+#include <sys/_types/_gid_t.h>
+#include <sys/_types/_in_addr_t.h>
+#include <sys/_types/_in_port_t.h>
+#include <sys/_types/_ino_t.h>
 
-#ifndef _BLKSIZE_T
-typedef        __darwin_blksize_t      blksize_t;
-#define        _BLKSIZE_T
-#endif
+#if !defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE)
+#include <sys/_types/_ino64_t.h>                       /* 64bit inode number */
+#endif /* !defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE) */
 
-#ifndef _GID_T
-typedef __darwin_gid_t         gid_t;
-#define _GID_T
-#endif
-
-#ifndef _IN_ADDR_T
-#define _IN_ADDR_T
-typedef        __uint32_t              in_addr_t;      /* base type for internet address */
-#endif
-
-#ifndef _IN_PORT_T
-#define _IN_PORT_T
-typedef        __uint16_t              in_port_t;
-#endif
+#include <sys/_types/_key_t.h>
+#include <sys/_types/_mode_t.h>
+#include <sys/_types/_nlink_t.h>
+#include <sys/_types/_id_t.h>
+#include <sys/_types/_pid_t.h>
+#include <sys/_types/_off_t.h>
 
-#ifndef        _INO_T
-typedef        __darwin_ino_t          ino_t;          /* inode number */
-#define _INO_T
-#endif
-
-#ifndef _KEY_T
-#define _KEY_T
-typedef        __int32_t               key_t;          /* IPC key (for Sys V IPC) */
-#endif
-
-#ifndef        _MODE_T
-typedef        __darwin_mode_t         mode_t;
-#define _MODE_T
-#endif
-
-#ifndef _NLINK_T
-typedef        __uint16_t              nlink_t;        /* link count */
-#define        _NLINK_T
-#endif
+typedef        int32_t                 segsz_t;        /* segment size */
+typedef        int32_t                 swblk_t;        /* swap offset */
 
-#ifndef _ID_T
-#define _ID_T
-typedef __darwin_id_t          id_t;           /* can hold pid_t, gid_t, or uid_t */
-#endif
+#include <sys/_types/_uid_t.h>
 
-#ifndef _PID_T
-typedef __darwin_pid_t         pid_t;
-#define _PID_T
-#endif
+#if !defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE)
+/* Major, minor numbers, dev_t's. */
+#if defined(__cplusplus)
+/*
+ * These lowercase macros tend to match member functions in some C++ code,
+ * so for C++, we must use inline functions instead.
+ */
 
-#ifndef _OFF_T
-typedef __darwin_off_t         off_t;
-#define _OFF_T
-#endif
+static inline __int32_t  major(__uint32_t _x)
+{
+       return (__int32_t)(((__uint32_t)_x >> 24) & 0xff);
+}
 
-typedef        int32_t                 segsz_t;        /* segment size */
-typedef        int32_t                 swblk_t;        /* swap offset */
+static inline __int32_t  minor(__uint32_t _x)
+{
+       return (__int32_t)((_x) & 0xffffff);
+}
 
-#ifndef _UID_T
-typedef __darwin_uid_t         uid_t;          /* user id */
-#define _UID_T
-#endif
+static inline dev_t  makedev(__uint32_t _major, __uint32_t _minor)
+{
+       return (dev_t)(((_major) << 24) | (_minor));
+}
 
-#ifndef _ID_T
-typedef __darwin_id_t          id_t;
-#define _ID_T
-#endif
+#else  /* !__cplusplus */
 
-#ifndef _POSIX_C_SOURCE
-/* Major, minor numbers, dev_t's. */
 #define        major(x)        ((int32_t)(((u_int32_t)(x) >> 24) & 0xff))
 #define        minor(x)        ((int32_t)((x) & 0xffffff))
 #define        makedev(x,y)    ((dev_t)(((x) << 24) | (y)))
-#endif
-
-#ifndef        _CLOCK_T
-#define        _CLOCK_T
-typedef        __darwin_clock_t        clock_t;
-#endif
 
-#ifndef _SIZE_T
-#define _SIZE_T
-/* DO NOT REMOVE THIS COMMENT: fixincludes needs to see
- * _GCC_SIZE_T */
-typedef __darwin_size_t                size_t;
-#endif
-
-#ifndef        _SSIZE_T
-#define        _SSIZE_T
-typedef        __darwin_ssize_t        ssize_t;
-#endif
+#endif /* !__cplusplus */
+#endif /* !_POSIX_C_SOURCE */
 
-#ifndef        _TIME_T
-#define        _TIME_T
-typedef        __darwin_time_t         time_t;
-#endif
+#include <sys/_types/_clock_t.h>
+#include <sys/_types/_size_t.h>
+#include <sys/_types/_ssize_t.h>
+#include <sys/_types/_time_t.h>
 
-#ifndef _USECONDS_T
-#define _USECONDS_T
-typedef __darwin_useconds_t    useconds_t;
-#endif
+#include <sys/_types/_useconds_t.h>
+#include <sys/_types/_suseconds_t.h>
 
-#ifndef _SUSECONDS_T
-#define _SUSECONDS_T
-typedef __darwin_suseconds_t   suseconds_t;
+#if !defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE)
+#include <sys/_types/_rsize_t.h>
+#include <sys/_types/_errno_t.h>
 #endif
 
-#ifndef _POSIX_C_SOURCE
+#if !defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE)
 /*
  * This code is present here in order to maintain historical backward
  * compatability, and is intended to be removed at some point in the
  * future; please include <sys/select.h> instead.
  */
-#define        NBBY            8                               /* bits in a byte */
-#define NFDBITS        (sizeof(__int32_t) * NBBY)              /* bits per mask */
-#define        howmany(x, y)   (((x) + ((y) - 1)) / (y))       /* # y's == x bits? */
-typedef __int32_t      fd_mask;
+#include <sys/_types/_fd_def.h>
 
-
-/*
- * Note:       We use _FD_SET to protect all select related
- *             types and macros
- */
-#ifndef _FD_SET
-#define        _FD_SET
+#define        NBBY            __DARWIN_NBBY           /* bits in a byte */
+#define NFDBITS                __DARWIN_NFDBITS        /* bits per mask */
+#define        howmany(x, y)   __DARWIN_howmany(x, y)  /* # y's == x bits? */
+typedef __int32_t      fd_mask;
 
 /*
  * Select uses bit masks of file descriptors in longs.  These macros
@@ -243,37 +190,15 @@ typedef __int32_t fd_mask;
  * extra protection here is to permit application redefinition above
  * the default size.
  */
-#ifndef        FD_SETSIZE
-#define        FD_SETSIZE      1024
-#endif
-
-#define        __DARWIN_NBBY   8                               /* bits in a byte */
-#define __DARWIN_NFDBITS       (sizeof(__int32_t) * __DARWIN_NBBY) /* bits per mask */
-#define        __DARWIN_howmany(x, y) (((x) + ((y) - 1)) / (y))        /* # y's == x bits? */
-
-__BEGIN_DECLS
-typedef        struct fd_set {
-       __int32_t       fds_bits[__DARWIN_howmany(FD_SETSIZE, __DARWIN_NFDBITS)];
-} fd_set;
-__END_DECLS
-
-#define        FD_SET(n, p)    ((p)->fds_bits[(n)/__DARWIN_NFDBITS] |= (1<<((n) % __DARWIN_NFDBITS)))
-#define        FD_CLR(n, p)    ((p)->fds_bits[(n)/__DARWIN_NFDBITS] &= ~(1<<((n) % __DARWIN_NFDBITS)))
-#define        FD_ISSET(n, p)  ((p)->fds_bits[(n)/__DARWIN_NFDBITS] & (1<<((n) % __DARWIN_NFDBITS)))
-#if __GNUC__ > 3 || __GNUC__ == 3 && __GNUC_MINOR__ >= 3
-/*
- * Use the built-in bzero function instead of the library version so that
- * we do not pollute the namespace or introduce prototype warnings.
- */
-#define        FD_ZERO(p)      __builtin_bzero(p, sizeof(*(p)))
-#else
-#define        FD_ZERO(p)      bzero(p, sizeof(*(p)))
-#endif
-#ifndef _POSIX_C_SOURCE
-#define        FD_COPY(f, t)   bcopy(f, t, sizeof(*(f)))
-#endif /* !_POSIX_C_SOURCE */
+#include <sys/_types/_fd_setsize.h>
+#include <sys/_types/_fd_set.h>
+#include <sys/_types/_fd_clr.h>
+#include <sys/_types/_fd_zero.h>
+#include <sys/_types/_fd_isset.h>
 
-#endif /* !_FD_SET */
+#if !defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE)
+#include <sys/_types/_fd_copy.h>
+#endif /* (!_POSIX_C_SOURCE || _DARWIN_C_SOURCE) */
 
 
 #if defined(__STDC__) && defined(KERNEL)
@@ -292,64 +217,32 @@ struct    tty;
 struct uio;
 #endif
 
-#endif /* !_POSIX_C_SOURCE */
+#endif /* (!_POSIX_C_SOURCE || _DARWIN_C_SOURCE) */
 #endif /* __ASSEMBLER__ */
 
+#ifndef KERNEL
+
 #ifndef __POSIX_LIB__
 
-#ifndef _PTHREAD_ATTR_T
-#define _PTHREAD_ATTR_T
-typedef __darwin_pthread_attr_t                pthread_attr_t;
-#endif
-#ifndef _PTHREAD_COND_T
-#define _PTHREAD_COND_T
-typedef __darwin_pthread_cond_t                pthread_cond_t;
-#endif
-#ifndef _PTHREAD_CONDATTR_T
-#define _PTHREAD_CONDATTR_T
-typedef __darwin_pthread_condattr_t    pthread_condattr_t;
-#endif
-#ifndef _PTHREAD_MUTEX_T
-#define _PTHREAD_MUTEX_T
-typedef __darwin_pthread_mutex_t       pthread_mutex_t;
-#endif
-#ifndef _PTHREAD_MUTEXATTR_T
-#define _PTHREAD_MUTEXATTR_T
-typedef __darwin_pthread_mutexattr_t   pthread_mutexattr_t;
-#endif
-#ifndef _PTHREAD_ONCE_T
-#define _PTHREAD_ONCE_T
-typedef __darwin_pthread_once_t                pthread_once_t;
-#endif
-#ifndef _PTHREAD_RWLOCK_T
-#define _PTHREAD_RWLOCK_T
-typedef __darwin_pthread_rwlock_t      pthread_rwlock_t;
-#endif
-#ifndef _PTHREAD_RWLOCKATTR_T
-#define _PTHREAD_RWLOCKATTR_T
-typedef __darwin_pthread_rwlockattr_t  pthread_rwlockattr_t;
-#endif
-#ifndef _PTHREAD_T
-#define _PTHREAD_T
-typedef __darwin_pthread_t             pthread_t;
-#endif
+#include <sys/_pthread/_pthread_attr_t.h>
+#include <sys/_pthread/_pthread_cond_t.h>
+#include <sys/_pthread/_pthread_condattr_t.h>
+#include <sys/_pthread/_pthread_mutex_t.h>
+#include <sys/_pthread/_pthread_mutexattr_t.h>
+#include <sys/_pthread/_pthread_once_t.h>
+#include <sys/_pthread/_pthread_rwlock_t.h>
+#include <sys/_pthread/_pthread_rwlockattr_t.h>
+#include <sys/_pthread/_pthread_t.h>
 
 #endif /* __POSIX_LIB__ */
 
-#ifndef _PTHREAD_KEY_T
-#define _PTHREAD_KEY_T
-typedef __darwin_pthread_key_t         pthread_key_t;
-#endif
+#include <sys/_pthread/_pthread_key_t.h>
+
+#endif /* KERNEL */
 
 /* statvfs and fstatvfs */
-#ifndef _FSBLKCNT_T
-#define _FSBLKCNT_T
-typedef __darwin_fsblkcnt_t            fsblkcnt_t;
-#endif
 
-#ifndef _FSFILCNT_T
-#define _FSFILCNT_T
-typedef __darwin_fsfilcnt_t            fsfilcnt_t;
-#endif
+#include <sys/_types/_fsblkcnt_t.h>
+#include <sys/_types/_fsfilcnt_t.h>
 
 #endif /* !_SYS_TYPES_H_ */