diff options
author | Robert Pluim <rpluim@gmail.com> | 2022-05-04 17:09:07 +0200 |
---|---|---|
committer | Robert Pluim <rpluim@gmail.com> | 2022-05-05 19:30:15 +0200 |
commit | 2087e5eb2bf6cfefe74b6b589c215c2144ed9fb0 (patch) | |
tree | 27b4865f176452535ec02666b16331ecf44445d7 /src/sysselect.h | |
parent | aebff74af27157b60a0d6549be718d85a809b985 (diff) | |
download | emacs-feature/more-fds.tar.gz |
Allow the use of poll instead of selectfeature/more-fds
Increase the maximum number of open files allowed to
10 x FD_SETSIZE (which is what poll is limited to on macOS).
* configure.ac (--with-poll): New option, default off, for requesting
'poll' support. Check for "sys/poll.h" header.
(USE_POLL): New variable.
(EMACS_CONFIG_FEATURES): Add USE_POLL.
* etc/NEWS: Document --with-poll.
* src/sysselect.h: New define EMACS_MAX_FD, defaulting to FD_SETSIZE,
for the maximum number of file descriptors Emacs can use.
* src/process.c:
* src/sysdep.c:
* src/nsterm.m (ns_select_1):
(applicationDidFinishLaunching): Use EMACS_MAX_FD instead of
FD_SETSIZE everywhere.
* src/syspoll.h (SYSPOLL_H): New file for definitions related to use
of 'poll'.
* src/sysselect.h [USE_POLL]: Set EMACS_MAX_FD to 10 x FD_SETSIZE.
(emacs_fd_set) [USE_POLL]: New type, used for bitsets of file
descriptors.
(FD_CLR, FD_ISSET, FD_SET, FD_ZERO) [USE_POLL]: Macros for
manipulating bitsets.
[USE_POLL]: Include "syspoll.h".
* src/process.c (fd_sets_to_pollfds) [USE_POLL]: New function.
Converts two 'emacs_fd_set' to an array of 'struct pollfd'
(pollfds_to_fd_sets) [USE_POLL]: New function.
Converts from an array of 'struct pollfd' to two 'emacs_fd_set'.
(timespec_to_timeout) [USE_POLL]: New function, converts a 'struct
timespec' to a timeout in milliseconds.
(emacs_pselect) [USE_POLL]: Replacement for 'pselect' that calls
'poll' and does the appropriate conversions. Does not support
sigmask.
Diffstat (limited to 'src/sysselect.h')
-rw-r--r-- | src/sysselect.h | 38 |
1 files changed, 35 insertions, 3 deletions
diff --git a/src/sysselect.h b/src/sysselect.h index 45cc22bc4cb..029a913f324 100644 --- a/src/sysselect.h +++ b/src/sysselect.h @@ -29,6 +29,7 @@ along with GNU Emacs. If not, see <https://www.gnu.org/licenses/>. */ where w32 needs it, but not where sysselect.h is included. The w32 definitions in w32.h are incompatible with the below. */ #ifndef WINDOWSNT +#ifndef USE_POLL #ifdef FD_SET #ifndef FD_SETSIZE #define FD_SETSIZE 64 @@ -43,6 +44,37 @@ typedef int fd_set; #define FD_ISSET(n, p) (*(p) & (1 << (n))) #define FD_ZERO(p) (*(p) = 0) #endif /* no FD_SET */ +#define EMACS_MAX_FD FD_SETSIZE +#else /* no USE_POLL */ +#define EMACS_MAX_FD (10 * FD_SETSIZE) +#define fd_set emacs_fd_set +#define pselect emacs_pselect +#undef FD_CLR +#undef FD_ISSET +#undef FD_SET +#undef FD_ZERO + +typedef struct { + EMACS_UINT bits[EMACS_MAX_FD / EMACS_UINT_WIDTH]; +} emacs_fd_set; + +/* standard access macros */ +#define FD_SET(n, p) \ + do { \ + if ((n) < EMACS_MAX_FD) { \ + (p)->bits[(n)/EMACS_UINT_WIDTH] |= (1 << (n)%EMACS_UINT_WIDTH); \ + } \ + } while (0) +#define FD_CLR(n, p) \ + do { \ + if ((n) < EMACS_MAX_FD) { \ + (p)->bits[(n)/EMACS_UINT_WIDTH] &= ~(1 << (n)%EMACS_UINT_WIDTH); \ + } \ + } while (0) +#define FD_ISSET(n, p) ((n) < EMACS_MAX_FD ? ((p)->bits[(n)/EMACS_UINT_WIDTH] & (1 << (n)%EMACS_UINT_WIDTH)) : 0) +#define FD_ZERO(p) memset((p), 0, sizeof(emacs_fd_set)) +#include "syspoll.h" +#endif /* no USE_POLL */ #endif /* not WINDOWSNT */ #if !defined (HAVE_SELECT) @@ -66,21 +98,21 @@ INLINE_HEADER_BEGIN INLINE void fd_CLR (int fd, fd_set *set) { - eassume (0 <= fd && fd < FD_SETSIZE); + eassume (0 <= fd && fd < EMACS_MAX_FD); FD_CLR (fd, set); } INLINE bool fd_ISSET (int fd, fd_set *set) { - eassume (0 <= fd && fd < FD_SETSIZE); + eassume (0 <= fd && fd < EMACS_MAX_FD); return FD_ISSET (fd, set) != 0; } INLINE void fd_SET (int fd, fd_set *set) { - eassume (0 <= fd && fd < FD_SETSIZE); + eassume (0 <= fd && fd < EMACS_MAX_FD); FD_SET (fd, set); } |