'LinkIncremental': 2, # enable incremental linking
},
},
+ 'xcode_settings': {
+ 'GCC_OPTIMIZATION_LEVEL': '0',
+ },
'conditions': [
['OS != "win"', {
'defines': [ 'EV_VERIFY=2' ],
while (1) {
#if __linux__
+ static int no_accept4;
+
+ if (no_accept4)
+ goto skip;
+
peerfd = uv__accept4(sockfd,
NULL,
NULL,
if (errno != ENOSYS)
break;
+
+ no_accept4 = 1;
+skip:
#endif
peerfd = accept(sockfd, NULL, NULL);
int uv__accept4(int fd, struct sockaddr* addr, socklen_t* addrlen, int flags) {
#if __i386__
- unsigned long args[] = {
- (unsigned long) fd,
- (unsigned long) addr,
- (unsigned long) addrlen,
- (unsigned long) flags
- };
- return syscall(__NR_socketcall, 18 /* SYS_ACCEPT4 */, args);
+ unsigned long args[4];
+ int r;
+
+ args[0] = (unsigned long) fd;
+ args[1] = (unsigned long) addr;
+ args[2] = (unsigned long) addrlen;
+ args[3] = (unsigned long) flags;
+
+ r = syscall(__NR_socketcall, 18 /* SYS_ACCEPT4 */, args);
+
+ /* socketcall() raises EINVAL when SYS_ACCEPT4 is not supported but so does
+ * a bad flags argument. Try to distinguish between the two cases.
+ */
+ if (r == -1)
+ if (errno == EINVAL)
+ if ((flags & ~(UV__SOCK_CLOEXEC|UV__SOCK_NONBLOCK)) == 0)
+ errno = ENOSYS;
+
+ return r;
#elif __NR_accept4
return syscall(__NR_accept4, fd, addr, addrlen, flags);
#else