]> git.saurik.com Git - apple/xnu.git/blobdiff - bsd/sys/select.h
xnu-6153.61.1.tar.gz
[apple/xnu.git] / bsd / sys / select.h
index 79237174b7eb606a8e67fc553f3dfe190972fe65..2fb516833d8e02496ac847799a2cdf8a9bc8e9dc 100644 (file)
@@ -2,7 +2,7 @@
  * Copyright (c) 2000-2005 Apple Computer, Inc. All rights reserved.
  *
  * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
- * 
+ *
  * This file contains Original Code and/or Modifications of Original Code
  * as defined in and that are subject to the Apple Public Source License
  * Version 2.0 (the 'License'). You may not use this file except in
  * unlawful or unlicensed copies of an Apple operating system, or to
  * circumvent, violate, or enable the circumvention or violation of, any
  * terms of an Apple operating system software license agreement.
- * 
+ *
  * Please obtain a copy of the License at
  * http://www.opensource.apple.com/apsl/ and read it before using this file.
- * 
+ *
  * The Original Code and all software distributed under the License are
  * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
@@ -22,7 +22,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
  * Please see the License for the specific language governing rights and
  * limitations under the License.
- * 
+ *
  * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
  */
 /*
@@ -61,7 +61,7 @@
  */
 
 #ifndef _SYS_SELECT_H_
-#define        _SYS_SELECT_H_
+#define _SYS_SELECT_H_
 
 #include <sys/appleapiopts.h>
 #include <sys/cdefs.h>
  * The timespec structure shall be defined as described in <time.h>
  * The <sys/select.h> header shall define the timeval structure.
  */
-#define __need_fd_set
-#define __need_struct_timespec
-#define __need_struct_timeval
-#include <sys/_structs.h>
+#include <sys/_types/_fd_def.h>
+#include <sys/_types/_timespec.h>
+#include <sys/_types/_timeval.h>
 
 /*
  * The time_t and suseconds_t types shall be defined as described in
  * <sys/types.h>
  * The sigset_t type shall be defined as described in <signal.h>
  */
-#ifndef        _TIME_T
-#define        _TIME_T
-typedef        __darwin_time_t         time_t;
-#endif
-
-#ifndef _SUSECONDS_T
-#define _SUSECONDS_T
-typedef __darwin_suseconds_t   suseconds_t;
-#endif
-
-#ifndef _SIGSET_T
-#define _SIGSET_T
-typedef __darwin_sigset_t      sigset_t;
-#endif
+#include <sys/_types/_time_t.h>
+#include <sys/_types/_suseconds_t.h>
+#include <sys/_types/_sigset_t.h>
 
 /*
  * [XSI] FD_CLR, FD_ISSET, FD_SET, FD_ZERO may be declared as a function, or
@@ -109,33 +97,19 @@ typedef __darwin_sigset_t  sigset_t;
  * extra protection here is to permit application redefinition above
  * the default size.
  */
-#ifndef        FD_SETSIZE
-#define        FD_SETSIZE      __DARWIN_FD_SETSIZE
-#endif /* FD_SETSIZE */
-#ifndef FD_SET
-#define        FD_SET(n, p)    __DARWIN_FD_SET(n, p)
-#endif /* FD_SET */
-#ifndef FD_CLR
-#define        FD_CLR(n, p)    __DARWIN_FD_CLR(n, p)
-#endif /* FD_CLR */
-#ifndef FD_ISSET
-#define        FD_ISSET(n, p)  __DARWIN_FD_ISSET(n, p)
-#endif /* FD_ISSET */
-#ifndef FD_ZERO
-#define        FD_ZERO(p)      __DARWIN_FD_ZERO(p)
-#endif /* FD_ZERO */
+#include <sys/_types/_fd_setsize.h>
+#include <sys/_types/_fd_set.h>
+#include <sys/_types/_fd_clr.h>
+#include <sys/_types/_fd_isset.h>
+#include <sys/_types/_fd_zero.h>
+
 #if !defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE)
