Skip to content

Commit

Permalink
deps: upgrade libuv to cb03e3b
Browse files Browse the repository at this point in the history
  • Loading branch information
bnoordhuis committed Oct 10, 2012
1 parent 0ad0058 commit 5823290
Show file tree
Hide file tree
Showing 12 changed files with 444 additions and 37 deletions.
17 changes: 17 additions & 0 deletions deps/uv/include/uv-private/uv-unix.h
Original file line number Diff line number Diff line change
Expand Up @@ -108,6 +108,23 @@ typedef pthread_rwlock_t uv_rwlock_t;
typedef UV_PLATFORM_SEM_T uv_sem_t;
typedef pthread_cond_t uv_cond_t;


#if defined(__APPLE__) && defined(__MACH__)

typedef struct {
unsigned int n;
unsigned int count;
uv_mutex_t mutex;
uv_sem_t turnstile1;
uv_sem_t turnstile2;
} uv_barrier_t;

#else /* defined(__APPLE__) && defined(__MACH__) */

typedef pthread_barrier_t uv_barrier_t;

#endif /* defined(__APPLE__) && defined(__MACH__) */

/* Platform-specific definitions for uv_spawn support. */
typedef gid_t uv_gid_t;
typedef uid_t uv_uid_t;
Expand Down
8 changes: 8 additions & 0 deletions deps/uv/include/uv-private/uv-win.h
Original file line number Diff line number Diff line change
Expand Up @@ -240,6 +240,14 @@ typedef union {
} fallback_;
} uv_rwlock_t;

typedef struct {
unsigned int n;
unsigned int count;
uv_mutex_t mutex;
uv_sem_t turnstile1;
uv_sem_t turnstile2;
} uv_barrier_t;

#define UV_ONCE_INIT { 0, NULL }

