diff options
Diffstat (limited to 'ext/socket/init.c')
-rw-r--r-- | ext/socket/init.c | 36 |
1 files changed, 16 insertions, 20 deletions
diff --git a/ext/socket/init.c b/ext/socket/init.c index b35226ab78..990f1a4d6b 100644 --- a/ext/socket/init.c +++ b/ext/socket/init.c @@ -240,34 +240,30 @@ rsock_s_recvfrom_nonblock(VALUE sock, int argc, VALUE *argv, enum sock_recv_type } static int -rsock_socket0(int domain, int type0, int proto) +rsock_socket0(int domain, int type, int proto) { - int ret, type; + int ret; #ifdef SOCK_CLOEXEC static int try_sock_cloexec = 1; - if (try_sock_cloexec) - type = type0|SOCK_CLOEXEC; - else - type = type0; - retry_without_sock_cloexec:; + if (try_sock_cloexec) { + ret = socket(domain, type|SOCK_CLOEXEC, proto); + if (ret == -1 && errno == EINVAL) { + /* SOCK_CLOEXEC is available since Linux 2.6.27. Linux 2.6.18 fails with EINVAL */ + ret = socket(domain, type, proto); + if (ret != -1) { + try_sock_cloexec = 0; + } + } + } + else { + ret = socket(domain, type, proto); + } #else - type = type0; -#endif - ret = socket(domain, type, proto); - - if (ret == -1) { -#ifdef SOCK_CLOEXEC - /* SOCK_CLOEXEC is available since Linux 2.6.27. Linux 2.6.18 fails with EINVAL */ - if (try_sock_cloexec && errno == EINVAL) { - try_sock_cloexec = 0; - type = type0; - goto retry_without_sock_cloexec; - } #endif + if (ret == -1) return -1; - } rb_fd_fix_cloexec(ret); |