-#ifndef FD_COPY
-#define        FD_COPY(f, t)   __DARWIN_FD_COPY(f, t)
-#endif /* FD_COPY */
-#endif /* (!_POSIX_C_SOURCE || _DARWIN_C_SOURCE) */
+#include <sys/_types/_fd_copy.h>
+#endif  /* (!_POSIX_C_SOURCE || _DARWIN_C_SOURCE) */
 
 #ifdef KERNEL
-#ifdef KERNEL_PRIVATE
-#include <kern/wait_queue.h>
-#endif
 #include <sys/kernel_types.h>
-
+#include <kern/waitq.h>
 #include <sys/event.h>
 
 /*
@@ -144,15 +118,16 @@ typedef __darwin_sigset_t sigset_t;
  */
 #ifdef KERNEL_PRIVATE
 struct selinfo {
-       struct  wait_queue si_wait_queue;       /* wait_queue for wait/wakeup */
-       struct klist si_note;           /* JMM - temporary separation */
-       u_int   si_flags;               /* see below */
+       struct  waitq si_waitq;         /* waitq for wait/wakeup */
+       struct  klist si_note;          /* JMM - temporary separation */
+       u_int   si_flags;               /* see below */
 };
 
-#define        SI_COLL         0x0001          /* collision occurred */
-#define        SI_RECORDED     0x0004          /* select has been recorded */ 
-#define        SI_INITED       0x0008          /* selinfo has been inited */ 
-#define        SI_CLEAR        0x0010          /* selinfo has been cleared */ 
+#define SI_COLL         0x0001          /* collision occurred */
+#define SI_RECORDED     0x0004          /* select has been recorded */
+#define SI_INITED       0x0008          /* selinfo has been inited */
+#define SI_CLEAR        0x0010          /* selinfo has been cleared */
+#define SI_KNPOSTING    0x0020          /* posting to knotes */
 
 #else
 struct selinfo;
@@ -161,9 +136,9 @@ struct selinfo;
 __BEGIN_DECLS
 
 extern int selwait;
-void   selrecord(proc_t selector, struct selinfo *, void *);
-void   selwakeup(struct selinfo *);
-void   selthreadclear(struct selinfo *);
+void    selrecord(proc_t selector, struct selinfo *, void *);
+void    selwakeup(struct selinfo *);
+void    selthreadclear(struct selinfo *);
 
 __END_DECLS
 
@@ -172,22 +147,22 @@ __END_DECLS
 __BEGIN_DECLS
 
 #ifndef  __MWERKS__
-int     pselect(int, fd_set * __restrict, fd_set * __restrict,
-               fd_set * __restrict, const struct timespec * __restrict,
-               const sigset_t * __restrict)
+int      pselect(int, fd_set * __restrict, fd_set * __restrict,
+    fd_set * __restrict, const struct timespec * __restrict,
+    const sigset_t * __restrict)
 #if defined(_DARWIN_C_SOURCE) || defined(_DARWIN_UNLIMITED_SELECT)
-               __DARWIN_EXTSN_C(pselect)
+__DARWIN_EXTSN_C(pselect)
 #else /* !_DARWIN_C_SOURCE && !_DARWIN_UNLIMITED_SELECT */
 #  if defined(__LP64__) && !__DARWIN_NON_CANCELABLE
-               __DARWIN_1050(pselect)
+__DARWIN_1050(pselect)
 #  else /* !__LP64__ || __DARWIN_NON_CANCELABLE */
-               __DARWIN_ALIAS_C(pselect)
+__DARWIN_ALIAS_C(pselect)
 #  endif /* __LP64__ && !__DARWIN_NON_CANCELABLE */
 #endif /* _DARWIN_C_SOURCE || _DARWIN_UNLIMITED_SELECT */
-               ;
+;
 #endif /* __MWERKS__ */
 
-#include <sys/_select.h>       /* select() prototype */
+#include <sys/_select.h>        /* select() prototype */
 
 __END_DECLS