| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262 | /** * D header file for POSIX. * * Copyright: Public Domain * License: Public Domain * Authors: Sean Kelly * Standards: The Open Group Base Specifications Issue 6, IEEE Std 1003.1, 2004 Edition */ module tango.stdc.posix.sys.select; private import tango.stdc.posix.config; public import tango.stdc.time; // for timespec public import tango.stdc.posix.sys.time; // for timeval public import tango.stdc.posix.sys.types; // for time_t public import tango.stdc.posix.signal; // for sigset_t extern (C): // // Required // /* NOTE: This module requires timeval from tango.stdc.posix.sys.time, but timeval is supposedly an XOpen extension. As a result, this header will not compile on platforms that are not XSI-compliant. This must be resolved on a per-platform basis. fd_set void FD_CLR(int fd, fd_set* fdset); int FD_ISSET(int fd, fd_set* fdset); void FD_SET(int fd, fd_set* fdset); void FD_ZERO(fd_set* fdset); FD_SETSIZE int pselect(int, fd_set*, fd_set*, fd_set*, in timespec*, in sigset_t*); int select(int, fd_set*, fd_set*, fd_set*, timeval*); */ version( linux ) { private { alias c_long __fd_mask; const int __NFDBITS = 8 * __fd_mask.sizeof; extern (D) int __FDELT( int d ) { return d / __NFDBITS; } extern (D) int __FDMASK( int d ) { return cast(__fd_mask) (1 << ( d % __NFDBITS )); } } const FD_SETSIZE = 1024; struct fd_set { __fd_mask[FD_SETSIZE / __NFDBITS] fds_bits; } extern (D) void FD_CLR( int fd, fd_set* fdset ) { fdset.fds_bits[__FDELT( fd )] &= ~__FDMASK( fd ); } extern (D) int FD_ISSET( int fd, fd_set* fdset ) { return cast(int)(fdset.fds_bits[__FDELT( fd )] & __FDMASK( fd )); } extern (D) void FD_SET( int fd, fd_set* fdset ) { fdset.fds_bits[__FDELT( fd )] |= __FDMASK( fd ); } extern (D) void FD_ZERO( fd_set* fdset ) { fdset.fds_bits[0 .. $] = 0; } /+ + GNU ASM Implementation + # define __FD_ZERO(fdsp) \ do { \ int __d0, __d1; \ __asm__ __volatile__ ("cld; rep; stosl" \ : "=c" (__d0), "=D" (__d1) \ : "a" (0), "0" (sizeof (fd_set) \ / sizeof (__fd_mask)), \ "1" (&__FDS_BITS (fdsp)[0]) \ : "memory"); \ } while (0) # define __FD_SET(fd, fdsp) \ __asm__ __volatile__ ("btsl %1,%0" \ : "=m" (__FDS_BITS (fdsp)[__FDELT (fd)]) \ : "r" (((int) (fd)) % __NFDBITS) \ : "cc","memory") # define __FD_CLR(fd, fdsp) \ __asm__ __volatile__ ("btrl %1,%0" \ : "=m" (__FDS_BITS (fdsp)[__FDELT (fd)]) \ : "r" (((int) (fd)) % __NFDBITS) \ : "cc","memory") # define __FD_ISSET(fd, fdsp) \ (__extension__ \ ({register char __result; \ __asm__ __volatile__ ("btl %1,%2 ; setcb %b0" \ : "=q" (__result) \ : "r" (((int) (fd)) % __NFDBITS), \ "m" (__FDS_BITS (fdsp)[__FDELT (fd)]) \ : "cc"); \ __result; })) +/ int pselect(int, fd_set*, fd_set*, fd_set*, in timespec*, in sigset_t*); int select(int, fd_set*, fd_set*, fd_set*, timeval*); } else version( darwin ) { private { const uint __DARWIN_NBBY = 8; /* bits in a byte */ const uint __DARWIN_NFDBITS = (int.sizeof * __DARWIN_NBBY); /* bits per mask */ alias uint __fd_mask; const __NFDBITS = 8 * __fd_mask.sizeof; extern (D) int __FDELT( int d ) { return d / cast(int)__NFDBITS; } extern (D) __fd_mask __FDMASK( int d ) { return cast(__fd_mask) 1 << ( d % __NFDBITS ); } } const FD_SETSIZE = 1024; struct fd_set { int[(((FD_SETSIZE) + ((__DARWIN_NFDBITS) - 1)) / (__DARWIN_NFDBITS))] fds_bits; } extern (D) void FD_CLR( int fd, fd_set* fdset ) { fdset.fds_bits[__FDELT( fd )] &= ~__FDMASK( fd ); } extern (D) int FD_ISSET( int fd, fd_set* fdset ) { return cast(int) (fdset.fds_bits[__FDELT( fd )] & __FDMASK( fd )); } extern (D) void FD_SET( int fd, fd_set* fdset ) { fdset.fds_bits[__FDELT( fd )] |= __FDMASK( fd ); } extern (D) void FD_ZERO( fd_set* fdset ) { fdset.fds_bits[0 .. $] = 0; } } else version( FreeBSD ) { private { const uint FD_SETSIZE = 1024; alias c_long __fd_mask; const _NFDBITS = 8 * __fd_mask.sizeof; extern (D) int __FDELT( int d ) { return cast(int) (d / _NFDBITS); } extern (D) __fd_mask __FDMASK( int d ) { return cast(__fd_mask) 1 << ( d % _NFDBITS ); } } struct fd_set { c_ulong[((FD_SETSIZE + (_NFDBITS - 1)) / _NFDBITS)] fds_bits; } extern (D) void FD_CLR( int fd, fd_set* fdset ) { fdset.fds_bits[__FDELT( fd )] &= ~__FDMASK( fd ); } extern (D) int FD_ISSET( int fd, fd_set* fdset ) { return cast(int) (fdset.fds_bits[__FDELT( fd )] & __FDMASK( fd )); } extern (D) void FD_SET( int fd, fd_set* fdset ) { fdset.fds_bits[__FDELT( fd )] |= __FDMASK( fd ); } extern (D) void FD_ZERO( fd_set* fdset ) { fdset.fds_bits[0 .. $] = 0; } } else version( solaris ) { private { alias c_long __fd_mask; const NBBY = 8; const FD_NFDBITS = __fd_mask.sizeof * NBBY; /* bits per mask */ extern (D) int __FDELT( int d ) { return d / FD_NFDBITS; } extern (D) __fd_mask __FDMASK( int d ) { return cast(__fd_mask) 1 << ( d % FD_NFDBITS ); } } version (X86_64) const FD_SETSIZE = 65536; else const FD_SETSIZE = 1024; struct fd_set { __fd_mask[( FD_SETSIZE + FD_NFDBITS - 1 ) / FD_NFDBITS] fds_bits; } extern (D) void FD_CLR( int fd, fd_set* fdset ) { fdset.fds_bits[__FDELT( fd )] &= ~__FDMASK( fd ); } extern (D) int FD_ISSET( int fd, fd_set* fdset ) { return fdset.fds_bits[__FDELT( fd )] & __FDMASK( fd ); } extern (D) void FD_SET( int fd, fd_set* fdset ) { fdset.fds_bits[__FDELT( fd )] |= __FDMASK( fd ); } extern (D) void FD_ZERO( fd_set* fdset ) { fdset.fds_bits[0 .. $] = 0; } } |