From: Thomas Schwinge Date: Sat, 3 Mar 2018 10:47:56 +0000 (+0000) Subject: socket_flags X-Git-Tag: archive/raspbian/2.27-1+rpi1^2~91 X-Git-Url: https://dgit.raspbian.org/?a=commitdiff_plain;h=0d6778406f6e87ca16d6489215fab797b1fa6c31;p=glibc.git socket_flags 2008-12-17 Thomas Schwinge SOCK_CLOEXEC and SOCK_NONBLOCK for socket on GNU Hurd. * sysdeps/mach/hurd/socket.c (__socket): Handle SOCK_CLOEXEC and SOCK_NONBLOCK. * sysdeps/mach/hurd/kernel-features.h (__ASSUME_SOCK_CLOEXEC): Define. Gbp-Pq: Topic hurd-i386 Gbp-Pq: Name tg-socket_flags.diff --- diff --git a/sysdeps/mach/hurd/socket.c b/sysdeps/mach/hurd/socket.c index 2c1b98c9e..43f2c3b2b 100644 --- a/sysdeps/mach/hurd/socket.c +++ b/sysdeps/mach/hurd/socket.c @@ -21,6 +21,7 @@ #include #include #include +#include /* Create a new socket of type TYPE in domain DOMAIN, using protocol PROTOCOL. If PROTOCOL is zero, one is chosen automatically. @@ -30,6 +31,11 @@ __socket (int domain, int type, int protocol) { error_t err; socket_t sock, server; + int flags = sock_to_o_flags (type & ~SOCK_TYPE_MASK); + type &= SOCK_TYPE_MASK; + + if (flags & ~(O_CLOEXEC | O_NONBLOCK)) + return __hurd_fail (EINVAL); /* Find the socket server for DOMAIN. */ server = _hurd_socket_server (domain, 0); @@ -55,10 +61,17 @@ __socket (int domain, int type, int protocol) || err == MIG_BAD_ID || err == EOPNOTSUPP) err = EAFNOSUPPORT; + if (! err) + { + if (flags & O_NONBLOCK) + err = __io_set_some_openmodes (sock, O_NONBLOCK); + /* TODO: do we need special ERR massaging after the previous call? */ + } + if (err) return __hurd_fail (err); - return _hurd_intern_fd (sock, O_IGNORE_CTTY, 1); + return _hurd_intern_fd (sock, O_IGNORE_CTTY | flags, 1); } libc_hidden_def (__socket)