typedef struct uv_once_s {
Expand Down
23 changes: 13 additions & 10 deletions deps/uv/include/uv.h
Original file line number Diff line number Diff line change
Expand Up @@ -352,11 +352,11 @@ UV_EXTERN const char* uv_err_name(uv_err_t err);
#define UV_REQ_FIELDS \
/* public */ \
void* data; \
/* read-only */ \
uv_req_type type; \
/* private */ \
ngx_queue_t active_queue; \
UV_REQ_PRIVATE_FIELDS \
/* read-only */ \
uv_req_type type; \

/* Abstract base class of all requests. */
struct uv_req_s {
Expand Down Expand Up @@ -1262,14 +1262,6 @@ typedef struct uv_process_options_s {
* `enum uv_process_flags` below.
*/
unsigned int flags;
/*
* Libuv can change the child process' user/group id. This happens only when
* the appropriate bits are set in the flags fields. This is not supported on
* windows; uv_spawn() will fail and set the error to UV_ENOTSUP.
*/
uv_uid_t uid;
uv_gid_t gid;

/*
* The `stdio` field points to an array of uv_stdio_container_t structs that
* describe the file descriptors that will be made available to the child
Expand All @@ -1281,6 +1273,13 @@ typedef struct uv_process_options_s {
*/
int stdio_count;
uv_stdio_container_t* stdio;
/*
* Libuv can change the child process' user/group id. This happens only when
* the appropriate bits are set in the flags fields. This is not supported on
* windows; uv_spawn() will fail and set the error to UV_ENOTSUP.
*/
uv_uid_t uid;
uv_gid_t gid;
} uv_process_options_t;

/*
Expand Down Expand Up @@ -1822,6 +1821,10 @@ UV_EXTERN void uv_cond_wait(uv_cond_t* cond, uv_mutex_t* mutex);
UV_EXTERN int uv_cond_timedwait(uv_cond_t* cond, uv_mutex_t* mutex,
uint64_t timeout);

UV_EXTERN int uv_barrier_init(uv_barrier_t* barrier, unsigned int count);
UV_EXTERN void uv_barrier_destroy(uv_barrier_t* barrier);
UV_EXTERN void uv_barrier_wait(uv_barrier_t* barrier);

/* Runs a function once and only once. Concurrent calls to uv_once() with the
* same guard will block all callers except one (it's unspecified which one).
* The guard should be initialized statically with the UV_ONCE_INIT macro.
Expand Down
39 changes: 19 additions & 20 deletions deps/uv/src/unix/fs.c
Original file line number Diff line number Diff line change
Expand Up @@ -133,24 +133,6 @@ static ssize_t uv__fs_futime(uv_fs_t* req) {
}


static ssize_t uv__fs_pwrite(uv_fs_t* req) {
#if defined(__APPLE__)
/* Serialize writes on OS X, concurrent pwrite() calls result in data loss.
* We can't use a per-file descriptor lock, the descriptor may be a dup().
*/
static pthread_mutex_t lock = PTHREAD_MUTEX_INITIALIZER;
ssize_t r;

pthread_mutex_lock(&lock);
r = pwrite(req->file, req->buf, req->len, req->off);
pthread_mutex_unlock(&lock);

return r;
#else
return pwrite(req->file, req->buf, req->len, req->off);
#endif
}

static ssize_t uv__fs_read(uv_fs_t* req) {
if (req->off < 0)
return read(req->file, req->buf, req->len);
Expand Down Expand Up @@ -447,10 +429,27 @@ static ssize_t uv__fs_utime(uv_fs_t* req) {


static ssize_t uv__fs_write(uv_fs_t* req) {
ssize_t r;

/* Serialize writes on OS X, concurrent write() and pwrite() calls result in
* data loss. We can't use a per-file descriptor lock, the descriptor may be
* a dup().
*/
#if defined(__APPLE__)
static pthread_mutex_t lock = PTHREAD_MUTEX_INITIALIZER;
pthread_mutex_lock(&lock);
#endif

if (req->off < 0)
return write(req->file, req->buf, req->len);
r = write(req->file, req->buf, req->len);
else
return uv__fs_pwrite(req);
r = pwrite(req->file, req->buf, req->len, req->off);

#if defined(__APPLE__)
pthread_mutex_unlock(&lock);
#endif

return r;
}


Expand Down
80 changes: 80 additions & 0 deletions deps/uv/src/unix/thread.c
Original file line number Diff line number Diff line change
Expand Up @@ -370,3 +370,83 @@ int uv_cond_timedwait(uv_cond_t* cond, uv_mutex_t* mutex, uint64_t timeout) {
}

#endif /* defined(__APPLE__) && defined(__MACH__) */


#if defined(__APPLE__) && defined(__MACH__)

int uv_barrier_init(uv_barrier_t* barrier, unsigned int count) {
barrier->n = count;
barrier->count = 0;

if (uv_mutex_init(&barrier->mutex))
return -1;

if (uv_sem_init(&barrier->turnstile1, 0))
goto error2;

if (uv_sem_init(&barrier->turnstile2, 1))
goto error;

return 0;

error:
uv_sem_destroy(&barrier->turnstile1);
error2:
uv_mutex_destroy(&barrier->mutex);
return -1;

}


void uv_barrier_destroy(uv_barrier_t* barrier) {
uv_sem_destroy(&barrier->turnstile2);
uv_sem_destroy(&barrier->turnstile1);
uv_mutex_destroy(&barrier->mutex);
}


void uv_barrier_wait(uv_barrier_t* barrier) {
uv_mutex_lock(&barrier->mutex);
if (++barrier->count == barrier->n) {
uv_sem_wait(&barrier->turnstile2);
uv_sem_post(&barrier->turnstile1);
}
uv_mutex_unlock(&barrier->mutex);

uv_sem_wait(&barrier->turnstile1);
uv_sem_post(&barrier->turnstile1);

uv_mutex_lock(&barrier->mutex);
if (--barrier->count == 0) {
uv_sem_wait(&barrier->turnstile1);
uv_sem_post(&barrier->turnstile2);
}
uv_mutex_unlock(&barrier->mutex);

uv_sem_wait(&barrier->turnstile2);
uv_sem_post(&barrier->turnstile2);
}

#else /* !(defined(__APPLE__) && defined(__MACH__)) */

int uv_barrier_init(uv_barrier_t* barrier, unsigned int count) {
if (pthread_barrier_init(barrier, NULL, count))
return -1;
else
return 0;
}


void uv_barrier_destroy(uv_barrier_t* barrier) {
if (pthread_barrier_destroy(barrier))
abort();
}


void uv_barrier_wait(uv_barrier_t* barrier) {
int r = pthread_barrier_wait(barrier);
if (r && r != PTHREAD_BARRIER_SERIAL_THREAD)
abort();
}

#endif /* defined(__APPLE__) && defined(__MACH__) */
11 changes: 5 additions & 6 deletions deps/uv/src/unix/threadpool.c
Original file line number Diff line number Diff line change
Expand Up @@ -98,18 +98,17 @@ static void init_once(void) {
__attribute__((destructor))
static void cleanup(void) {
unsigned int i;
int err;

if (initialized == 0)
return;

post(&exit_message);

for (i = 0; i < ARRAY_SIZE(threads); i++) {
err = pthread_join(threads[i], NULL);
assert(err == 0 || err == ESRCH);
(void) err; /* Silence compiler warning in release builds. */
}
for (i = 0; i < ARRAY_SIZE(threads); i++)
if (pthread_join(threads[i], NULL))
abort();

initialized = 0;
}


Expand Down
54 changes: 54 additions & 0 deletions deps/uv/src/win/thread.c
Original file line number Diff line number Diff line change
Expand Up @@ -610,3 +610,57 @@ int uv_cond_timedwait(uv_cond_t* cond, uv_mutex_t* mutex,
else
return uv_cond_fallback_timedwait(cond, mutex, timeout);
}


int uv_barrier_init(uv_barrier_t* barrier, unsigned int count) {
barrier->n = count;
barrier->count = 0;

if (uv_mutex_init(&barrier->mutex))
return -1;

if (uv_sem_init(&barrier->turnstile1, 0))
goto error2;

if (uv_sem_init(&barrier->turnstile2, 1))
goto error;

return 0;

error:
uv_sem_destroy(&barrier->turnstile1);
error2:
uv_mutex_destroy(&barrier->mutex);
return -1;

}


void uv_barrier_destroy(uv_barrier_t* barrier) {
uv_sem_destroy(&barrier->turnstile2);
uv_sem_destroy(&barrier->turnstile1);
uv_mutex_destroy(&barrier->mutex);
}


void uv_barrier_wait(uv_barrier_t* barrier) {
uv_mutex_lock(&barrier->mutex);
if (++barrier->count == barrier->n) {
uv_sem_wait(&barrier->turnstile2);
uv_sem_post(&barrier->turnstile1);
}
uv_mutex_unlock(&barrier->mutex);

uv_sem_wait(&barrier->turnstile1);
uv_sem_post(&barrier->turnstile1);

uv_mutex_lock(&barrier->mutex);
if (--barrier->count == 0) {
uv_sem_wait(&barrier->turnstile1);
uv_sem_post(&barrier->turnstile2);
}
uv_mutex_unlock(&barrier->mutex);

uv_sem_wait(&barrier->turnstile2);
uv_sem_post(&barrier->turnstile2);
}
7 changes: 6 additions & 1 deletion deps/uv/test/runner-win.c
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,10 @@
#include <malloc.h>
#include <stdio.h>
#include <process.h>
#include <crtdbg.h>
#if !defined(__MINGW32__)
# include <crtdbg.h>
#endif


#include "task.h"
#include "runner.h"
Expand All @@ -44,8 +47,10 @@ void platform_init(int argc, char **argv) {
/* Disable the "application crashed" popup. */
SetErrorMode(SEM_FAILCRITICALERRORS | SEM_NOGPFAULTERRORBOX |
SEM_NOOPENFILEERRORBOX);
#if !defined(__MINGW32__)
_CrtSetReportMode(_CRT_ASSERT, _CRTDBG_MODE_DEBUG);
_CrtSetReportMode(_CRT_ERROR, _CRTDBG_MODE_DEBUG);
#endif

_setmode(0, _O_BINARY);
_setmode(1, _O_BINARY);
Expand Down
Loading

0 comments on commit 5823290

Please sign in to comment.