diff options
author | Richard Braun <rbraun@sceen.net> | 2019-08-30 01:16:37 +0200 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2019-08-30 01:16:37 +0200 |
commit | c3010778d5846f0f16278f8e94763efb59cd5761 (patch) | |
tree | 6cfc4d253c71e0a1617270f0c04e5cd4fd563983 /hurd/Makefile | |
parent | 90f0f97ccba34efa6ac8d7d4d77db5d473e8da32 (diff) | |
download | glibc-c3010778d5846f0f16278f8e94763efb59cd5761.zip glibc-c3010778d5846f0f16278f8e94763efb59cd5761.tar.gz glibc-c3010778d5846f0f16278f8e94763efb59cd5761.tar.bz2 |
hurd: Fix timeout handling in _hurd_select
Rely on servers to implement timeouts, so that very short values (including
0) don't make mach_msg return before valid replies can be received. The
purpose of this scheme is to guarantee a full client-server round-trip,
whatever the timeout value.
This change depends on the new io_select_timeout RPC being implemented by
servers.
* hurd/Makefile (user-interfaces): Add io_reply and io_request.
* hurd/hurdselect.c: Include <sys/time.h>, <hurd/io_request.h> and
<limits.h>.
(_hurd_select): Replace the call to __io_select with either
__io_select_request or __io_select_timeout_request, depending on the
timeout. Count the number of ready descriptors (replies for which at
least one type bit is set). Implement the timeout locally when there is
no file descriptor.
Diffstat (limited to 'hurd/Makefile')
-rw-r--r-- | hurd/Makefile | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/hurd/Makefile b/hurd/Makefile index 99d33f9..6d9cbf5 100644 --- a/hurd/Makefile +++ b/hurd/Makefile @@ -33,7 +33,8 @@ user-interfaces := $(addprefix hurd/,\ process process_request \ msg msg_reply msg_request \ exec exec_startup crash interrupt \ - fs fsys io term tioctl socket ifsock \ + fs fsys io io_reply io_request \ + term tioctl socket ifsock \ login password pfinet pci \ ) server-interfaces := hurd/msg faultexc |