author | Rich Felker <dalias@aerifal.cx> | 2012年09月29日 17:36:27 -0400 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2012年09月29日 17:36:27 -0400 |
commit | 79a5e73e518213d5e77a06cfc0db74ffbf7922c6 (patch) | |
tree | a13e64b58de93ae8a94787414007c4db0d72843d /src | |
parent | 3d8d90c5ccf66f1d243cb1b248b047295c197b5c (diff) | |
download | musl-79a5e73e518213d5e77a06cfc0db74ffbf7922c6.tar.gz |
-rw-r--r-- | src/misc/syslog.c | 3 | ||||
-rw-r--r-- | src/network/socket.c | 15 |
diff --git a/src/misc/syslog.c b/src/misc/syslog.c index a4f36dee..8de34f8d 100644 --- a/src/misc/syslog.c +++ b/src/misc/syslog.c @@ -51,8 +51,7 @@ static void __openlog(const char *ident, int opt, int facility) if (!(opt & LOG_NDELAY) || log_fd>=0) return; - log_fd = socket(AF_UNIX, SOCK_DGRAM, 0); - fcntl(log_fd, F_SETFD, FD_CLOEXEC); + log_fd = socket(AF_UNIX, SOCK_DGRAM|SOCK_CLOEXEC, 0); } void openlog(const char *ident, int opt, int facility) diff --git a/src/network/socket.c b/src/network/socket.c index 4f1e86db..ba8d45b1 100644 --- a/src/network/socket.c +++ b/src/network/socket.c @@ -1,7 +1,20 @@ #include <sys/socket.h> +#include <fcntl.h> +#include <errno.h> #include "syscall.h" int socket(int domain, int type, int protocol) { - return socketcall(socket, domain, type, protocol, 0, 0, 0); + int s = socketcall(socket, domain, type, protocol, 0, 0, 0); + if (s<0 && errno==EINVAL && (type&(SOCK_CLOEXEC|SOCK_NONBLOCK))) { + s = socketcall(socket, domain, + type & ~(SOCK_CLOEXEC|SOCK_NONBLOCK), + protocol, 0, 0, 0); + if (s < 0) return s; + if (type & SOCK_CLOEXEC) + fcntl(s, F_SETFD, FD_CLOEXEC); + if (type & SOCK_NONBLOCK) + fcntl(s, F_SETFL, fcntl(s, F_GETFL) | O_NONBLOCK); + } + return s; } |