1*8d67ca89SAndroid Build Coastguard Worker /* 2*8d67ca89SAndroid Build Coastguard Worker * Copyright (C) 2008 The Android Open Source Project 3*8d67ca89SAndroid Build Coastguard Worker * All rights reserved. 4*8d67ca89SAndroid Build Coastguard Worker * 5*8d67ca89SAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without 6*8d67ca89SAndroid Build Coastguard Worker * modification, are permitted provided that the following conditions 7*8d67ca89SAndroid Build Coastguard Worker * are met: 8*8d67ca89SAndroid Build Coastguard Worker * * Redistributions of source code must retain the above copyright 9*8d67ca89SAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer. 10*8d67ca89SAndroid Build Coastguard Worker * * Redistributions in binary form must reproduce the above copyright 11*8d67ca89SAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer in 12*8d67ca89SAndroid Build Coastguard Worker * the documentation and/or other materials provided with the 13*8d67ca89SAndroid Build Coastguard Worker * distribution. 14*8d67ca89SAndroid Build Coastguard Worker * 15*8d67ca89SAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 16*8d67ca89SAndroid Build Coastguard Worker * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 17*8d67ca89SAndroid Build Coastguard Worker * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 18*8d67ca89SAndroid Build Coastguard Worker * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 19*8d67ca89SAndroid Build Coastguard Worker * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 20*8d67ca89SAndroid Build Coastguard Worker * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 21*8d67ca89SAndroid Build Coastguard Worker * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS 22*8d67ca89SAndroid Build Coastguard Worker * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 23*8d67ca89SAndroid Build Coastguard Worker * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 24*8d67ca89SAndroid Build Coastguard Worker * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT 25*8d67ca89SAndroid Build Coastguard Worker * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 26*8d67ca89SAndroid Build Coastguard Worker * SUCH DAMAGE. 27*8d67ca89SAndroid Build Coastguard Worker */ 28*8d67ca89SAndroid Build Coastguard Worker 29*8d67ca89SAndroid Build Coastguard Worker #pragma once 30*8d67ca89SAndroid Build Coastguard Worker 31*8d67ca89SAndroid Build Coastguard Worker /** 32*8d67ca89SAndroid Build Coastguard Worker * @file sys/select.h 33*8d67ca89SAndroid Build Coastguard Worker * @brief Wait for events on a set of file descriptors (but use <poll.h> instead). 34*8d67ca89SAndroid Build Coastguard Worker */ 35*8d67ca89SAndroid Build Coastguard Worker 36*8d67ca89SAndroid Build Coastguard Worker #include <sys/cdefs.h> 37*8d67ca89SAndroid Build Coastguard Worker #include <sys/types.h> 38*8d67ca89SAndroid Build Coastguard Worker 39*8d67ca89SAndroid Build Coastguard Worker #include <linux/time.h> 40*8d67ca89SAndroid Build Coastguard Worker #include <signal.h> 41*8d67ca89SAndroid Build Coastguard Worker 42*8d67ca89SAndroid Build Coastguard Worker __BEGIN_DECLS 43*8d67ca89SAndroid Build Coastguard Worker 44*8d67ca89SAndroid Build Coastguard Worker typedef unsigned long fd_mask; 45*8d67ca89SAndroid Build Coastguard Worker 46*8d67ca89SAndroid Build Coastguard Worker /** 47*8d67ca89SAndroid Build Coastguard Worker * The limit on the largest fd that can be used with fd_set. 48*8d67ca89SAndroid Build Coastguard Worker * Use <poll.h> instead. 49*8d67ca89SAndroid Build Coastguard Worker */ 50*8d67ca89SAndroid Build Coastguard Worker #define FD_SETSIZE 1024 51*8d67ca89SAndroid Build Coastguard Worker #define NFDBITS (8 * sizeof(fd_mask)) 52*8d67ca89SAndroid Build Coastguard Worker 53*8d67ca89SAndroid Build Coastguard Worker /** 54*8d67ca89SAndroid Build Coastguard Worker * The type of a file descriptor set. Limited to 1024 fds. 55*8d67ca89SAndroid Build Coastguard Worker * The underlying system calls do not have this limit, 56*8d67ca89SAndroid Build Coastguard Worker * and callers can allocate their own sets with calloc(). 57*8d67ca89SAndroid Build Coastguard Worker * 58*8d67ca89SAndroid Build Coastguard Worker * Use <poll.h> instead. 59*8d67ca89SAndroid Build Coastguard Worker */ 60*8d67ca89SAndroid Build Coastguard Worker typedef struct { 61*8d67ca89SAndroid Build Coastguard Worker fd_mask fds_bits[FD_SETSIZE/NFDBITS]; 62*8d67ca89SAndroid Build Coastguard Worker } fd_set; 63*8d67ca89SAndroid Build Coastguard Worker 64*8d67ca89SAndroid Build Coastguard Worker #define __FDELT(fd) ((fd) / NFDBITS) 65*8d67ca89SAndroid Build Coastguard Worker #define __FDMASK(fd) (1UL << ((fd) % NFDBITS)) 66*8d67ca89SAndroid Build Coastguard Worker #define __FDS_BITS(type, set) (__BIONIC_CAST(static_cast, type, set)->fds_bits) 67*8d67ca89SAndroid Build Coastguard Worker 68*8d67ca89SAndroid Build Coastguard Worker void __FD_CLR_chk(int, fd_set* _Nonnull , size_t); 69*8d67ca89SAndroid Build Coastguard Worker void __FD_SET_chk(int, fd_set* _Nonnull, size_t); 70*8d67ca89SAndroid Build Coastguard Worker int __FD_ISSET_chk(int, const fd_set* _Nonnull, size_t); 71*8d67ca89SAndroid Build Coastguard Worker 72*8d67ca89SAndroid Build Coastguard Worker /** FD_CLR() with no bounds checking for users that allocated their own set. */ 73*8d67ca89SAndroid Build Coastguard Worker #define __FD_CLR(fd, set) (__FDS_BITS(fd_set*, set)[__FDELT(fd)] &= ~__FDMASK(fd)) 74*8d67ca89SAndroid Build Coastguard Worker /** FD_SET() with no bounds checking for users that allocated their own set. */ 75*8d67ca89SAndroid Build Coastguard Worker #define __FD_SET(fd, set) (__FDS_BITS(fd_set*, set)[__FDELT(fd)] |= __FDMASK(fd)) 76*8d67ca89SAndroid Build Coastguard Worker /** FD_ISSET() with no bounds checking for users that allocated their own set. */ 77*8d67ca89SAndroid Build Coastguard Worker #define __FD_ISSET(fd, set) ((__FDS_BITS(const fd_set*, set)[__FDELT(fd)] & __FDMASK(fd)) != 0) 78*8d67ca89SAndroid Build Coastguard Worker 79*8d67ca89SAndroid Build Coastguard Worker /** Removes all 1024 fds from the given set. Use <poll.h> instead. */ 80*8d67ca89SAndroid Build Coastguard Worker #define FD_ZERO(set) __builtin_memset(set, 0, sizeof(*__BIONIC_CAST(static_cast, const fd_set*, set))) 81*8d67ca89SAndroid Build Coastguard Worker 82*8d67ca89SAndroid Build Coastguard Worker /** Removes `fd` from the given set. Limited to fds under 1024. Use <poll.h> instead. */ 83*8d67ca89SAndroid Build Coastguard Worker #define FD_CLR(fd, set) __FD_CLR_chk(fd, set, __bos(set)) 84*8d67ca89SAndroid Build Coastguard Worker /** Adds `fd` to the given set. Limited to fds under 1024. Use <poll.h> instead. */ 85*8d67ca89SAndroid Build Coastguard Worker #define FD_SET(fd, set) __FD_SET_chk(fd, set, __bos(set)) 86*8d67ca89SAndroid Build Coastguard Worker /** Tests whether `fd` is in the given set. Limited to fds under 1024. Use <poll.h> instead. */ 87*8d67ca89SAndroid Build Coastguard Worker #define FD_ISSET(fd, set) __FD_ISSET_chk(fd, set, __bos(set)) 88*8d67ca89SAndroid Build Coastguard Worker 89*8d67ca89SAndroid Build Coastguard Worker /** 90*8d67ca89SAndroid Build Coastguard Worker * [select(2)](https://man7.org/linux/man-pages/man2/select.2.html) waits on a 91*8d67ca89SAndroid Build Coastguard Worker * set of file descriptors. 92*8d67ca89SAndroid Build Coastguard Worker * 93*8d67ca89SAndroid Build Coastguard Worker * Use poll() instead. 94*8d67ca89SAndroid Build Coastguard Worker * 95*8d67ca89SAndroid Build Coastguard Worker * Returns the number of ready file descriptors on success, 0 for timeout, 96*8d67ca89SAndroid Build Coastguard Worker * and returns -1 and sets `errno` on failure. 97*8d67ca89SAndroid Build Coastguard Worker */ 98*8d67ca89SAndroid Build Coastguard Worker int select(int __max_fd_plus_one, fd_set* _Nullable __read_fds, fd_set* _Nullable __write_fds, fd_set* _Nullable __exception_fds, struct timeval* _Nullable __timeout); 99*8d67ca89SAndroid Build Coastguard Worker 100*8d67ca89SAndroid Build Coastguard Worker /** 101*8d67ca89SAndroid Build Coastguard Worker * [pselect(2)](https://man7.org/linux/man-pages/man2/select.2.html) waits on a 102*8d67ca89SAndroid Build Coastguard Worker * set of file descriptors. 103*8d67ca89SAndroid Build Coastguard Worker * 104*8d67ca89SAndroid Build Coastguard Worker * Use ppoll() instead. 105*8d67ca89SAndroid Build Coastguard Worker * 106*8d67ca89SAndroid Build Coastguard Worker * Returns the number of ready file descriptors on success, 0 for timeout, 107*8d67ca89SAndroid Build Coastguard Worker * and returns -1 and sets `errno` on failure. 108*8d67ca89SAndroid Build Coastguard Worker */ 109*8d67ca89SAndroid Build Coastguard Worker int pselect(int __max_fd_plus_one, fd_set* _Nullable __read_fds, fd_set* _Nullable __write_fds, fd_set* _Nullable __exception_fds, const struct timespec* _Nullable __timeout, const sigset_t* _Nullable __mask); 110*8d67ca89SAndroid Build Coastguard Worker 111*8d67ca89SAndroid Build Coastguard Worker /** 112*8d67ca89SAndroid Build Coastguard Worker * [pselect64(2)](https://man7.org/linux/man-pages/man2/select.2.html) waits on a 113*8d67ca89SAndroid Build Coastguard Worker * set of file descriptors. 114*8d67ca89SAndroid Build Coastguard Worker * 115*8d67ca89SAndroid Build Coastguard Worker * Use ppoll64() instead. 116*8d67ca89SAndroid Build Coastguard Worker * 117*8d67ca89SAndroid Build Coastguard Worker * Returns the number of ready file descriptors on success, 0 for timeout, 118*8d67ca89SAndroid Build Coastguard Worker * and returns -1 and sets `errno` on failure. 119*8d67ca89SAndroid Build Coastguard Worker * 120*8d67ca89SAndroid Build Coastguard Worker * Available since API level 28. 121*8d67ca89SAndroid Build Coastguard Worker */ 122*8d67ca89SAndroid Build Coastguard Worker 123*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(28) 124*8d67ca89SAndroid Build Coastguard Worker int pselect64(int __max_fd_plus_one, fd_set* _Nullable __read_fds, fd_set* _Nullable __write_fds, fd_set* _Nullable __exception_fds, const struct timespec* _Nullable __timeout, const sigset64_t* _Nullable __mask) __INTRODUCED_IN(28); 125*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(28) */ 126*8d67ca89SAndroid Build Coastguard Worker 127*8d67ca89SAndroid Build Coastguard Worker 128*8d67ca89SAndroid Build Coastguard Worker __END_DECLS 129