Skip to content
This repository has been archived by the owner on Apr 22, 2023. It is now read-only.

Commit

Permalink
uv: upgrade to 6490c6a
Browse files Browse the repository at this point in the history
  • Loading branch information
bnoordhuis committed Aug 25, 2011
1 parent 64b4168 commit 576b116
Show file tree
Hide file tree
Showing 3 changed files with 142 additions and 9 deletions.
18 changes: 15 additions & 3 deletions deps/uv/src/uv-unix.c
Expand Up @@ -44,14 +44,26 @@
#include <sys/uio.h> /* writev */
#include <poll.h>

#ifdef __linux__
#if defined(__linux__)

#include <linux/version.h>
#include <features.h>

#undef HAVE_PIPE2
#undef HAVE_ACCEPT4

/* pipe2() requires linux >= 2.6.27 and glibc >= 2.9 */
#if defined(LINUX_VERSION_CODE) && defined(__GLIBC_PREREQ) && LINUX_VERSION_CODE >= 0x2061B && __GLIBC_PREREQ(2, 9)
#if LINUX_VERSION_CODE >= 0x2061B && __GLIBC_PREREQ(2, 9)
#define HAVE_PIPE2
#endif

/* accept4() requires linux >= 2.6.28 and glib >= 2.10 */
#if LINUX_VERSION_CODE >= 0x2061C && __GLIBC_PREREQ(2, 10)
#define HAVE_ACCEPT4
#endif

#endif /* __linux__ */

#ifdef __sun
# include <sys/types.h>
# include <sys/wait.h>
Expand Down Expand Up @@ -2601,7 +2613,7 @@ static int uv__accept(int sockfd, struct sockaddr* saddr, socklen_t slen) {
assert(sockfd >= 0);

do {
#if defined(SOCK_NONBLOCK) && defined(SOCK_CLOEXEC)
#if defined(HAVE_ACCEPT4)
peerfd = accept4(sockfd, saddr, &slen, SOCK_NONBLOCK | SOCK_CLOEXEC);
#else
if ((peerfd = accept(sockfd, saddr, &slen)) != -1) {
Expand Down
127 changes: 123 additions & 4 deletions deps/uv/test/test-getsockname.c
Expand Up @@ -22,15 +22,19 @@
#include "uv.h"
#include "task.h"

#include <stdlib.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

static int getsocknamecount = 0;

static int getsocknamecount = 0;

static uv_tcp_t tcp;
static uv_udp_t udp;
static uv_connect_t connect_req;
static uv_tcp_t tcpServer;
static uv_udp_t udpServer;
static uv_udp_send_t send_req;


static uv_buf_t alloc(uv_handle_t* handle, size_t suggested_size) {
Expand Down Expand Up @@ -99,7 +103,6 @@ static void on_connection(uv_stream_t* server, int status) {

r = uv_read_start((uv_stream_t*)handle, alloc, after_read);
ASSERT(r == 0);

}


Expand Down Expand Up @@ -147,6 +150,8 @@ static int tcp_listener(int port) {
return 1;
}

memset(&sockname, -1, sizeof sockname);

r = uv_getsockname((uv_handle_t*)&tcpServer, &sockname, &namelen);
if (r != 0) {
fprintf(stderr, "uv_getsockname error (listening) %d\n", uv_last_error().code);
Expand Down Expand Up @@ -179,7 +184,106 @@ static void tcp_connector() {
}


TEST_IMPL(getsockname) {
static void udp_recv(uv_udp_t* handle,
ssize_t nread,
uv_buf_t buf,
struct sockaddr* addr,
unsigned flags) {
struct sockaddr sockname;
char ip[20];
int namelen;
int r;

ASSERT(nread >= 0);

if (nread == 0) {
uv_close((uv_handle_t*)handle, NULL);
free(buf.base);
return;
}

namelen = sizeof(sockname);
r = uv_getsockname((uv_handle_t*)&udp, &sockname, &namelen);
if (r != 0) {
fprintf(stderr, "uv_getsockname error (connector) %d\n", uv_last_error().code);
}
ASSERT(r == 0);

r = uv_ip4_name((struct sockaddr_in*)&sockname, ip, 20);
ASSERT(r == 0);
printf("sockname = %s\n", ip);

getsocknamecount++;

uv_close((uv_handle_t*)&udp, NULL);
}


static void udp_send(uv_udp_send_t* req, int status) {

}


static int udp_listener(int port) {
struct sockaddr_in addr = uv_ip4_addr("0.0.0.0", port);
struct sockaddr sockname;
int namelen = sizeof(sockname);
char ip[20];
int r;

r = uv_udp_init(&udpServer);
if (r) {
fprintf(stderr, "Socket creation error\n");
return 1;
}

r = uv_udp_bind(&udpServer, addr, 0);
if (r) {
fprintf(stderr, "Bind error\n");
return 1;
}

memset(&sockname, -1, sizeof sockname);

r = uv_getsockname((uv_handle_t*)&udpServer, &sockname, &namelen);
if (r != 0) {
fprintf(stderr, "uv_getsockname error (listening) %d\n", uv_last_error().code);
}
ASSERT(r == 0);

r = uv_ip4_name((struct sockaddr_in*)&sockname, ip, 20);
ASSERT(r == 0);
ASSERT(ip[0] == '0');
ASSERT(ip[1] == '.');
ASSERT(ip[2] == '0');
printf("sockname = %s\n", ip);

getsocknamecount++;

r = uv_udp_recv_start(&udpServer, alloc, udp_recv);
ASSERT(r == 0);

return 0;
}


static void udp_sender(void) {
struct sockaddr_in server_addr;
uv_buf_t buf;
int r;

r = uv_udp_init(&udp);
ASSERT(!r);

buf = uv_buf_init("PING", 4);
server_addr = uv_ip4_addr("127.0.0.1", TEST_PORT);

r = uv_udp_send(&send_req, &udp, &buf, 1, server_addr, udp_send);
ASSERT(!r);
}


TEST_IMPL(getsockname_tcp) {
uv_init();

if (tcp_listener(TEST_PORT))
Expand All @@ -194,3 +298,18 @@ TEST_IMPL(getsockname) {
return 0;
}


TEST_IMPL(getsockname_udp) {
uv_init();

if (udp_listener(TEST_PORT))
return 1;

udp_sender();

uv_run();

ASSERT(getsocknamecount == 2);

return 0;
}
6 changes: 4 additions & 2 deletions deps/uv/test/test-list.h
Expand Up @@ -64,7 +64,8 @@ TEST_DECLARE (hrtime)
TEST_DECLARE (getaddrinfo_basic)
TEST_DECLARE (getaddrinfo_concurrent)
TEST_DECLARE (gethostbyname)
TEST_DECLARE (getsockname)
TEST_DECLARE (getsockname_tcp)
TEST_DECLARE (getsockname_udp)
TEST_DECLARE (fail_always)
TEST_DECLARE (pass_always)
TEST_DECLARE (spawn_exit_code)
Expand Down Expand Up @@ -156,7 +157,8 @@ TASK_LIST_START
TEST_ENTRY (gethostbyname)
TEST_HELPER (gethostbyname, tcp4_echo_server)

TEST_ENTRY (getsockname)
TEST_ENTRY (getsockname_tcp)
TEST_ENTRY (getsockname_udp)

TEST_ENTRY (spawn_exit_code)
TEST_ENTRY (spawn_stdout)
Expand Down

0 comments on commit 576b116

Please sign in to comment.