Commit 256a3fbf authored by Jason Madden's avatar Jason Madden

Update to libuv 1.22

parent d15664a5
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
1.3.5 (unreleased) 1.3.5 (unreleased)
================== ==================
- Update the bundled libuv from 1.20.1 to 1.21.0. - Update the bundled libuv from 1.20.1 to 1.22.0.
- Update Python versions tested on Travis, including PyPy to 6.0. See :issue:`1195`. - Update Python versions tested on Travis, including PyPy to 6.0. See :issue:`1195`.
......
...@@ -343,3 +343,5 @@ Björn Linse <bjorn.linse@gmail.com> ...@@ -343,3 +343,5 @@ Björn Linse <bjorn.linse@gmail.com>
zyxwvu Shi <i@shiyc.cn> zyxwvu Shi <i@shiyc.cn>
Peter Johnson <johnson.peter@gmail.com> Peter Johnson <johnson.peter@gmail.com>
Paolo Greppi <paolo.greppi@libpf.com> Paolo Greppi <paolo.greppi@libpf.com>
Shelley Vohr <shelley.vohr@gmail.com>
Ujjwal Sharma <usharma1998@gmail.com>
...@@ -15,6 +15,7 @@ set(uv_sources ...@@ -15,6 +15,7 @@ set(uv_sources
src/fs-poll.c src/fs-poll.c
src/inet.c src/inet.c
src/threadpool.c src/threadpool.c
src/timer.c
src/uv-common.c src/uv-common.c
src/uv-data-getter-setters.c src/uv-data-getter-setters.c
src/version.c) src/version.c)
...@@ -197,7 +198,6 @@ if(WIN32) ...@@ -197,7 +198,6 @@ if(WIN32)
src/win/stream.c src/win/stream.c
src/win/tcp.c src/win/tcp.c
src/win/tty.c src/win/tty.c
src/win/timer.c
src/win/udp.c src/win/udp.c
src/win/util.c src/win/util.c
src/win/winapi.c src/win/winapi.c
...@@ -223,7 +223,6 @@ else() ...@@ -223,7 +223,6 @@ else()
src/unix/stream.c src/unix/stream.c
src/unix/tcp.c src/unix/tcp.c
src/unix/thread.c src/unix/thread.c
src/unix/timer.c
src/unix/tty.c src/unix/tty.c
src/unix/udp.c) src/unix/udp.c)
list(APPEND uv_test_sources test/runner-unix.c) list(APPEND uv_test_sources test/runner-unix.c)
......
2018.06.23, Version 1.21.0 (Stable) 2018.07.11, Version 1.22.0 (Stable)
Changes since version 1.21.0:
* unix: remove checksparse.sh (Ben Noordhuis)
* win: fix mingw build error (Ben Noordhuis)
* win: fix -Wunused-function warnings in thread.c (Ben Noordhuis)
* unix,win: merge timers implementation (Ben Noordhuis)
* win: fix pointer type in pipe.c (Ben Noordhuis)
* win: fixing build for older MSVC compilers (Michael Fero)
* zos: clear poll events on every iteration (jBarz)
* zos: write-protect message queue (jBarz)
* zos: use correct pointer type in strnlen (jBarz)
* unix,win: merge handle flags (Ben Noordhuis)
* doc: update Imran Iqbal's GitHub handle (cjihrig)
* src: add new error apis to prevent memory leaks (Shelley Vohr)
* test: make test-condvar call uv_cond_wait (Jamie Davis)
* fs: change position of uv_fs_lchown (Ujjwal Sharma)
2018.06.23, Version 1.21.0 (Stable), e4983a9b0c152932f7553ff4a9ff189d2314cdcb
Changes since version 1.20.3: Changes since version 1.20.3:
......
...@@ -12,7 +12,7 @@ libuv is currently managed by the following individuals: ...@@ -12,7 +12,7 @@ libuv is currently managed by the following individuals:
- GPG key: 5735 3E0D BDAA A7E8 39B6 6A1A FF47 D5E4 AD8B 4FDC (pubkey-cjihrig-kb) - GPG key: 5735 3E0D BDAA A7E8 39B6 6A1A FF47 D5E4 AD8B 4FDC (pubkey-cjihrig-kb)
* **Fedor Indutny** ([@indutny](https://github.com/indutny)) * **Fedor Indutny** ([@indutny](https://github.com/indutny))
- GPG key: AF2E EA41 EC34 47BF DD86 FED9 D706 3CCE 19B7 E890 (pubkey-indutny) - GPG key: AF2E EA41 EC34 47BF DD86 FED9 D706 3CCE 19B7 E890 (pubkey-indutny)
* **Imran Iqbal** ([@iWuzHere](https://github.com/iWuzHere)) * **Imran Iqbal** ([@imran-iq](https://github.com/imran-iq))
- GPG key: 9DFE AA5F 481B BF77 2D90 03CE D592 4925 2F8E C41A (pubkey-iwuzhere) - GPG key: 9DFE AA5F 481B BF77 2D90 03CE D592 4925 2F8E C41A (pubkey-iwuzhere)
* **John Barboza** ([@jbarz](https://github.com/jbarz)) * **John Barboza** ([@jbarz](https://github.com/jbarz))
* **Santiago Gimeno** ([@santigimeno](https://github.com/santigimeno)) * **Santiago Gimeno** ([@santigimeno](https://github.com/santigimeno))
......
...@@ -32,6 +32,7 @@ libuv_la_SOURCES = src/fs-poll.c \ ...@@ -32,6 +32,7 @@ libuv_la_SOURCES = src/fs-poll.c \
src/inet.c \ src/inet.c \
src/queue.h \ src/queue.h \
src/threadpool.c \ src/threadpool.c \
src/timer.c \
src/uv-data-getter-setters.c \ src/uv-data-getter-setters.c \
src/uv-common.c \ src/uv-common.c \
src/uv-common.h \ src/uv-common.h \
...@@ -74,7 +75,6 @@ libuv_la_SOURCES += src/win/async.c \ ...@@ -74,7 +75,6 @@ libuv_la_SOURCES += src/win/async.c \
src/win/stream-inl.h \ src/win/stream-inl.h \
src/win/tcp.c \ src/win/tcp.c \
src/win/thread.c \ src/win/thread.c \
src/win/timer.c \
src/win/tty.c \ src/win/tty.c \
src/win/udp.c \ src/win/udp.c \
src/win/util.c \ src/win/util.c \
...@@ -105,7 +105,6 @@ libuv_la_SOURCES += src/unix/async.c \ ...@@ -105,7 +105,6 @@ libuv_la_SOURCES += src/unix/async.c \
src/unix/stream.c \ src/unix/stream.c \
src/unix/tcp.c \ src/unix/tcp.c \
src/unix/thread.c \ src/unix/thread.c \
src/unix/timer.c \
src/unix/tty.c \ src/unix/tty.c \
src/unix/udp.c src/unix/udp.c
......
#!/bin/sh
# Copyright (c) 2013, Ben Noordhuis <info@bnoordhuis.nl>
#
# Permission to use, copy, modify, and/or distribute this software for any
# purpose with or without fee is hereby granted, provided that the above
# copyright notice and this permission notice appear in all copies.
#
# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
SPARSE=${SPARSE:-sparse}
SPARSE_FLAGS=${SPARSE_FLAGS:-"
-D__POSIX__
-Wsparse-all
-Wno-do-while
-Wno-transparent-union
-Iinclude
-Isrc
"}
SOURCES="
include/uv/tree.h
include/uv/unix.h
include/uv.h
src/fs-poll.c
src/inet.c
src/queue.h
src/unix/async.c
src/unix/core.c
src/unix/dl.c
src/unix/fs.c
src/unix/getaddrinfo.c
src/unix/internal.h
src/unix/loop-watcher.c
src/unix/loop.c
src/unix/pipe.c
src/unix/poll.c
src/unix/process.c
src/unix/signal.c
src/unix/stream.c
src/unix/tcp.c
src/unix/thread.c
src/unix/threadpool.c
src/unix/timer.c
src/unix/tty.c
src/unix/udp.c
src/uv-common.c
src/uv-common.h
src/uv-data-getter-setters.c
"
TESTS="
test/benchmark-async-pummel.c
test/benchmark-async.c
test/benchmark-fs-stat.c
test/benchmark-getaddrinfo.c
test/benchmark-loop-count.c
test/benchmark-million-async.c
test/benchmark-million-timers.c
test/benchmark-multi-accept.c
test/benchmark-ping-pongs.c
test/benchmark-pound.c
test/benchmark-pump.c
test/benchmark-sizes.c
test/benchmark-spawn.c
test/benchmark-tcp-write-batch.c
test/benchmark-thread.c
test/benchmark-udp-pummel.c
test/blackhole-server.c
test/dns-server.c
test/echo-server.c
test/run-benchmarks.c
test/run-tests.c
test/runner-unix.c
test/runner-unix.h
test/runner.c
test/runner.h
test/task.h
test/test-active.c
test/test-async.c
test/test-barrier.c
test/test-callback-order.c
test/test-callback-stack.c
test/test-condvar.c
test/test-connection-fail.c
test/test-cwd-and-chdir.c
test/test-delayed-accept.c
test/test-dlerror.c
test/test-embed.c
test/test-env-vars.c
test/test-error.c
test/test-fail-always.c
test/test-fs-copyfile.c
test/test-fs-event.c
test/test-fs-poll.c
test/test-fs.c
test/test-getters-setters.c
test/test-get-currentexe.c
test/test-get-loadavg.c
test/test-get-memory.c
test/test-get-passwd.c
test/test-getaddrinfo.c
test/test-gethostname.c
test/test-getsockname.c
test/test-homedir.c
test/test-hrtime.c
test/test-idle.c
test/test-ip6-addr.c
test/test-ipc-heavy-traffic-deadlock-bug.c
test/test-ipc-send-recv.c
test/test-ipc.c
test/test-loop-handles.c
test/test-multiple-listen.c
test/test-mutexes.c
test/test-pass-always.c
test/test-ping-pong.c
test/test-pipe-bind-error.c
test/test-pipe-connect-error.c
test/test-pipe-sendmsg.c
test/test-pipe-server-close.c
test/test-platform-output.c
test/test-poll-close.c
test/test-poll.c
test/test-process-title.c
test/test-process-title-threadsafe.c
test/test-ref.c
test/test-run-nowait.c
test/test-run-once.c
test/test-semaphore.c
test/test-shutdown-close.c
test/test-shutdown-eof.c
test/test-signal-multiple-loops.c
test/test-signal.c
test/test-spawn.c
test/test-stdio-over-pipes.c
test/test-tcp-bind-error.c
test/test-tcp-bind6-error.c
test/test-tcp-close-while-connecting.c
test/test-tcp-close-accept.c
test/test-tcp-close.c
test/test-tcp-connect-error-after-write.c
test/test-tcp-connect-error.c
test/test-tcp-connect-timeout.c
test/test-tcp-connect6-error.c
test/test-tcp-flags.c
test/test-tcp-open.c
test/test-tcp-read-stop.c
test/test-tcp-shutdown-after-write.c
test/test-tcp-unexpected-read.c
test/test-tcp-oob.c
test/test-tcp-write-error.c
test/test-tcp-write-to-half-open-connection.c
test/test-tcp-writealot.c
test/test-thread.c
test/test-threadpool-cancel.c
test/test-threadpool.c
test/test-timer-again.c
test/test-timer.c
test/test-tmpdir.c
test/test-tty.c
test/test-udp-dgram-too-big.c
test/test-udp-ipv6.c
test/test-udp-multicast-join.c
test/test-udp-multicast-ttl.c
test/test-udp-open.c
test/test-udp-options.c
test/test-udp-send-and-recv.c
test/test-udp-send-hang-loop.c
test/test-walk-handles.c
test/test-watcher-cross-stop.c
"
case `uname -s` in
AIX)
SPARSE_FLAGS="$SPARSE_FLAGS -D_AIX=1"
SOURCES="$SOURCES
src/unix/aix-common.c
src/unix/aix.c"
;;
OS400)
SPARSE_FLAGS="$SPARSE_FLAGS -D__PASE__=1"
SOURCES="$SOURCES
src/unix/aix-common.c
src/unix/ibmi.c
src/unix/posix-poll.c
src/unix/no-fsevents.c
src/unix/no-proctitle.c"
;;
Darwin)
SPARSE_FLAGS="$SPARSE_FLAGS -D__APPLE__=1"
SOURCES="$SOURCES
include/uv/bsd.h
src/unix/darwin.c
src/unix/kqueue.c
src/unix/fsevents.c"
;;
DragonFly)
SPARSE_FLAGS="$SPARSE_FLAGS -D__DragonFly__=1"
SOURCES="$SOURCES
include/uv/bsd.h
src/unix/kqueue.c
src/unix/freebsd.c"
;;
FreeBSD)
SPARSE_FLAGS="$SPARSE_FLAGS -D__FreeBSD__=1"
SOURCES="$SOURCES
include/uv/bsd.h
src/unix/kqueue.c
src/unix/freebsd.c"
;;
Linux)
SPARSE_FLAGS="$SPARSE_FLAGS -D__linux__=1"
SOURCES="$SOURCES
include/uv/linux.h
src/unix/linux-inotify.c
src/unix/linux-core.c
src/unix/linux-syscalls.c
src/unix/linux-syscalls.h"
;;
NetBSD)
SPARSE_FLAGS="$SPARSE_FLAGS -D__NetBSD__=1"
SOURCES="$SOURCES
include/uv/bsd.h
src/unix/kqueue.c
src/unix/netbsd.c"
;;
OpenBSD)
SPARSE_FLAGS="$SPARSE_FLAGS -D__OpenBSD__=1"
SOURCES="$SOURCES
include/uv/bsd.h
src/unix/kqueue.c
src/unix/openbsd.c"
;;
SunOS)
SPARSE_FLAGS="$SPARSE_FLAGS -D__sun=1"
SOURCES="$SOURCES
include/uv/sunos.h
src/unix/sunos.c"
;;
esac
for ARCH in __i386__ __x86_64__ __arm__ __mips__; do
$SPARSE $SPARSE_FLAGS -D$ARCH=1 $SOURCES
done
# Tests are architecture independent.
$SPARSE $SPARSE_FLAGS -Itest $TESTS
...@@ -13,7 +13,7 @@ ...@@ -13,7 +13,7 @@
# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. # OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
AC_PREREQ(2.57) AC_PREREQ(2.57)
AC_INIT([libuv], [1.21.0], [https://github.com/libuv/libuv/issues]) AC_INIT([libuv], [1.22.0], [https://github.com/libuv/libuv/issues])
AC_CONFIG_MACRO_DIR([m4]) AC_CONFIG_MACRO_DIR([m4])
m4_include([m4/libuv-extra-automake-flags.m4]) m4_include([m4/libuv-extra-automake-flags.m4])
m4_include([m4/as_case.m4]) m4_include([m4/as_case.m4])
......
...@@ -370,7 +370,10 @@ typedef enum { ...@@ -370,7 +370,10 @@ typedef enum {
UV_EXTERN int uv_translate_sys_error(int sys_errno); UV_EXTERN int uv_translate_sys_error(int sys_errno);
UV_EXTERN const char* uv_strerror(int err); UV_EXTERN const char* uv_strerror(int err);
UV_EXTERN char* uv_strerror_r(int err, char* buf, size_t buflen);
UV_EXTERN const char* uv_err_name(int err); UV_EXTERN const char* uv_err_name(int err);
UV_EXTERN char* uv_err_name_r(int err, char* buf, size_t buflen);
#define UV_REQ_FIELDS \ #define UV_REQ_FIELDS \
...@@ -1141,9 +1144,9 @@ typedef enum { ...@@ -1141,9 +1144,9 @@ typedef enum {
UV_FS_READLINK, UV_FS_READLINK,
UV_FS_CHOWN, UV_FS_CHOWN,
UV_FS_FCHOWN, UV_FS_FCHOWN,
UV_FS_LCHOWN,
UV_FS_REALPATH, UV_FS_REALPATH,
UV_FS_COPYFILE UV_FS_COPYFILE,
UV_FS_LCHOWN
} uv_fs_type; } uv_fs_type;
/* uv_fs_t is a subclass of uv_req_t. */ /* uv_fs_t is a subclass of uv_req_t. */
......
...@@ -31,7 +31,7 @@ ...@@ -31,7 +31,7 @@
*/ */
#define UV_VERSION_MAJOR 1 #define UV_VERSION_MAJOR 1
#define UV_VERSION_MINOR 21 #define UV_VERSION_MINOR 22
#define UV_VERSION_PATCH 0 #define UV_VERSION_PATCH 0
#define UV_VERSION_IS_RELEASE 1 #define UV_VERSION_IS_RELEASE 1
#define UV_VERSION_SUFFIX "" #define UV_VERSION_SUFFIX ""
......
...@@ -308,8 +308,6 @@ typedef struct { ...@@ -308,8 +308,6 @@ typedef struct {
char* errmsg; char* errmsg;
} uv_lib_t; } uv_lib_t;
RB_HEAD(uv_timer_tree_s, uv_timer_s);
#define UV_LOOP_PRIVATE_FIELDS \ #define UV_LOOP_PRIVATE_FIELDS \
/* The loop's I/O completion port */ \ /* The loop's I/O completion port */ \
HANDLE iocp; \ HANDLE iocp; \
...@@ -321,8 +319,8 @@ RB_HEAD(uv_timer_tree_s, uv_timer_s); ...@@ -321,8 +319,8 @@ RB_HEAD(uv_timer_tree_s, uv_timer_s);
uv_req_t* pending_reqs_tail; \ uv_req_t* pending_reqs_tail; \
/* Head of a single-linked list of closed handles */ \ /* Head of a single-linked list of closed handles */ \
uv_handle_t* endgame_handles; \ uv_handle_t* endgame_handles; \
/* The head of the timers tree */ \ /* TODO(bnoordhuis) Stop heap-allocating |timer_heap| in libuv v2.x. */ \
struct uv_timer_tree_s timers; \ void* timer_heap; \
/* Lists of active loop (prepare / check / idle) watchers */ \ /* Lists of active loop (prepare / check / idle) watchers */ \
uv_prepare_t* prepare_handles; \ uv_prepare_t* prepare_handles; \
uv_check_t* check_handles; \ uv_check_t* check_handles; \
...@@ -529,8 +527,9 @@ RB_HEAD(uv_timer_tree_s, uv_timer_s); ...@@ -529,8 +527,9 @@ RB_HEAD(uv_timer_tree_s, uv_timer_s);
unsigned char events; unsigned char events;
#define UV_TIMER_PRIVATE_FIELDS \ #define UV_TIMER_PRIVATE_FIELDS \
RB_ENTRY(uv_timer_s) tree_entry; \ void* heap_node[3]; \
uint64_t due; \ int unused; \
uint64_t timeout; \
uint64_t repeat; \ uint64_t repeat; \
uint64_t start_id; \ uint64_t start_id; \
uv_timer_cb timer_cb; uv_timer_cb timer_cb;
......
...@@ -83,7 +83,7 @@ int uv_fs_poll_start(uv_fs_poll_t* handle, ...@@ -83,7 +83,7 @@ int uv_fs_poll_start(uv_fs_poll_t* handle,
if (err < 0) if (err < 0)
goto error; goto error;
ctx->timer_handle.flags |= UV__HANDLE_INTERNAL; ctx->timer_handle.flags |= UV_HANDLE_INTERNAL;
uv__handle_unref(&ctx->timer_handle); uv__handle_unref(&ctx->timer_handle);
err = uv_fs_stat(loop, &ctx->fs_req, ctx->path, poll_cb); err = uv_fs_stat(loop, &ctx->fs_req, ctx->path, poll_cb);
...@@ -248,7 +248,7 @@ static int statbuf_eq(const uv_stat_t* a, const uv_stat_t* b) { ...@@ -248,7 +248,7 @@ static int statbuf_eq(const uv_stat_t* a, const uv_stat_t* b) {
#include "win/handle-inl.h" #include "win/handle-inl.h"
void uv__fs_poll_endgame(uv_loop_t* loop, uv_fs_poll_t* handle) { void uv__fs_poll_endgame(uv_loop_t* loop, uv_fs_poll_t* handle) {
assert(handle->flags & UV__HANDLE_CLOSING); assert(handle->flags & UV_HANDLE_CLOSING);
assert(!(handle->flags & UV_HANDLE_CLOSED)); assert(!(handle->flags & UV_HANDLE_CLOSED));
uv__handle_close(handle); uv__handle_close(handle);
} }
......
...@@ -19,13 +19,22 @@ ...@@ -19,13 +19,22 @@
*/ */
#include "uv.h" #include "uv.h"
#include "internal.h" #include "uv-common.h"
#include "heap-inl.h" #include "heap-inl.h"
#include <assert.h> #include <assert.h>
#include <limits.h> #include <limits.h>
static struct heap *timer_heap(const uv_loop_t* loop) {
#ifdef _WIN32
return (struct heap*) loop->timer_heap;
#else
return (struct heap*) &loop->timer_heap;
#endif
}
static int timer_less_than(const struct heap_node* ha, static int timer_less_than(const struct heap_node* ha,
const struct heap_node* hb) { const struct heap_node* hb) {
const uv_timer_t* a; const uv_timer_t* a;
...@@ -81,7 +90,7 @@ int uv_timer_start(uv_timer_t* handle, ...@@ -81,7 +90,7 @@ int uv_timer_start(uv_timer_t* handle,
/* start_id is the second index to be compared in uv__timer_cmp() */ /* start_id is the second index to be compared in uv__timer_cmp() */
handle->start_id = handle->loop->timer_counter++; handle->start_id = handle->loop->timer_counter++;
heap_insert((struct heap*) &handle->loop->timer_heap, heap_insert(timer_heap(handle->loop),
(struct heap_node*) &handle->heap_node, (struct heap_node*) &handle->heap_node,
timer_less_than); timer_less_than);
uv__handle_start(handle); uv__handle_start(handle);
...@@ -94,7 +103,7 @@ int uv_timer_stop(uv_timer_t* handle) { ...@@ -94,7 +103,7 @@ int uv_timer_stop(uv_timer_t* handle) {
if (!uv__is_active(handle)) if (!uv__is_active(handle))
return 0; return 0;
heap_remove((struct heap*) &handle->loop->timer_heap, heap_remove(timer_heap(handle->loop),
(struct heap_node*) &handle->heap_node, (struct heap_node*) &handle->heap_node,
timer_less_than); timer_less_than);
uv__handle_stop(handle); uv__handle_stop(handle);
...@@ -131,7 +140,7 @@ int uv__next_timeout(const uv_loop_t* loop) { ...@@ -131,7 +140,7 @@ int uv__next_timeout(const uv_loop_t* loop) {
const uv_timer_t* handle; const uv_timer_t* handle;
uint64_t diff; uint64_t diff;
heap_node = heap_min((const struct heap*) &loop->timer_heap); heap_node = heap_min(timer_heap(loop));
if (heap_node == NULL) if (heap_node == NULL)
return -1; /* block indefinitely */ return -1; /* block indefinitely */
...@@ -152,7 +161,7 @@ void uv__run_timers(uv_loop_t* loop) { ...@@ -152,7 +161,7 @@ void uv__run_timers(uv_loop_t* loop) {
uv_timer_t* handle; uv_timer_t* handle;
for (;;) { for (;;) {
heap_node = heap_min((struct heap*) &loop->timer_heap); heap_node = heap_min(timer_heap(loop));
if (heap_node == NULL) if (heap_node == NULL)
break; break;
......
...@@ -116,7 +116,7 @@ uint64_t uv_hrtime(void) { ...@@ -116,7 +116,7 @@ uint64_t uv_hrtime(void) {
void uv_close(uv_handle_t* handle, uv_close_cb close_cb) { void uv_close(uv_handle_t* handle, uv_close_cb close_cb) {
assert(!uv__is_closing(handle)); assert(!uv__is_closing(handle));
handle->flags |= UV_CLOSING; handle->flags |= UV_HANDLE_CLOSING;
handle->close_cb = close_cb; handle->close_cb = close_cb;
switch (handle->type) { switch (handle->type) {
...@@ -214,8 +214,8 @@ int uv__socket_sockopt(uv_handle_t* handle, int optname, int* value) { ...@@ -214,8 +214,8 @@ int uv__socket_sockopt(uv_handle_t* handle, int optname, int* value) {
} }
void uv__make_close_pending(uv_handle_t* handle) { void uv__make_close_pending(uv_handle_t* handle) {
assert(handle->flags & UV_CLOSING); assert(handle->flags & UV_HANDLE_CLOSING);
assert(!(handle->flags & UV_CLOSED)); assert(!(handle->flags & UV_HANDLE_CLOSED));
handle->next_closing = handle->loop->closing_handles; handle->next_closing = handle->loop->closing_handles;
handle->loop->closing_handles = handle; handle->loop->closing_handles = handle;
} }
...@@ -241,15 +241,17 @@ int uv__getiovmax(void) { ...@@ -241,15 +241,17 @@ int uv__getiovmax(void) {
static void uv__finish_close(uv_handle_t* handle) { static void uv__finish_close(uv_handle_t* handle) {
/* Note: while the handle is in the UV_CLOSING state now, it's still possible /* Note: while the handle is in the UV_HANDLE_CLOSING state now, it's still
* for it to be active in the sense that uv__is_active() returns true. * possible for it to be active in the sense that uv__is_active() returns
* true.
*
* A good example is when the user calls uv_shutdown(), immediately followed * A good example is when the user calls uv_shutdown(), immediately followed
* by uv_close(). The handle is considered active at this point because the * by uv_close(). The handle is considered active at this point because the
* completion of the shutdown req is still pending. * completion of the shutdown req is still pending.
*/ */
assert(handle->flags & UV_CLOSING); assert(handle->flags & UV_HANDLE_CLOSING);
assert(!(handle->flags & UV_CLOSED)); assert(!(handle->flags & UV_HANDLE_CLOSED));
handle->flags |= UV_CLOSED; handle->flags |= UV_HANDLE_CLOSED;
switch (handle->type) { switch (handle->type) {
case UV_PREPARE: case UV_PREPARE:
......
...@@ -836,7 +836,7 @@ int uv__fsevents_init(uv_fs_event_t* handle) { ...@@ -836,7 +836,7 @@ int uv__fsevents_init(uv_fs_event_t* handle) {
handle->cf_cb->data = handle; handle->cf_cb->data = handle;
uv_async_init(handle->loop, handle->cf_cb, uv__fsevents_cb); uv_async_init(handle->loop, handle->cf_cb, uv__fsevents_cb);
handle->cf_cb->flags |= UV__HANDLE_INTERNAL; handle->cf_cb->flags |= UV_HANDLE_INTERNAL;
uv_unref((uv_handle_t*) handle->cf_cb); uv_unref((uv_handle_t*) handle->cf_cb);
err = uv_mutex_init(&handle->cf_mutex); err = uv_mutex_init(&handle->cf_mutex);
......
...@@ -127,26 +127,6 @@ int uv__pthread_sigmask(int how, const sigset_t* set, sigset_t* oset); ...@@ -127,26 +127,6 @@ int uv__pthread_sigmask(int how, const sigset_t* set, sigset_t* oset);
typedef struct uv__stream_queued_fds_s uv__stream_queued_fds_t; typedef struct uv__stream_queued_fds_s uv__stream_queued_fds_t;
/* handle flags */
enum {
UV_CLOSING = 0x01, /* uv_close() called but not finished. */
UV_CLOSED = 0x02, /* close(2) finished. */
UV_STREAM_READING = 0x04, /* uv_read_start() called. */
UV_STREAM_SHUTTING = 0x08, /* uv_shutdown() called but not complete. */
UV_STREAM_SHUT = 0x10, /* Write side closed. */
UV_STREAM_READABLE = 0x20, /* The stream is readable */
UV_STREAM_WRITABLE = 0x40, /* The stream is writable */
UV_STREAM_BLOCKING = 0x80, /* Synchronous writes. */
UV_STREAM_READ_PARTIAL = 0x100, /* read(2) read less than requested. */
UV_STREAM_READ_EOF = 0x200, /* read(2) read EOF. */
UV_TCP_NODELAY = 0x400, /* Disable Nagle. */
UV_TCP_KEEPALIVE = 0x800, /* Turn on keep-alive. */
UV_TCP_SINGLE_ACCEPT = 0x1000, /* Only accept() when idle. */
UV_HANDLE_IPV6 = 0x10000, /* Handle is bound to a IPv6 socket. */
UV_UDP_PROCESSING = 0x20000, /* Handle is running the send callback queue. */
UV_HANDLE_BOUND = 0x40000 /* Handle is bound to an address and port */
};
/* loop flags */ /* loop flags */
enum { enum {
UV_LOOP_BLOCK_SIGPROF = 1 UV_LOOP_BLOCK_SIGPROF = 1
...@@ -252,10 +232,6 @@ int uv__tcp_keepalive(int fd, int on, unsigned int delay); ...@@ -252,10 +232,6 @@ int uv__tcp_keepalive(int fd, int on, unsigned int delay);
/* pipe */ /* pipe */
int uv_pipe_listen(uv_pipe_t* handle, int backlog, uv_connection_cb cb); int uv_pipe_listen(uv_pipe_t* handle, int backlog, uv_connection_cb cb);
/* timer */
void uv__run_timers(uv_loop_t* loop);
int uv__next_timeout(const uv_loop_t* loop);
/* signal */ /* signal */
void uv__signal_close(uv_signal_t* handle); void uv__signal_close(uv_signal_t* handle);
void uv__signal_global_once_init(void); void uv__signal_global_once_init(void);
...@@ -280,7 +256,6 @@ void uv__prepare_close(uv_prepare_t* handle); ...@@ -280,7 +256,6 @@ void uv__prepare_close(uv_prepare_t* handle);
void uv__process_close(uv_process_t* handle); void uv__process_close(uv_process_t* handle);
void uv__stream_close(uv_stream_t* handle); void uv__stream_close(uv_stream_t* handle);
void uv__tcp_close(uv_tcp_t* handle); void uv__tcp_close(uv_tcp_t* handle);
void uv__timer_close(uv_timer_t* handle);
void uv__udp_close(uv_udp_t* handle); void uv__udp_close(uv_udp_t* handle);
void uv__udp_finish_close(uv_udp_t* handle); void uv__udp_finish_close(uv_udp_t* handle);
uv_handle_type uv__handle_type(int fd); uv_handle_type uv__handle_type(int fd);
......
...@@ -74,7 +74,7 @@ int uv_loop_init(uv_loop_t* loop) { ...@@ -74,7 +74,7 @@ int uv_loop_init(uv_loop_t* loop) {
goto fail_signal_init; goto fail_signal_init;
uv__handle_unref(&loop->child_watcher); uv__handle_unref(&loop->child_watcher);
loop->child_watcher.flags |= UV__HANDLE_INTERNAL; loop->child_watcher.flags |= UV_HANDLE_INTERNAL;
QUEUE_INIT(&loop->process_handles); QUEUE_INIT(&loop->process_handles);
err = uv_rwlock_init(&loop->cloexec_lock); err = uv_rwlock_init(&loop->cloexec_lock);
...@@ -90,7 +90,7 @@ int uv_loop_init(uv_loop_t* loop) { ...@@ -90,7 +90,7 @@ int uv_loop_init(uv_loop_t* loop) {
goto fail_async_init; goto fail_async_init;
uv__handle_unref(&loop->wq_async); uv__handle_unref(&loop->wq_async);
loop->wq_async.flags |= UV__HANDLE_INTERNAL; loop->wq_async.flags |= UV_HANDLE_INTERNAL;
return 0; return 0;
......
...@@ -141,7 +141,7 @@ static void init_message_queue(uv__os390_epoll* lst) { ...@@ -141,7 +141,7 @@ static void init_message_queue(uv__os390_epoll* lst) {
} msg; } msg;
/* initialize message queue */ /* initialize message queue */
lst->msg_queue = msgget(IPC_PRIVATE, 0622 | IPC_CREAT); lst->msg_queue = msgget(IPC_PRIVATE, 0600 | IPC_CREAT);
if (lst->msg_queue == -1) if (lst->msg_queue == -1)
abort(); abort();
...@@ -255,12 +255,13 @@ int epoll_ctl(uv__os390_epoll* lst, ...@@ -255,12 +255,13 @@ int epoll_ctl(uv__os390_epoll* lst,
lst->items[fd].events = event->events; lst->items[fd].events = event->events;
lst->items[fd].revents = 0; lst->items[fd].revents = 0;
} else if (op == EPOLL_CTL_MOD) { } else if (op == EPOLL_CTL_MOD) {
if (fd >= lst->size || lst->items[fd].fd == -1) { if (fd >= lst->size - 1 || lst->items[fd].fd == -1) {
uv_mutex_unlock(&global_epoll_lock); uv_mutex_unlock(&global_epoll_lock);
errno = ENOENT; errno = ENOENT;
return -1; return -1;
} }
lst->items[fd].events = event->events; lst->items[fd].events = event->events;
lst->items[fd].revents = 0;
} else } else
abort(); abort();
...@@ -275,8 +276,9 @@ int epoll_wait(uv__os390_epoll* lst, struct epoll_event* events, ...@@ -275,8 +276,9 @@ int epoll_wait(uv__os390_epoll* lst, struct epoll_event* events,
struct pollfd* pfds; struct pollfd* pfds;
int pollret; int pollret;
int reventcount; int reventcount;
int nevents;
size = _SET_FDS_MSGS(size, 1, lst->size - 1); _SET_FDS_MSGS(size, 1, lst->size - 1);
pfds = lst->items; pfds = lst->items;
pollret = poll(pfds, size, timeout); pollret = poll(pfds, size, timeout);
if (pollret <= 0) if (pollret <= 0)
...@@ -285,19 +287,28 @@ int epoll_wait(uv__os390_epoll* lst, struct epoll_event* events, ...@@ -285,19 +287,28 @@ int epoll_wait(uv__os390_epoll* lst, struct epoll_event* events,
pollret = _NFDS(pollret) + _NMSGS(pollret); pollret = _NFDS(pollret) + _NMSGS(pollret);
reventcount = 0; reventcount = 0;
nevents = 0;
for (int i = 0; for (int i = 0;
i < lst->size && i < maxevents && reventcount < pollret; ++i) { i < lst->size && i < maxevents && reventcount < pollret; ++i) {
struct epoll_event ev; struct epoll_event ev;
struct pollfd* pfd;
if (pfds[i].fd == -1 || pfds[i].revents == 0) pfd = &pfds[i];
if (pfd->fd == -1 || pfd->revents == 0)
continue; continue;
ev.fd = pfds[i].fd; ev.fd = pfd->fd;
ev.events = pfds[i].revents; ev.events = pfd->revents;
events[reventcount++] = ev; if (pfd->revents & POLLIN && pfd->revents & POLLOUT)
reventcount += 2;
else if (pfd->revents & (POLLIN | POLLOUT))
++reventcount;
pfd->revents = 0;
events[nevents++] = ev;
} }
return reventcount; return nevents;
} }
...@@ -493,7 +504,7 @@ ssize_t os390_readlink(const char* path, char* buf, size_t len) { ...@@ -493,7 +504,7 @@ ssize_t os390_readlink(const char* path, char* buf, size_t len) {
size_t strnlen(const char* str, size_t maxlen) { size_t strnlen(const char* str, size_t maxlen) {
void* p = memchr(str, 0, maxlen); char* p = memchr(str, 0, maxlen);
if (p == NULL) if (p == NULL)
return maxlen; return maxlen;
else else
......
...@@ -149,7 +149,7 @@ int uv_pipe_open(uv_pipe_t* handle, uv_file fd) { ...@@ -149,7 +149,7 @@ int uv_pipe_open(uv_pipe_t* handle, uv_file fd) {
return uv__stream_open((uv_stream_t*)handle, return uv__stream_open((uv_stream_t*)handle,
fd, fd,
UV_STREAM_READABLE | UV_STREAM_WRITABLE); UV_HANDLE_READABLE | UV_HANDLE_WRITABLE);
} }
...@@ -199,7 +199,7 @@ void uv_pipe_connect(uv_connect_t* req, ...@@ -199,7 +199,7 @@ void uv_pipe_connect(uv_connect_t* req,
if (new_sock) { if (new_sock) {
err = uv__stream_open((uv_stream_t*)handle, err = uv__stream_open((uv_stream_t*)handle,
uv__stream_fd(handle), uv__stream_fd(handle),
UV_STREAM_READABLE | UV_STREAM_WRITABLE); UV_HANDLE_READABLE | UV_HANDLE_WRITABLE);
} }
if (err == 0) if (err == 0)
......
...@@ -239,9 +239,9 @@ static int uv__process_open_stream(uv_stdio_container_t* container, ...@@ -239,9 +239,9 @@ static int uv__process_open_stream(uv_stdio_container_t* container,
flags = 0; flags = 0;
if (container->flags & UV_WRITABLE_PIPE) if (container->flags & UV_WRITABLE_PIPE)
flags |= UV_STREAM_READABLE; flags |= UV_HANDLE_READABLE;
if (container->flags & UV_READABLE_PIPE) if (container->flags & UV_READABLE_PIPE)
flags |= UV_STREAM_WRITABLE; flags |= UV_HANDLE_WRITABLE;
return uv__stream_open(container->data.stream, pipefds[0], flags); return uv__stream_open(container->data.stream, pipefds[0], flags);
} }
......
...@@ -396,7 +396,7 @@ static int uv__signal_start(uv_signal_t* handle, ...@@ -396,7 +396,7 @@ static int uv__signal_start(uv_signal_t* handle,
*/ */
first_handle = uv__signal_first_handle(signum); first_handle = uv__signal_first_handle(signum);
if (first_handle == NULL || if (first_handle == NULL ||
(!oneshot && (first_handle->flags & UV__SIGNAL_ONE_SHOT))) { (!oneshot && (first_handle->flags & UV_SIGNAL_ONE_SHOT))) {
err = uv__signal_register_handler(signum, oneshot); err = uv__signal_register_handler(signum, oneshot);
if (err) { if (err) {
/* Registering the signal handler failed. Must be an invalid signal. */ /* Registering the signal handler failed. Must be an invalid signal. */
...@@ -407,7 +407,7 @@ static int uv__signal_start(uv_signal_t* handle, ...@@ -407,7 +407,7 @@ static int uv__signal_start(uv_signal_t* handle,
handle->signum = signum; handle->signum = signum;
if (oneshot) if (oneshot)
handle->flags |= UV__SIGNAL_ONE_SHOT; handle->flags |= UV_SIGNAL_ONE_SHOT;
RB_INSERT(uv__signal_tree_s, &uv__signal_tree, handle); RB_INSERT(uv__signal_tree_s, &uv__signal_tree, handle);
...@@ -464,20 +464,20 @@ static void uv__signal_event(uv_loop_t* loop, ...@@ -464,20 +464,20 @@ static void uv__signal_event(uv_loop_t* loop,
handle = msg->handle; handle = msg->handle;
if (msg->signum == handle->signum) { if (msg->signum == handle->signum) {
assert(!(handle->flags & UV_CLOSING)); assert(!(handle->flags & UV_HANDLE_CLOSING));
handle->signal_cb(handle, handle->signum); handle->signal_cb(handle, handle->signum);
} }
handle->dispatched_signals++; handle->dispatched_signals++;
if (handle->flags & UV__SIGNAL_ONE_SHOT) if (handle->flags & UV_SIGNAL_ONE_SHOT)
uv__signal_stop(handle); uv__signal_stop(handle);
/* If uv_close was called while there were caught signals that were not /* If uv_close was called while there were caught signals that were not
* yet dispatched, the uv__finish_close was deferred. Make close pending * yet dispatched, the uv__finish_close was deferred. Make close pending
* now if this has happened. * now if this has happened.
*/ */
if ((handle->flags & UV_CLOSING) && if ((handle->flags & UV_HANDLE_CLOSING) &&
(handle->caught_signals == handle->dispatched_signals)) { (handle->caught_signals == handle->dispatched_signals)) {
uv__make_close_pending((uv_handle_t*) handle); uv__make_close_pending((uv_handle_t*) handle);
} }
...@@ -505,11 +505,11 @@ static int uv__signal_compare(uv_signal_t* w1, uv_signal_t* w2) { ...@@ -505,11 +505,11 @@ static int uv__signal_compare(uv_signal_t* w1, uv_signal_t* w2) {
if (w1->signum < w2->signum) return -1; if (w1->signum < w2->signum) return -1;
if (w1->signum > w2->signum) return 1; if (w1->signum > w2->signum) return 1;
/* Handlers without UV__SIGNAL_ONE_SHOT set will come first, so if the first /* Handlers without UV_SIGNAL_ONE_SHOT set will come first, so if the first
* handler returned is a one-shot handler, the rest will be too. * handler returned is a one-shot handler, the rest will be too.
*/ */
f1 = w1->flags & UV__SIGNAL_ONE_SHOT; f1 = w1->flags & UV_SIGNAL_ONE_SHOT;
f2 = w2->flags & UV__SIGNAL_ONE_SHOT; f2 = w2->flags & UV_SIGNAL_ONE_SHOT;
if (f1 < f2) return -1; if (f1 < f2) return -1;
if (f1 > f2) return 1; if (f1 > f2) return 1;
...@@ -558,8 +558,8 @@ static void uv__signal_stop(uv_signal_t* handle) { ...@@ -558,8 +558,8 @@ static void uv__signal_stop(uv_signal_t* handle) {
if (first_handle == NULL) { if (first_handle == NULL) {
uv__signal_unregister_handler(handle->signum); uv__signal_unregister_handler(handle->signum);
} else { } else {
rem_oneshot = handle->flags & UV__SIGNAL_ONE_SHOT; rem_oneshot = handle->flags & UV_SIGNAL_ONE_SHOT;
first_oneshot = first_handle->flags & UV__SIGNAL_ONE_SHOT; first_oneshot = first_handle->flags & UV_SIGNAL_ONE_SHOT;
if (first_oneshot && !rem_oneshot) { if (first_oneshot && !rem_oneshot) {
ret = uv__signal_register_handler(handle->signum, 1); ret = uv__signal_register_handler(handle->signum, 1);
assert(ret == 0); assert(ret == 0);
......
This diff is collapsed.
...@@ -216,7 +216,7 @@ int uv__tcp_connect(uv_connect_t* req, ...@@ -216,7 +216,7 @@ int uv__tcp_connect(uv_connect_t* req,
err = maybe_new_socket(handle, err = maybe_new_socket(handle,
addr->sa_family, addr->sa_family,
UV_STREAM_READABLE | UV_STREAM_WRITABLE); UV_HANDLE_READABLE | UV_HANDLE_WRITABLE);
if (err) if (err)
return err; return err;
...@@ -272,7 +272,7 @@ int uv_tcp_open(uv_tcp_t* handle, uv_os_sock_t sock) { ...@@ -272,7 +272,7 @@ int uv_tcp_open(uv_tcp_t* handle, uv_os_sock_t sock) {
return uv__stream_open((uv_stream_t*)handle, return uv__stream_open((uv_stream_t*)handle,
sock, sock,
UV_STREAM_READABLE | UV_STREAM_WRITABLE); UV_HANDLE_READABLE | UV_HANDLE_WRITABLE);
} }
...@@ -334,7 +334,7 @@ int uv_tcp_listen(uv_tcp_t* tcp, int backlog, uv_connection_cb cb) { ...@@ -334,7 +334,7 @@ int uv_tcp_listen(uv_tcp_t* tcp, int backlog, uv_connection_cb cb) {
} }
if (single_accept) if (single_accept)
tcp->flags |= UV_TCP_SINGLE_ACCEPT; tcp->flags |= UV_HANDLE_TCP_SINGLE_ACCEPT;
flags = 0; flags = 0;
#if defined(__MVS__) #if defined(__MVS__)
...@@ -401,9 +401,9 @@ int uv_tcp_nodelay(uv_tcp_t* handle, int on) { ...@@ -401,9 +401,9 @@ int uv_tcp_nodelay(uv_tcp_t* handle, int on) {
} }
if (on) if (on)
handle->flags |= UV_TCP_NODELAY; handle->flags |= UV_HANDLE_TCP_NODELAY;
else else
handle->flags &= ~UV_TCP_NODELAY; handle->flags &= ~UV_HANDLE_TCP_NODELAY;
return 0; return 0;
} }
...@@ -419,9 +419,9 @@ int uv_tcp_keepalive(uv_tcp_t* handle, int on, unsigned int delay) { ...@@ -419,9 +419,9 @@ int uv_tcp_keepalive(uv_tcp_t* handle, int on, unsigned int delay) {
} }
if (on) if (on)
handle->flags |= UV_TCP_KEEPALIVE; handle->flags |= UV_HANDLE_TCP_KEEPALIVE;
else else
handle->flags &= ~UV_TCP_KEEPALIVE; handle->flags &= ~UV_HANDLE_TCP_KEEPALIVE;
/* TODO Store delay if uv__stream_fd(handle) == -1 but don't want to enlarge /* TODO Store delay if uv__stream_fd(handle) == -1 but don't want to enlarge
* uv_tcp_t with an int that's almost never used... * uv_tcp_t with an int that's almost never used...
...@@ -433,9 +433,9 @@ int uv_tcp_keepalive(uv_tcp_t* handle, int on, unsigned int delay) { ...@@ -433,9 +433,9 @@ int uv_tcp_keepalive(uv_tcp_t* handle, int on, unsigned int delay) {
int uv_tcp_simultaneous_accepts(uv_tcp_t* handle, int enable) { int uv_tcp_simultaneous_accepts(uv_tcp_t* handle, int enable) {
if (enable) if (enable)
handle->flags &= ~UV_TCP_SINGLE_ACCEPT; handle->flags &= ~UV_HANDLE_TCP_SINGLE_ACCEPT;
else else
handle->flags |= UV_TCP_SINGLE_ACCEPT; handle->flags |= UV_HANDLE_TCP_SINGLE_ACCEPT;
return 0; return 0;
} }
......
...@@ -135,7 +135,7 @@ int uv_tty_init(uv_loop_t* loop, uv_tty_t* tty, int fd, int readable) { ...@@ -135,7 +135,7 @@ int uv_tty_init(uv_loop_t* loop, uv_tty_t* tty, int fd, int readable) {
if (r < 0) { if (r < 0) {
/* fallback to using blocking writes */ /* fallback to using blocking writes */
if (!readable) if (!readable)
flags |= UV_STREAM_BLOCKING; flags |= UV_HANDLE_BLOCKING_WRITES;
goto skip; goto skip;
} }
...@@ -177,7 +177,7 @@ skip: ...@@ -177,7 +177,7 @@ skip:
* the handle queue, since it was added by uv__handle_init in uv_stream_init. * the handle queue, since it was added by uv__handle_init in uv_stream_init.
*/ */
if (!(flags & UV_STREAM_BLOCKING)) if (!(flags & UV_HANDLE_BLOCKING_WRITES))
uv__nonblock(fd, 1); uv__nonblock(fd, 1);
#if defined(__APPLE__) #if defined(__APPLE__)
...@@ -195,9 +195,9 @@ skip: ...@@ -195,9 +195,9 @@ skip:
#endif #endif
if (readable) if (readable)
flags |= UV_STREAM_READABLE; flags |= UV_HANDLE_READABLE;
else else
flags |= UV_STREAM_WRITABLE; flags |= UV_HANDLE_WRITABLE;
uv__stream_open((uv_stream_t*) tty, fd, flags); uv__stream_open((uv_stream_t*) tty, fd, flags);
tty->mode = UV_TTY_MODE_NORMAL; tty->mode = UV_TTY_MODE_NORMAL;
......
...@@ -92,8 +92,8 @@ static void uv__udp_run_completed(uv_udp_t* handle) { ...@@ -92,8 +92,8 @@ static void uv__udp_run_completed(uv_udp_t* handle) {
uv_udp_send_t* req; uv_udp_send_t* req;
QUEUE* q; QUEUE* q;
assert(!(handle->flags & UV_UDP_PROCESSING)); assert(!(handle->flags & UV_HANDLE_UDP_PROCESSING));
handle->flags |= UV_UDP_PROCESSING; handle->flags |= UV_HANDLE_UDP_PROCESSING;
while (!QUEUE_EMPTY(&handle->write_completed_queue)) { while (!QUEUE_EMPTY(&handle->write_completed_queue)) {
q = QUEUE_HEAD(&handle->write_completed_queue); q = QUEUE_HEAD(&handle->write_completed_queue);
...@@ -128,7 +128,7 @@ static void uv__udp_run_completed(uv_udp_t* handle) { ...@@ -128,7 +128,7 @@ static void uv__udp_run_completed(uv_udp_t* handle) {
uv__handle_stop(handle); uv__handle_stop(handle);
} }
handle->flags &= ~UV_UDP_PROCESSING; handle->flags &= ~UV_HANDLE_UDP_PROCESSING;
} }
...@@ -427,7 +427,7 @@ int uv__udp_send(uv_udp_send_t* req, ...@@ -427,7 +427,7 @@ int uv__udp_send(uv_udp_send_t* req,
QUEUE_INSERT_TAIL(&handle->write_queue, &req->queue); QUEUE_INSERT_TAIL(&handle->write_queue, &req->queue);
uv__handle_start(handle); uv__handle_start(handle);
if (empty_queue && !(handle->flags & UV_UDP_PROCESSING)) { if (empty_queue && !(handle->flags & UV_HANDLE_UDP_PROCESSING)) {
uv__udp_sendmsg(handle); uv__udp_sendmsg(handle);
/* `uv__udp_sendmsg` may not be able to do non-blocking write straight /* `uv__udp_sendmsg` may not be able to do non-blocking write straight
......
...@@ -155,6 +155,18 @@ static const char* uv__unknown_err_code(int err) { ...@@ -155,6 +155,18 @@ static const char* uv__unknown_err_code(int err) {
return copy != NULL ? copy : "Unknown system error"; return copy != NULL ? copy : "Unknown system error";
} }
#define UV_ERR_NAME_GEN_R(name, _) \
case UV_## name: \
snprintf(buf, buflen, "%s", #name); break;
char* uv_err_name_r(int err, char* buf, size_t buflen) {
switch (err) {
UV_ERRNO_MAP(UV_ERR_NAME_GEN_R)
default: snprintf(buf, buflen, "Unknown system error %d", err);
}
return buf;
}
#undef UV_ERR_NAME_GEN_R
#define UV_ERR_NAME_GEN(name, _) case UV_ ## name: return #name; #define UV_ERR_NAME_GEN(name, _) case UV_ ## name: return #name;
const char* uv_err_name(int err) { const char* uv_err_name(int err) {
...@@ -166,6 +178,19 @@ const char* uv_err_name(int err) { ...@@ -166,6 +178,19 @@ const char* uv_err_name(int err) {
#undef UV_ERR_NAME_GEN #undef UV_ERR_NAME_GEN
#define UV_STRERROR_GEN_R(name, msg) \
case UV_ ## name: \
snprintf(buf, buflen, "%s", msg); break;
char* uv_strerror_r(int err, char* buf, size_t buflen) {
switch (err) {
UV_ERRNO_MAP(UV_STRERROR_GEN_R)
default: snprintf(buf, buflen, "Unknown system error %d", err);
}
return buf;
}
#undef UV_STRERROR_GEN_R
#define UV_STRERROR_GEN(name, msg) case UV_ ## name: return msg; #define UV_STRERROR_GEN(name, msg) case UV_ ## name: return msg;
const char* uv_strerror(int err) { const char* uv_strerror(int err) {
switch (err) { switch (err) {
...@@ -357,7 +382,7 @@ void uv_walk(uv_loop_t* loop, uv_walk_cb walk_cb, void* arg) { ...@@ -357,7 +382,7 @@ void uv_walk(uv_loop_t* loop, uv_walk_cb walk_cb, void* arg) {
QUEUE_REMOVE(q); QUEUE_REMOVE(q);
QUEUE_INSERT_TAIL(&loop->handle_queue, q); QUEUE_INSERT_TAIL(&loop->handle_queue, q);
if (h->flags & UV__HANDLE_INTERNAL) continue; if (h->flags & UV_HANDLE_INTERNAL) continue;
walk_cb(h, arg); walk_cb(h, arg);
} }
} }
...@@ -386,9 +411,9 @@ static void uv__print_handles(uv_loop_t* loop, int only_active, FILE* stream) { ...@@ -386,9 +411,9 @@ static void uv__print_handles(uv_loop_t* loop, int only_active, FILE* stream) {
fprintf(stream, fprintf(stream,
"[%c%c%c] %-8s %p\n", "[%c%c%c] %-8s %p\n",
"R-"[!(h->flags & UV__HANDLE_REF)], "R-"[!(h->flags & UV_HANDLE_REF)],
"A-"[!(h->flags & UV__HANDLE_ACTIVE)], "A-"[!(h->flags & UV_HANDLE_ACTIVE)],
"I-"[!(h->flags & UV__HANDLE_INTERNAL)], "I-"[!(h->flags & UV_HANDLE_INTERNAL)],
type, type,
(void*)h); (void*)h);
} }
...@@ -632,7 +657,7 @@ int uv_loop_close(uv_loop_t* loop) { ...@@ -632,7 +657,7 @@ int uv_loop_close(uv_loop_t* loop) {
QUEUE_FOREACH(q, &loop->handle_queue) { QUEUE_FOREACH(q, &loop->handle_queue) {
h = QUEUE_DATA(q, uv_handle_t, handle_queue); h = QUEUE_DATA(q, uv_handle_t, handle_queue);
if (!(h->flags & UV__HANDLE_INTERNAL)) if (!(h->flags & UV_HANDLE_INTERNAL))
return UV_EBUSY; return UV_EBUSY;
} }
......
...@@ -59,22 +59,67 @@ extern int snprintf(char*, size_t, const char*, ...); ...@@ -59,22 +59,67 @@ extern int snprintf(char*, size_t, const char*, ...);
#define STATIC_ASSERT(expr) \ #define STATIC_ASSERT(expr) \
void uv__static_assert(int static_assert_failed[1 - 2 * !(expr)]) void uv__static_assert(int static_assert_failed[1 - 2 * !(expr)])
#ifndef _WIN32 /* Handle flags. Some flags are specific to Windows or UNIX. */
enum { enum {
UV__SIGNAL_ONE_SHOT = 0x80000, /* On signal reception remove sighandler */ /* Used by all handles. */
UV__HANDLE_INTERNAL = 0x8000, UV_HANDLE_CLOSING = 0x00000001,
UV__HANDLE_ACTIVE = 0x4000, UV_HANDLE_CLOSED = 0x00000002,
UV__HANDLE_REF = 0x2000, UV_HANDLE_ACTIVE = 0x00000004,
UV__HANDLE_CLOSING = 0 /* no-op on unix */ UV_HANDLE_REF = 0x00000008,
UV_HANDLE_INTERNAL = 0x00000010,
UV_HANDLE_ENDGAME_QUEUED = 0x00000020,
/* Used by streams. */
UV_HANDLE_LISTENING = 0x00000040,
UV_HANDLE_CONNECTION = 0x00000080,
UV_HANDLE_SHUTTING = 0x00000100,
UV_HANDLE_SHUT = 0x00000200,
UV_HANDLE_READ_PARTIAL = 0x00000400,
UV_HANDLE_READ_EOF = 0x00000800,
/* Used by streams and UDP handles. */
UV_HANDLE_READING = 0x00001000,
UV_HANDLE_BOUND = 0x00002000,
UV_HANDLE_READABLE = 0x00004000,
UV_HANDLE_WRITABLE = 0x00008000,
UV_HANDLE_READ_PENDING = 0x00010000,
UV_HANDLE_SYNC_BYPASS_IOCP = 0x00020000,
UV_HANDLE_ZERO_READ = 0x00040000,
UV_HANDLE_EMULATE_IOCP = 0x00080000,
UV_HANDLE_BLOCKING_WRITES = 0x00100000,
UV_HANDLE_CANCELLATION_PENDING = 0x00200000,
/* Used by uv_tcp_t and uv_udp_t handles */
UV_HANDLE_IPV6 = 0x00400000,
/* Only used by uv_tcp_t handles. */
UV_HANDLE_TCP_NODELAY = 0x01000000,
UV_HANDLE_TCP_KEEPALIVE = 0x02000000,
UV_HANDLE_TCP_SINGLE_ACCEPT = 0x04000000,
UV_HANDLE_TCP_ACCEPT_STATE_CHANGING = 0x08000000,
UV_HANDLE_TCP_SOCKET_CLOSED = 0x10000000,
UV_HANDLE_SHARED_TCP_SOCKET = 0x20000000,
/* Only used by uv_udp_t handles. */
UV_HANDLE_UDP_PROCESSING = 0x01000000,
/* Only used by uv_pipe_t handles. */
UV_HANDLE_NON_OVERLAPPED_PIPE = 0x01000000,
UV_HANDLE_PIPESERVER = 0x02000000,
/* Only used by uv_tty_t handles. */
UV_HANDLE_TTY_READABLE = 0x01000000,
UV_HANDLE_TTY_RAW = 0x02000000,
UV_HANDLE_TTY_SAVED_POSITION = 0x04000000,
UV_HANDLE_TTY_SAVED_ATTRIBUTES = 0x08000000,
/* Only used by uv_signal_t handles. */
UV_SIGNAL_ONE_SHOT_DISPATCHED = 0x01000000,
UV_SIGNAL_ONE_SHOT = 0x02000000,
/* Only used by uv_poll_t handles. */
UV_HANDLE_POLL_SLOW = 0x01000000
}; };
#else
# define UV__SIGNAL_ONE_SHOT_DISPATCHED 0x200
# define UV__SIGNAL_ONE_SHOT 0x100
# define UV__HANDLE_INTERNAL 0x80
# define UV__HANDLE_ACTIVE 0x40
# define UV__HANDLE_REF 0x20
# define UV__HANDLE_CLOSING 0x01
#endif
int uv__loop_configure(uv_loop_t* loop, uv_loop_option option, va_list ap); int uv__loop_configure(uv_loop_t* loop, uv_loop_option option, va_list ap);
...@@ -132,6 +177,10 @@ int uv__socket_sockopt(uv_handle_t* handle, int optname, int* value); ...@@ -132,6 +177,10 @@ int uv__socket_sockopt(uv_handle_t* handle, int optname, int* value);
void uv__fs_scandir_cleanup(uv_fs_t* req); void uv__fs_scandir_cleanup(uv_fs_t* req);
int uv__next_timeout(const uv_loop_t* loop);
void uv__run_timers(uv_loop_t* loop);
void uv__timer_close(uv_timer_t* handle);
#define uv__has_active_reqs(loop) \ #define uv__has_active_reqs(loop) \
((loop)->active_reqs.count > 0) ((loop)->active_reqs.count > 0)
...@@ -164,49 +213,47 @@ void uv__fs_scandir_cleanup(uv_fs_t* req); ...@@ -164,49 +213,47 @@ void uv__fs_scandir_cleanup(uv_fs_t* req);
while (0) while (0)
#define uv__is_active(h) \ #define uv__is_active(h) \
(((h)->flags & UV__HANDLE_ACTIVE) != 0) (((h)->flags & UV_HANDLE_ACTIVE) != 0)
#define uv__is_closing(h) \ #define uv__is_closing(h) \
(((h)->flags & (UV_CLOSING | UV_CLOSED)) != 0) (((h)->flags & (UV_HANDLE_CLOSING | UV_HANDLE_CLOSED)) != 0)
#define uv__handle_start(h) \ #define uv__handle_start(h) \
do { \ do { \
assert(((h)->flags & UV__HANDLE_CLOSING) == 0); \ if (((h)->flags & UV_HANDLE_ACTIVE) != 0) break; \
if (((h)->flags & UV__HANDLE_ACTIVE) != 0) break; \ (h)->flags |= UV_HANDLE_ACTIVE; \
(h)->flags |= UV__HANDLE_ACTIVE; \ if (((h)->flags & UV_HANDLE_REF) != 0) uv__active_handle_add(h); \
if (((h)->flags & UV__HANDLE_REF) != 0) uv__active_handle_add(h); \
} \ } \
while (0) while (0)
#define uv__handle_stop(h) \ #define uv__handle_stop(h) \
do { \ do { \
assert(((h)->flags & UV__HANDLE_CLOSING) == 0); \ if (((h)->flags & UV_HANDLE_ACTIVE) == 0) break; \
if (((h)->flags & UV__HANDLE_ACTIVE) == 0) break; \ (h)->flags &= ~UV_HANDLE_ACTIVE; \
(h)->flags &= ~UV__HANDLE_ACTIVE; \ if (((h)->flags & UV_HANDLE_REF) != 0) uv__active_handle_rm(h); \
if (((h)->flags & UV__HANDLE_REF) != 0) uv__active_handle_rm(h); \
} \ } \
while (0) while (0)
#define uv__handle_ref(h) \ #define uv__handle_ref(h) \
do { \ do { \
if (((h)->flags & UV__HANDLE_REF) != 0) break; \ if (((h)->flags & UV_HANDLE_REF) != 0) break; \
(h)->flags |= UV__HANDLE_REF; \ (h)->flags |= UV_HANDLE_REF; \
if (((h)->flags & UV__HANDLE_CLOSING) != 0) break; \ if (((h)->flags & UV_HANDLE_CLOSING) != 0) break; \
if (((h)->flags & UV__HANDLE_ACTIVE) != 0) uv__active_handle_add(h); \ if (((h)->flags & UV_HANDLE_ACTIVE) != 0) uv__active_handle_add(h); \
} \ } \
while (0) while (0)
#define uv__handle_unref(h) \ #define uv__handle_unref(h) \
do { \ do { \
if (((h)->flags & UV__HANDLE_REF) == 0) break; \ if (((h)->flags & UV_HANDLE_REF) == 0) break; \
(h)->flags &= ~UV__HANDLE_REF; \ (h)->flags &= ~UV_HANDLE_REF; \
if (((h)->flags & UV__HANDLE_CLOSING) != 0) break; \ if (((h)->flags & UV_HANDLE_CLOSING) != 0) break; \
if (((h)->flags & UV__HANDLE_ACTIVE) != 0) uv__active_handle_rm(h); \ if (((h)->flags & UV_HANDLE_ACTIVE) != 0) uv__active_handle_rm(h); \
} \ } \
while (0) while (0)
#define uv__has_ref(h) \ #define uv__has_ref(h) \
(((h)->flags & UV__HANDLE_REF) != 0) (((h)->flags & UV_HANDLE_REF) != 0)
#if defined(_WIN32) #if defined(_WIN32)
# define uv__handle_platform_init(h) ((h)->u.fd = -1) # define uv__handle_platform_init(h) ((h)->u.fd = -1)
...@@ -218,7 +265,7 @@ void uv__fs_scandir_cleanup(uv_fs_t* req); ...@@ -218,7 +265,7 @@ void uv__fs_scandir_cleanup(uv_fs_t* req);
do { \ do { \
(h)->loop = (loop_); \ (h)->loop = (loop_); \
(h)->type = (type_); \ (h)->type = (type_); \
(h)->flags = UV__HANDLE_REF; /* Ref the loop when active. */ \ (h)->flags = UV_HANDLE_REF; /* Ref the loop when active. */ \
QUEUE_INSERT_TAIL(&(loop_)->handle_queue, &(h)->handle_queue); \ QUEUE_INSERT_TAIL(&(loop_)->handle_queue, &(h)->handle_queue); \
uv__handle_platform_init(h); \ uv__handle_platform_init(h); \
} \ } \
......
...@@ -29,7 +29,7 @@ ...@@ -29,7 +29,7 @@
void uv_async_endgame(uv_loop_t* loop, uv_async_t* handle) { void uv_async_endgame(uv_loop_t* loop, uv_async_t* handle) {
if (handle->flags & UV__HANDLE_CLOSING && if (handle->flags & UV_HANDLE_CLOSING &&
!handle->async_sent) { !handle->async_sent) {
assert(!(handle->flags & UV_HANDLE_CLOSED)); assert(!(handle->flags & UV_HANDLE_CLOSED));
uv__handle_close(handle); uv__handle_close(handle);
...@@ -73,7 +73,7 @@ int uv_async_send(uv_async_t* handle) { ...@@ -73,7 +73,7 @@ int uv_async_send(uv_async_t* handle) {
/* The user should make sure never to call uv_async_send to a closing or /* The user should make sure never to call uv_async_send to a closing or
* closed handle. */ * closed handle. */
assert(!(handle->flags & UV__HANDLE_CLOSING)); assert(!(handle->flags & UV_HANDLE_CLOSING));
if (!uv__atomic_exchange_set(&handle->async_sent)) { if (!uv__atomic_exchange_set(&handle->async_sent)) {
POST_COMPLETION_FOR_REQ(loop, &handle->async_req); POST_COMPLETION_FOR_REQ(loop, &handle->async_req);
...@@ -90,7 +90,7 @@ void uv_process_async_wakeup_req(uv_loop_t* loop, uv_async_t* handle, ...@@ -90,7 +90,7 @@ void uv_process_async_wakeup_req(uv_loop_t* loop, uv_async_t* handle,
handle->async_sent = 0; handle->async_sent = 0;
if (handle->flags & UV__HANDLE_CLOSING) { if (handle->flags & UV_HANDLE_CLOSING) {
uv_want_endgame(loop, (uv_handle_t*)handle); uv_want_endgame(loop, (uv_handle_t*)handle);
} else if (handle->async_cb != NULL) { } else if (handle->async_cb != NULL) {
handle->async_cb(handle); handle->async_cb(handle);
......
...@@ -33,6 +33,7 @@ ...@@ -33,6 +33,7 @@
#include "internal.h" #include "internal.h"
#include "queue.h" #include "queue.h"
#include "handle-inl.h" #include "handle-inl.h"
#include "heap-inl.h"
#include "req-inl.h" #include "req-inl.h"
/* uv_once initialization guards */ /* uv_once initialization guards */
...@@ -221,6 +222,7 @@ static void uv_init(void) { ...@@ -221,6 +222,7 @@ static void uv_init(void) {
int uv_loop_init(uv_loop_t* loop) { int uv_loop_init(uv_loop_t* loop) {
struct heap* timer_heap;
int err; int err;
/* Initialize libuv itself first */ /* Initialize libuv itself first */
...@@ -246,7 +248,11 @@ int uv_loop_init(uv_loop_t* loop) { ...@@ -246,7 +248,11 @@ int uv_loop_init(uv_loop_t* loop) {
loop->endgame_handles = NULL; loop->endgame_handles = NULL;
RB_INIT(&loop->timers); loop->timer_heap = timer_heap = uv__malloc(sizeof(*timer_heap));
if (timer_heap == NULL)
goto fail_timers_alloc;
heap_init(timer_heap);
loop->check_handles = NULL; loop->check_handles = NULL;
loop->prepare_handles = NULL; loop->prepare_handles = NULL;
...@@ -273,7 +279,7 @@ int uv_loop_init(uv_loop_t* loop) { ...@@ -273,7 +279,7 @@ int uv_loop_init(uv_loop_t* loop) {
goto fail_async_init; goto fail_async_init;
uv__handle_unref(&loop->wq_async); uv__handle_unref(&loop->wq_async);
loop->wq_async.flags |= UV__HANDLE_INTERNAL; loop->wq_async.flags |= UV_HANDLE_INTERNAL;
err = uv__loops_add(loop); err = uv__loops_add(loop);
if (err) if (err)
...@@ -285,6 +291,10 @@ fail_async_init: ...@@ -285,6 +291,10 @@ fail_async_init:
uv_mutex_destroy(&loop->wq_mutex); uv_mutex_destroy(&loop->wq_mutex);
fail_mutex_init: fail_mutex_init:
uv__free(timer_heap);
loop->timer_heap = NULL;
fail_timers_alloc:
CloseHandle(loop->iocp); CloseHandle(loop->iocp);
loop->iocp = INVALID_HANDLE_VALUE; loop->iocp = INVALID_HANDLE_VALUE;
...@@ -292,6 +302,13 @@ fail_mutex_init: ...@@ -292,6 +302,13 @@ fail_mutex_init:
} }
void uv_update_time(uv_loop_t* loop) {
uint64_t new_time = uv__hrtime(1000);
assert(new_time >= loop->time);
loop->time = new_time;
}
void uv__once_init(void) { void uv__once_init(void) {
uv_once(&uv_init_guard_, uv_init); uv_once(&uv_init_guard_, uv_init);
} }
...@@ -320,6 +337,9 @@ void uv__loop_close(uv_loop_t* loop) { ...@@ -320,6 +337,9 @@ void uv__loop_close(uv_loop_t* loop) {
uv_mutex_unlock(&loop->wq_mutex); uv_mutex_unlock(&loop->wq_mutex);
uv_mutex_destroy(&loop->wq_mutex); uv_mutex_destroy(&loop->wq_mutex);
uv__free(loop->timer_heap);
loop->timer_heap = NULL;
CloseHandle(loop->iocp); CloseHandle(loop->iocp);
} }
...@@ -441,7 +461,7 @@ int uv_run(uv_loop_t *loop, uv_run_mode mode) { ...@@ -441,7 +461,7 @@ int uv_run(uv_loop_t *loop, uv_run_mode mode) {
while (r != 0 && loop->stop_flag == 0) { while (r != 0 && loop->stop_flag == 0) {
uv_update_time(loop); uv_update_time(loop);
uv_process_timers(loop); uv__run_timers(loop);
ran_pending = uv_process_reqs(loop); ran_pending = uv_process_reqs(loop);
uv_idle_invoke(loop); uv_idle_invoke(loop);
...@@ -465,7 +485,7 @@ int uv_run(uv_loop_t *loop, uv_run_mode mode) { ...@@ -465,7 +485,7 @@ int uv_run(uv_loop_t *loop, uv_run_mode mode) {
* UV_RUN_NOWAIT makes no guarantees about progress so it's omitted from * UV_RUN_NOWAIT makes no guarantees about progress so it's omitted from
* the check. * the check.
*/ */
uv_process_timers(loop); uv__run_timers(loop);
} }
r = uv__loop_alive(loop); r = uv__loop_alive(loop);
......
...@@ -419,7 +419,7 @@ void uv_process_fs_event_req(uv_loop_t* loop, uv_req_t* req, ...@@ -419,7 +419,7 @@ void uv_process_fs_event_req(uv_loop_t* loop, uv_req_t* req,
* - We are not active, just ignore the callback * - We are not active, just ignore the callback
*/ */
if (!uv__is_active(handle)) { if (!uv__is_active(handle)) {
if (handle->flags & UV__HANDLE_CLOSING) { if (handle->flags & UV_HANDLE_CLOSING) {
uv_want_endgame(loop, (uv_handle_t*) handle); uv_want_endgame(loop, (uv_handle_t*) handle);
} }
return; return;
...@@ -543,7 +543,7 @@ void uv_process_fs_event_req(uv_loop_t* loop, uv_req_t* req, ...@@ -543,7 +543,7 @@ void uv_process_fs_event_req(uv_loop_t* loop, uv_req_t* req,
} }
offset = file_info->NextEntryOffset; offset = file_info->NextEntryOffset;
} while (offset && !(handle->flags & UV__HANDLE_CLOSING)); } while (offset && !(handle->flags & UV_HANDLE_CLOSING));
} else { } else {
handle->cb(handle, NULL, UV_CHANGE, 0); handle->cb(handle, NULL, UV_CHANGE, 0);
} }
...@@ -552,7 +552,7 @@ void uv_process_fs_event_req(uv_loop_t* loop, uv_req_t* req, ...@@ -552,7 +552,7 @@ void uv_process_fs_event_req(uv_loop_t* loop, uv_req_t* req,
handle->cb(handle, NULL, 0, uv_translate_sys_error(err)); handle->cb(handle, NULL, 0, uv_translate_sys_error(err));
} }
if (!(handle->flags & UV__HANDLE_CLOSING)) { if (!(handle->flags & UV_HANDLE_CLOSING)) {
uv_fs_event_queue_readdirchanges(loop, handle); uv_fs_event_queue_readdirchanges(loop, handle);
} else { } else {
uv_want_endgame(loop, (uv_handle_t*)handle); uv_want_endgame(loop, (uv_handle_t*)handle);
...@@ -573,7 +573,7 @@ void uv_fs_event_close(uv_loop_t* loop, uv_fs_event_t* handle) { ...@@ -573,7 +573,7 @@ void uv_fs_event_close(uv_loop_t* loop, uv_fs_event_t* handle) {
void uv_fs_event_endgame(uv_loop_t* loop, uv_fs_event_t* handle) { void uv_fs_event_endgame(uv_loop_t* loop, uv_fs_event_t* handle) {
if ((handle->flags & UV__HANDLE_CLOSING) && !handle->req_pending) { if ((handle->flags & UV_HANDLE_CLOSING) && !handle->req_pending) {
assert(!(handle->flags & UV_HANDLE_CLOSED)); assert(!(handle->flags & UV_HANDLE_CLOSED));
if (handle->buffer) { if (handle->buffer) {
......
...@@ -32,7 +32,7 @@ ...@@ -32,7 +32,7 @@
#define DECREASE_ACTIVE_COUNT(loop, handle) \ #define DECREASE_ACTIVE_COUNT(loop, handle) \
do { \ do { \
if (--(handle)->activecnt == 0 && \ if (--(handle)->activecnt == 0 && \
!((handle)->flags & UV__HANDLE_CLOSING)) { \ !((handle)->flags & UV_HANDLE_CLOSING)) { \
uv__handle_stop((handle)); \ uv__handle_stop((handle)); \
} \ } \
assert((handle)->activecnt >= 0); \ assert((handle)->activecnt >= 0); \
...@@ -53,7 +53,7 @@ ...@@ -53,7 +53,7 @@
assert(handle->reqs_pending > 0); \ assert(handle->reqs_pending > 0); \
handle->reqs_pending--; \ handle->reqs_pending--; \
\ \
if (handle->flags & UV__HANDLE_CLOSING && \ if (handle->flags & UV_HANDLE_CLOSING && \
handle->reqs_pending == 0) { \ handle->reqs_pending == 0) { \
uv_want_endgame(loop, (uv_handle_t*)handle); \ uv_want_endgame(loop, (uv_handle_t*)handle); \
} \ } \
...@@ -62,14 +62,14 @@ ...@@ -62,14 +62,14 @@
#define uv__handle_closing(handle) \ #define uv__handle_closing(handle) \
do { \ do { \
assert(!((handle)->flags & UV__HANDLE_CLOSING)); \ assert(!((handle)->flags & UV_HANDLE_CLOSING)); \
\ \
if (!(((handle)->flags & UV__HANDLE_ACTIVE) && \ if (!(((handle)->flags & UV_HANDLE_ACTIVE) && \
((handle)->flags & UV__HANDLE_REF))) \ ((handle)->flags & UV_HANDLE_REF))) \
uv__active_handle_add((uv_handle_t*) (handle)); \ uv__active_handle_add((uv_handle_t*) (handle)); \
\ \
(handle)->flags |= UV__HANDLE_CLOSING; \ (handle)->flags |= UV_HANDLE_CLOSING; \
(handle)->flags &= ~UV__HANDLE_ACTIVE; \ (handle)->flags &= ~UV_HANDLE_ACTIVE; \
} while (0) } while (0)
...@@ -126,7 +126,8 @@ INLINE static void uv_process_endgames(uv_loop_t* loop) { ...@@ -126,7 +126,8 @@ INLINE static void uv_process_endgames(uv_loop_t* loop) {
break; break;
case UV_TIMER: case UV_TIMER:
uv_timer_endgame(loop, (uv_timer_t*) handle); uv__timer_close((uv_timer_t*) handle);
uv__handle_close(handle);
break; break;
case UV_PREPARE: case UV_PREPARE:
......
...@@ -59,15 +59,15 @@ uv_handle_type uv_guess_handle(uv_file file) { ...@@ -59,15 +59,15 @@ uv_handle_type uv_guess_handle(uv_file file) {
int uv_is_active(const uv_handle_t* handle) { int uv_is_active(const uv_handle_t* handle) {
return (handle->flags & UV__HANDLE_ACTIVE) && return (handle->flags & UV_HANDLE_ACTIVE) &&
!(handle->flags & UV__HANDLE_CLOSING); !(handle->flags & UV_HANDLE_CLOSING);
} }
void uv_close(uv_handle_t* handle, uv_close_cb cb) { void uv_close(uv_handle_t* handle, uv_close_cb cb) {
uv_loop_t* loop = handle->loop; uv_loop_t* loop = handle->loop;
if (handle->flags & UV__HANDLE_CLOSING) { if (handle->flags & UV_HANDLE_CLOSING) {
assert(0); assert(0);
return; return;
} }
...@@ -150,7 +150,7 @@ void uv_close(uv_handle_t* handle, uv_close_cb cb) { ...@@ -150,7 +150,7 @@ void uv_close(uv_handle_t* handle, uv_close_cb cb) {
int uv_is_closing(const uv_handle_t* handle) { int uv_is_closing(const uv_handle_t* handle) {
return !!(handle->flags & (UV__HANDLE_CLOSING | UV_HANDLE_CLOSED)); return !!(handle->flags & (UV_HANDLE_CLOSING | UV_HANDLE_CLOSED));
} }
......
...@@ -57,69 +57,6 @@ extern UV_THREAD_LOCAL int uv__crt_assert_enabled; ...@@ -57,69 +57,6 @@ extern UV_THREAD_LOCAL int uv__crt_assert_enabled;
#define UV_END_DISABLE_CRT_ASSERT() #define UV_END_DISABLE_CRT_ASSERT()
#endif #endif
/*
* Handles
* (also see handle-inl.h)
*/
/* Used by all handles. */
#define UV_HANDLE_CLOSED 0x00000002
#define UV_HANDLE_ENDGAME_QUEUED 0x00000008
/* uv-common.h: #define UV__HANDLE_CLOSING 0x00000001 */
/* uv-common.h: #define UV__HANDLE_ACTIVE 0x00000040 */
/* uv-common.h: #define UV__HANDLE_REF 0x00000020 */
/* uv-common.h: #define UV_HANDLE_INTERNAL 0x00000080 */
/* Used by streams and UDP handles. */
#define UV_HANDLE_READING 0x00000100
#define UV_HANDLE_BOUND 0x00000200
#define UV_HANDLE_LISTENING 0x00000800
#define UV_HANDLE_CONNECTION 0x00001000
#define UV_HANDLE_READABLE 0x00008000
#define UV_HANDLE_WRITABLE 0x00010000
#define UV_HANDLE_READ_PENDING 0x00020000
#define UV_HANDLE_SYNC_BYPASS_IOCP 0x00040000
#define UV_HANDLE_ZERO_READ 0x00080000
#define UV_HANDLE_EMULATE_IOCP 0x00100000
#define UV_HANDLE_BLOCKING_WRITES 0x00200000
#define UV_HANDLE_CANCELLATION_PENDING 0x00400000
/* Used by uv_tcp_t and uv_udp_t handles */
#define UV_HANDLE_IPV6 0x01000000
/* Only used by uv_tcp_t handles. */
#define UV_HANDLE_TCP_NODELAY 0x02000000
#define UV_HANDLE_TCP_KEEPALIVE 0x04000000
#define UV_HANDLE_TCP_SINGLE_ACCEPT 0x08000000
#define UV_HANDLE_TCP_ACCEPT_STATE_CHANGING 0x10000000
#define UV_HANDLE_TCP_SOCKET_CLOSED 0x20000000
#define UV_HANDLE_SHARED_TCP_SOCKET 0x40000000
/* Only used by uv_pipe_t handles. */
#define UV_HANDLE_NON_OVERLAPPED_PIPE 0x01000000
#define UV_HANDLE_PIPESERVER 0x02000000
/* Only used by uv_tty_t handles. */
#define UV_HANDLE_TTY_READABLE 0x01000000
#define UV_HANDLE_TTY_RAW 0x02000000
#define UV_HANDLE_TTY_SAVED_POSITION 0x04000000
#define UV_HANDLE_TTY_SAVED_ATTRIBUTES 0x08000000
/* Only used by uv_poll_t handles. */
#define UV_HANDLE_POLL_SLOW 0x02000000
/*
* Requests: see req-inl.h
*/
/*
* Streams: see stream-inl.h
*/
/* /*
* TCP * TCP
*/ */
...@@ -246,15 +183,6 @@ int uv_poll_close(uv_loop_t* loop, uv_poll_t* handle); ...@@ -246,15 +183,6 @@ int uv_poll_close(uv_loop_t* loop, uv_poll_t* handle);
void uv_poll_endgame(uv_loop_t* loop, uv_poll_t* handle); void uv_poll_endgame(uv_loop_t* loop, uv_poll_t* handle);
/*
* Timers
*/
void uv_timer_endgame(uv_loop_t* loop, uv_timer_t* handle);
DWORD uv__next_timeout(const uv_loop_t* loop);
void uv_process_timers(uv_loop_t* loop);
/* /*
* Loop watchers * Loop watchers
*/ */
......
...@@ -27,7 +27,7 @@ ...@@ -27,7 +27,7 @@
void uv_loop_watcher_endgame(uv_loop_t* loop, uv_handle_t* handle) { void uv_loop_watcher_endgame(uv_loop_t* loop, uv_handle_t* handle) {
if (handle->flags & UV__HANDLE_CLOSING) { if (handle->flags & UV_HANDLE_CLOSING) {
assert(!(handle->flags & UV_HANDLE_CLOSED)); assert(!(handle->flags & UV_HANDLE_CLOSED));
handle->flags |= UV_HANDLE_CLOSED; handle->flags |= UV_HANDLE_CLOSED;
uv__handle_close(handle); uv__handle_close(handle);
......
...@@ -21,7 +21,6 @@ ...@@ -21,7 +21,6 @@
#include <assert.h> #include <assert.h>
#include <io.h> #include <io.h>
#include <stdbool.h>
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
...@@ -347,7 +346,7 @@ void uv_pipe_endgame(uv_loop_t* loop, uv_pipe_t* handle) { ...@@ -347,7 +346,7 @@ void uv_pipe_endgame(uv_loop_t* loop, uv_pipe_t* handle) {
/* Clear the shutdown_req field so we don't go here again. */ /* Clear the shutdown_req field so we don't go here again. */
handle->stream.conn.shutdown_req = NULL; handle->stream.conn.shutdown_req = NULL;
if (handle->flags & UV__HANDLE_CLOSING) { if (handle->flags & UV_HANDLE_CLOSING) {
UNREGISTER_HANDLE_REQ(loop, handle, req); UNREGISTER_HANDLE_REQ(loop, handle, req);
/* Already closing. Cancel the shutdown. */ /* Already closing. Cancel the shutdown. */
...@@ -408,7 +407,7 @@ void uv_pipe_endgame(uv_loop_t* loop, uv_pipe_t* handle) { ...@@ -408,7 +407,7 @@ void uv_pipe_endgame(uv_loop_t* loop, uv_pipe_t* handle) {
} }
} }
if (handle->flags & UV__HANDLE_CLOSING && if (handle->flags & UV_HANDLE_CLOSING &&
handle->reqs_pending == 0) { handle->reqs_pending == 0) {
assert(!(handle->flags & UV_HANDLE_CLOSED)); assert(!(handle->flags & UV_HANDLE_CLOSED));
...@@ -907,7 +906,7 @@ int uv_pipe_accept(uv_pipe_t* server, uv_stream_t* client) { ...@@ -907,7 +906,7 @@ int uv_pipe_accept(uv_pipe_t* server, uv_stream_t* client) {
req->next_pending = NULL; req->next_pending = NULL;
req->pipeHandle = INVALID_HANDLE_VALUE; req->pipeHandle = INVALID_HANDLE_VALUE;
if (!(server->flags & UV__HANDLE_CLOSING)) { if (!(server->flags & UV_HANDLE_CLOSING)) {
uv_pipe_queue_accept(loop, server, req, FALSE); uv_pipe_queue_accept(loop, server, req, FALSE);
} }
} }
...@@ -1294,7 +1293,7 @@ static int uv__pipe_write_data(uv_loop_t* loop, ...@@ -1294,7 +1293,7 @@ static int uv__pipe_write_data(uv_loop_t* loop,
size_t nbufs, size_t nbufs,
uv_stream_t* send_handle, uv_stream_t* send_handle,
uv_write_cb cb, uv_write_cb cb,
bool copy_always) { int copy_always) {
int err; int err;
int result; int result;
uv_buf_t write_buf; uv_buf_t write_buf;
...@@ -1536,7 +1535,7 @@ int uv__pipe_write_ipc(uv_loop_t* loop, ...@@ -1536,7 +1535,7 @@ int uv__pipe_write_ipc(uv_loop_t* loop,
/* Write buffers. We set the `always_copy` flag, so it is not a problem that /* Write buffers. We set the `always_copy` flag, so it is not a problem that
* some of the written data lives on the stack. */ * some of the written data lives on the stack. */
err = uv__pipe_write_data( err = uv__pipe_write_data(
loop, req, handle, bufs, buf_count, send_handle, cb, true); loop, req, handle, bufs, buf_count, send_handle, cb, 1);
/* If we had to heap-allocate the bufs array, free it now. */ /* If we had to heap-allocate the bufs array, free it now. */
if (bufs != stack_bufs) { if (bufs != stack_bufs) {
...@@ -1561,7 +1560,7 @@ int uv__pipe_write(uv_loop_t* loop, ...@@ -1561,7 +1560,7 @@ int uv__pipe_write(uv_loop_t* loop,
/* Non-IPC pipe write: put data on the wire directly. */ /* Non-IPC pipe write: put data on the wire directly. */
assert(send_handle == NULL); assert(send_handle == NULL);
return uv__pipe_write_data( return uv__pipe_write_data(
loop, req, handle, bufs, nbufs, NULL, cb, false); loop, req, handle, bufs, nbufs, NULL, cb, 0);
} }
} }
...@@ -1675,7 +1674,7 @@ static DWORD uv__pipe_read_data(uv_loop_t* loop, ...@@ -1675,7 +1674,7 @@ static DWORD uv__pipe_read_data(uv_loop_t* loop,
static DWORD uv__pipe_read_ipc(uv_loop_t* loop, uv_pipe_t* handle) { static DWORD uv__pipe_read_ipc(uv_loop_t* loop, uv_pipe_t* handle) {
DWORD* data_remaining = &handle->pipe.conn.ipc_data_frame.payload_remaining; uint32_t* data_remaining = &handle->pipe.conn.ipc_data_frame.payload_remaining;
int err; int err;
if (*data_remaining > 0) { if (*data_remaining > 0) {
...@@ -1856,7 +1855,7 @@ void uv_process_pipe_accept_req(uv_loop_t* loop, uv_pipe_t* handle, ...@@ -1856,7 +1855,7 @@ void uv_process_pipe_accept_req(uv_loop_t* loop, uv_pipe_t* handle,
assert(handle->type == UV_NAMED_PIPE); assert(handle->type == UV_NAMED_PIPE);
if (handle->flags & UV__HANDLE_CLOSING) { if (handle->flags & UV_HANDLE_CLOSING) {
/* The req->pipeHandle should be freed already in uv_pipe_cleanup(). */ /* The req->pipeHandle should be freed already in uv_pipe_cleanup(). */
assert(req->pipeHandle == INVALID_HANDLE_VALUE); assert(req->pipeHandle == INVALID_HANDLE_VALUE);
DECREASE_PENDING_REQ_COUNT(handle); DECREASE_PENDING_REQ_COUNT(handle);
...@@ -1876,7 +1875,7 @@ void uv_process_pipe_accept_req(uv_loop_t* loop, uv_pipe_t* handle, ...@@ -1876,7 +1875,7 @@ void uv_process_pipe_accept_req(uv_loop_t* loop, uv_pipe_t* handle,
CloseHandle(req->pipeHandle); CloseHandle(req->pipeHandle);
req->pipeHandle = INVALID_HANDLE_VALUE; req->pipeHandle = INVALID_HANDLE_VALUE;
} }
if (!(handle->flags & UV__HANDLE_CLOSING)) { if (!(handle->flags & UV_HANDLE_CLOSING)) {
uv_pipe_queue_accept(loop, handle, req, FALSE); uv_pipe_queue_accept(loop, handle, req, FALSE);
} }
} }
......
...@@ -218,7 +218,7 @@ static void uv__fast_poll_process_poll_req(uv_loop_t* loop, uv_poll_t* handle, ...@@ -218,7 +218,7 @@ static void uv__fast_poll_process_poll_req(uv_loop_t* loop, uv_poll_t* handle,
if ((handle->events & ~(handle->submitted_events_1 | if ((handle->events & ~(handle->submitted_events_1 |
handle->submitted_events_2)) != 0) { handle->submitted_events_2)) != 0) {
uv__fast_poll_submit_poll_req(loop, handle); uv__fast_poll_submit_poll_req(loop, handle);
} else if ((handle->flags & UV__HANDLE_CLOSING) && } else if ((handle->flags & UV_HANDLE_CLOSING) &&
handle->submitted_events_1 == 0 && handle->submitted_events_1 == 0 &&
handle->submitted_events_2 == 0) { handle->submitted_events_2 == 0) {
uv_want_endgame(loop, (uv_handle_t*) handle); uv_want_endgame(loop, (uv_handle_t*) handle);
...@@ -228,7 +228,7 @@ static void uv__fast_poll_process_poll_req(uv_loop_t* loop, uv_poll_t* handle, ...@@ -228,7 +228,7 @@ static void uv__fast_poll_process_poll_req(uv_loop_t* loop, uv_poll_t* handle,
static int uv__fast_poll_set(uv_loop_t* loop, uv_poll_t* handle, int events) { static int uv__fast_poll_set(uv_loop_t* loop, uv_poll_t* handle, int events) {
assert(handle->type == UV_POLL); assert(handle->type == UV_POLL);
assert(!(handle->flags & UV__HANDLE_CLOSING)); assert(!(handle->flags & UV_HANDLE_CLOSING));
assert((events & ~(UV_READABLE | UV_WRITABLE | UV_DISCONNECT)) == 0); assert((events & ~(UV_READABLE | UV_WRITABLE | UV_DISCONNECT)) == 0);
handle->events = events; handle->events = events;
...@@ -461,7 +461,7 @@ static void uv__slow_poll_process_poll_req(uv_loop_t* loop, uv_poll_t* handle, ...@@ -461,7 +461,7 @@ static void uv__slow_poll_process_poll_req(uv_loop_t* loop, uv_poll_t* handle,
if ((handle->events & ~(handle->submitted_events_1 | if ((handle->events & ~(handle->submitted_events_1 |
handle->submitted_events_2)) != 0) { handle->submitted_events_2)) != 0) {
uv__slow_poll_submit_poll_req(loop, handle); uv__slow_poll_submit_poll_req(loop, handle);
} else if ((handle->flags & UV__HANDLE_CLOSING) && } else if ((handle->flags & UV_HANDLE_CLOSING) &&
handle->submitted_events_1 == 0 && handle->submitted_events_1 == 0 &&
handle->submitted_events_2 == 0) { handle->submitted_events_2 == 0) {
uv_want_endgame(loop, (uv_handle_t*) handle); uv_want_endgame(loop, (uv_handle_t*) handle);
...@@ -471,7 +471,7 @@ static void uv__slow_poll_process_poll_req(uv_loop_t* loop, uv_poll_t* handle, ...@@ -471,7 +471,7 @@ static void uv__slow_poll_process_poll_req(uv_loop_t* loop, uv_poll_t* handle,
static int uv__slow_poll_set(uv_loop_t* loop, uv_poll_t* handle, int events) { static int uv__slow_poll_set(uv_loop_t* loop, uv_poll_t* handle, int events) {
assert(handle->type == UV_POLL); assert(handle->type == UV_POLL);
assert(!(handle->flags & UV__HANDLE_CLOSING)); assert(!(handle->flags & UV_HANDLE_CLOSING));
assert((events & ~(UV_READABLE | UV_WRITABLE)) == 0); assert((events & ~(UV_READABLE | UV_WRITABLE)) == 0);
handle->events = events; handle->events = events;
...@@ -633,7 +633,7 @@ int uv_poll_close(uv_loop_t* loop, uv_poll_t* handle) { ...@@ -633,7 +633,7 @@ int uv_poll_close(uv_loop_t* loop, uv_poll_t* handle) {
void uv_poll_endgame(uv_loop_t* loop, uv_poll_t* handle) { void uv_poll_endgame(uv_loop_t* loop, uv_poll_t* handle) {
assert(handle->flags & UV__HANDLE_CLOSING); assert(handle->flags & UV_HANDLE_CLOSING);
assert(!(handle->flags & UV_HANDLE_CLOSED)); assert(!(handle->flags & UV_HANDLE_CLOSED));
assert(handle->submitted_events_1 == 0); assert(handle->submitted_events_1 == 0);
......
...@@ -103,6 +103,7 @@ static int uv__create_stdio_pipe_pair(uv_loop_t* loop, ...@@ -103,6 +103,7 @@ static int uv__create_stdio_pipe_pair(uv_loop_t* loop,
DWORD client_access = 0; DWORD client_access = 0;
HANDLE child_pipe = INVALID_HANDLE_VALUE; HANDLE child_pipe = INVALID_HANDLE_VALUE;
int err; int err;
int overlap;
if (flags & UV_READABLE_PIPE) { if (flags & UV_READABLE_PIPE) {
/* The server needs inbound access too, otherwise CreateNamedPipe() won't /* The server needs inbound access too, otherwise CreateNamedPipe() won't
...@@ -130,7 +131,7 @@ static int uv__create_stdio_pipe_pair(uv_loop_t* loop, ...@@ -130,7 +131,7 @@ static int uv__create_stdio_pipe_pair(uv_loop_t* loop,
sa.lpSecurityDescriptor = NULL; sa.lpSecurityDescriptor = NULL;
sa.bInheritHandle = TRUE; sa.bInheritHandle = TRUE;
BOOL overlap = server_pipe->ipc || (flags & UV_OVERLAPPED_PIPE); overlap = server_pipe->ipc || (flags & UV_OVERLAPPED_PIPE);
child_pipe = CreateFileA(pipe_name, child_pipe = CreateFileA(pipe_name,
client_access, client_access,
0, 0,
......
...@@ -872,7 +872,7 @@ void uv_process_proc_exit(uv_loop_t* loop, uv_process_t* handle) { ...@@ -872,7 +872,7 @@ void uv_process_proc_exit(uv_loop_t* loop, uv_process_t* handle) {
/* If we're closing, don't call the exit callback. Just schedule a close /* If we're closing, don't call the exit callback. Just schedule a close
* callback now. */ * callback now. */
if (handle->flags & UV__HANDLE_CLOSING) { if (handle->flags & UV_HANDLE_CLOSING) {
uv_want_endgame(loop, (uv_handle_t*) handle); uv_want_endgame(loop, (uv_handle_t*) handle);
return; return;
} }
...@@ -924,7 +924,7 @@ void uv_process_close(uv_loop_t* loop, uv_process_t* handle) { ...@@ -924,7 +924,7 @@ void uv_process_close(uv_loop_t* loop, uv_process_t* handle) {
void uv_process_endgame(uv_loop_t* loop, uv_process_t* handle) { void uv_process_endgame(uv_loop_t* loop, uv_process_t* handle) {
assert(!handle->exit_cb_pending); assert(!handle->exit_cb_pending);
assert(handle->flags & UV__HANDLE_CLOSING); assert(handle->flags & UV_HANDLE_CLOSING);
assert(!(handle->flags & UV_HANDLE_CLOSED)); assert(!(handle->flags & UV_HANDLE_CLOSED));
/* Clean-up the process handle. */ /* Clean-up the process handle. */
......
...@@ -90,7 +90,7 @@ int uv__signal_dispatch(int signum) { ...@@ -90,7 +90,7 @@ int uv__signal_dispatch(int signum) {
unsigned long previous = InterlockedExchange( unsigned long previous = InterlockedExchange(
(volatile LONG*) &handle->pending_signum, signum); (volatile LONG*) &handle->pending_signum, signum);
if (handle->flags & UV__SIGNAL_ONE_SHOT_DISPATCHED) if (handle->flags & UV_SIGNAL_ONE_SHOT_DISPATCHED)
continue; continue;
if (!previous) { if (!previous) {
...@@ -98,8 +98,8 @@ int uv__signal_dispatch(int signum) { ...@@ -98,8 +98,8 @@ int uv__signal_dispatch(int signum) {
} }
dispatched = 1; dispatched = 1;
if (handle->flags & UV__SIGNAL_ONE_SHOT) if (handle->flags & UV_SIGNAL_ONE_SHOT)
handle->flags |= UV__SIGNAL_ONE_SHOT_DISPATCHED; handle->flags |= UV_SIGNAL_ONE_SHOT_DISPATCHED;
} }
LeaveCriticalSection(&uv__signal_lock); LeaveCriticalSection(&uv__signal_lock);
...@@ -213,7 +213,7 @@ int uv__signal_start(uv_signal_t* handle, ...@@ -213,7 +213,7 @@ int uv__signal_start(uv_signal_t* handle,
handle->signum = signum; handle->signum = signum;
if (oneshot) if (oneshot)
handle->flags |= UV__SIGNAL_ONE_SHOT; handle->flags |= UV_SIGNAL_ONE_SHOT;
RB_INSERT(uv_signal_tree_s, &uv__signal_tree, handle); RB_INSERT(uv_signal_tree_s, &uv__signal_tree, handle);
...@@ -243,10 +243,10 @@ void uv_process_signal_req(uv_loop_t* loop, uv_signal_t* handle, ...@@ -243,10 +243,10 @@ void uv_process_signal_req(uv_loop_t* loop, uv_signal_t* handle,
if (dispatched_signum == handle->signum) if (dispatched_signum == handle->signum)
handle->signal_cb(handle, dispatched_signum); handle->signal_cb(handle, dispatched_signum);
if (handle->flags & UV__SIGNAL_ONE_SHOT) if (handle->flags & UV_SIGNAL_ONE_SHOT)
uv_signal_stop(handle); uv_signal_stop(handle);
if (handle->flags & UV__HANDLE_CLOSING) { if (handle->flags & UV_HANDLE_CLOSING) {
/* When it is closing, it must be stopped at this point. */ /* When it is closing, it must be stopped at this point. */
assert(handle->signum == 0); assert(handle->signum == 0);
uv_want_endgame(loop, (uv_handle_t*) handle); uv_want_endgame(loop, (uv_handle_t*) handle);
...@@ -265,7 +265,7 @@ void uv_signal_close(uv_loop_t* loop, uv_signal_t* handle) { ...@@ -265,7 +265,7 @@ void uv_signal_close(uv_loop_t* loop, uv_signal_t* handle) {
void uv_signal_endgame(uv_loop_t* loop, uv_signal_t* handle) { void uv_signal_endgame(uv_loop_t* loop, uv_signal_t* handle) {
assert(handle->flags & UV__HANDLE_CLOSING); assert(handle->flags & UV_HANDLE_CLOSING);
assert(!(handle->flags & UV_HANDLE_CLOSED)); assert(!(handle->flags & UV_HANDLE_CLOSED));
assert(handle->signum == 0); assert(handle->signum == 0);
......
...@@ -176,7 +176,7 @@ int uv_write2(uv_write_t* req, ...@@ -176,7 +176,7 @@ int uv_write2(uv_write_t* req,
int uv_try_write(uv_stream_t* stream, int uv_try_write(uv_stream_t* stream,
const uv_buf_t bufs[], const uv_buf_t bufs[],
unsigned int nbufs) { unsigned int nbufs) {
if (stream->flags & UV__HANDLE_CLOSING) if (stream->flags & UV_HANDLE_CLOSING)
return UV_EBADF; return UV_EBADF;
if (!(stream->flags & UV_HANDLE_WRITABLE)) if (!(stream->flags & UV_HANDLE_WRITABLE))
return UV_EPIPE; return UV_EPIPE;
......
...@@ -217,7 +217,7 @@ void uv_tcp_endgame(uv_loop_t* loop, uv_tcp_t* handle) { ...@@ -217,7 +217,7 @@ void uv_tcp_endgame(uv_loop_t* loop, uv_tcp_t* handle) {
UNREGISTER_HANDLE_REQ(loop, handle, handle->stream.conn.shutdown_req); UNREGISTER_HANDLE_REQ(loop, handle, handle->stream.conn.shutdown_req);
err = 0; err = 0;
if (handle->flags & UV__HANDLE_CLOSING) { if (handle->flags & UV_HANDLE_CLOSING) {
err = ERROR_OPERATION_ABORTED; err = ERROR_OPERATION_ABORTED;
} else if (shutdown(handle->socket, SD_SEND) == SOCKET_ERROR) { } else if (shutdown(handle->socket, SD_SEND) == SOCKET_ERROR) {
err = WSAGetLastError(); err = WSAGetLastError();
...@@ -233,7 +233,7 @@ void uv_tcp_endgame(uv_loop_t* loop, uv_tcp_t* handle) { ...@@ -233,7 +233,7 @@ void uv_tcp_endgame(uv_loop_t* loop, uv_tcp_t* handle) {
return; return;
} }
if (handle->flags & UV__HANDLE_CLOSING && if (handle->flags & UV_HANDLE_CLOSING &&
handle->reqs_pending == 0) { handle->reqs_pending == 0) {
assert(!(handle->flags & UV_HANDLE_CLOSED)); assert(!(handle->flags & UV_HANDLE_CLOSED));
...@@ -680,7 +680,7 @@ int uv_tcp_accept(uv_tcp_t* server, uv_tcp_t* client) { ...@@ -680,7 +680,7 @@ int uv_tcp_accept(uv_tcp_t* server, uv_tcp_t* client) {
req->next_pending = NULL; req->next_pending = NULL;
req->accept_socket = INVALID_SOCKET; req->accept_socket = INVALID_SOCKET;
if (!(server->flags & UV__HANDLE_CLOSING)) { if (!(server->flags & UV_HANDLE_CLOSING)) {
/* Check if we're in a middle of changing the number of pending accepts. */ /* Check if we're in a middle of changing the number of pending accepts. */
if (!(server->flags & UV_HANDLE_TCP_ACCEPT_STATE_CHANGING)) { if (!(server->flags & UV_HANDLE_TCP_ACCEPT_STATE_CHANGING)) {
uv_tcp_queue_accept(server, req); uv_tcp_queue_accept(server, req);
...@@ -1166,7 +1166,7 @@ void uv_process_tcp_connect_req(uv_loop_t* loop, uv_tcp_t* handle, ...@@ -1166,7 +1166,7 @@ void uv_process_tcp_connect_req(uv_loop_t* loop, uv_tcp_t* handle,
err = 0; err = 0;
if (REQ_SUCCESS(req)) { if (REQ_SUCCESS(req)) {
if (handle->flags & UV__HANDLE_CLOSING) { if (handle->flags & UV_HANDLE_CLOSING) {
/* use UV_ECANCELED for consistency with Unix */ /* use UV_ECANCELED for consistency with Unix */
err = ERROR_OPERATION_ABORTED; err = ERROR_OPERATION_ABORTED;
} else if (setsockopt(handle->socket, } else if (setsockopt(handle->socket,
......
...@@ -26,15 +26,6 @@ ...@@ -26,15 +26,6 @@
#include "uv.h" #include "uv.h"
#include "internal.h" #include "internal.h"
static int uv_cond_condvar_init(uv_cond_t* cond);
static void uv_cond_condvar_destroy(uv_cond_t* cond);
static void uv_cond_condvar_signal(uv_cond_t* cond);
static void uv_cond_condvar_broadcast(uv_cond_t* cond);
static void uv_cond_condvar_wait(uv_cond_t* cond, uv_mutex_t* mutex);
static int uv_cond_condvar_timedwait(uv_cond_t* cond,
uv_mutex_t* mutex, uint64_t timeout);
static void uv__once_inner(uv_once_t* guard, void (*callback)(void)) { static void uv__once_inner(uv_once_t* guard, void (*callback)(void)) {
DWORD result; DWORD result;
HANDLE existing_event, created_event; HANDLE existing_event, created_event;
...@@ -374,7 +365,7 @@ int uv_cond_init(uv_cond_t* cond) { ...@@ -374,7 +365,7 @@ int uv_cond_init(uv_cond_t* cond) {
void uv_cond_destroy(uv_cond_t* cond) { void uv_cond_destroy(uv_cond_t* cond) {
/* nothing to do */ /* nothing to do */
UV__UNUSED(cond); (void) &cond;
} }
......
/* Copyright Joyent, Inc. and other Node contributors. All rights reserved.
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to
* deal in the Software without restriction, including without limitation the
* rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
* IN THE SOFTWARE.
*/
#include <assert.h>
#include <limits.h>
#include "uv.h"
#include "internal.h"
#include "uv/tree.h"
#include "handle-inl.h"
/* The number of milliseconds in one second. */
#define UV__MILLISEC 1000
void uv_update_time(uv_loop_t* loop) {
uint64_t new_time = uv__hrtime(UV__MILLISEC);
assert(new_time >= loop->time);
loop->time = new_time;
}
static int uv_timer_compare(uv_timer_t* a, uv_timer_t* b) {
if (a->due < b->due)
return -1;
if (a->due > b->due)
return 1;
/*
* compare start_id when both has the same due. start_id is
* allocated with loop->timer_counter in uv_timer_start().
*/
if (a->start_id < b->start_id)
return -1;
if (a->start_id > b->start_id)
return 1;
return 0;
}
RB_GENERATE_STATIC(uv_timer_tree_s, uv_timer_s, tree_entry, uv_timer_compare)
int uv_timer_init(uv_loop_t* loop, uv_timer_t* handle) {
uv__handle_init(loop, (uv_handle_t*) handle, UV_TIMER);
handle->timer_cb = NULL;
handle->repeat = 0;
return 0;
}
void uv_timer_endgame(uv_loop_t* loop, uv_timer_t* handle) {
if (handle->flags & UV__HANDLE_CLOSING) {
assert(!(handle->flags & UV_HANDLE_CLOSED));
uv__handle_close(handle);
}
}
static uint64_t get_clamped_due_time(uint64_t loop_time, uint64_t timeout) {
uint64_t clamped_timeout;
clamped_timeout = loop_time + timeout;
if (clamped_timeout < timeout)
clamped_timeout = (uint64_t) -1;
return clamped_timeout;
}
int uv_timer_start(uv_timer_t* handle, uv_timer_cb timer_cb, uint64_t timeout,
uint64_t repeat) {
uv_loop_t* loop = handle->loop;
uv_timer_t* old;
if (timer_cb == NULL)
return UV_EINVAL;
if (uv__is_active(handle))
uv_timer_stop(handle);
handle->timer_cb = timer_cb;
handle->due = get_clamped_due_time(loop->time, timeout);
handle->repeat = repeat;
uv__handle_start(handle);
/* start_id is the second index to be compared in uv__timer_cmp() */
handle->start_id = handle->loop->timer_counter++;
old = RB_INSERT(uv_timer_tree_s, &loop->timers, handle);
assert(old == NULL);
return 0;
}
int uv_timer_stop(uv_timer_t* handle) {
uv_loop_t* loop = handle->loop;
if (!uv__is_active(handle))
return 0;
RB_REMOVE(uv_timer_tree_s, &loop->timers, handle);
uv__handle_stop(handle);
return 0;
}
int uv_timer_again(uv_timer_t* handle) {
/* If timer_cb is NULL that means that the timer was never started. */
if (!handle->timer_cb) {
return UV_EINVAL;
}
if (handle->repeat) {
uv_timer_stop(handle);
uv_timer_start(handle, handle->timer_cb, handle->repeat, handle->repeat);
}
return 0;
}
void uv_timer_set_repeat(uv_timer_t* handle, uint64_t repeat) {
assert(handle->type == UV_TIMER);
handle->repeat = repeat;
}
uint64_t uv_timer_get_repeat(const uv_timer_t* handle) {
assert(handle->type == UV_TIMER);
return handle->repeat;
}
DWORD uv__next_timeout(const uv_loop_t* loop) {
uv_timer_t* timer;
int64_t delta;
/* Check if there are any running timers
* Need to cast away const first, since RB_MIN doesn't know what we are
* going to do with this return value, it can't be marked const
*/
timer = RB_MIN(uv_timer_tree_s, &((uv_loop_t*)loop)->timers);
if (timer) {
delta = timer->due - loop->time;
if (delta >= UINT_MAX - 1) {
/* A timeout value of UINT_MAX means infinite, so that's no good. */
return UINT_MAX - 1;
} else if (delta < 0) {
/* Negative timeout values are not allowed */
return 0;
} else {
return (DWORD)delta;
}
} else {
/* No timers */
return INFINITE;
}
}
void uv_process_timers(uv_loop_t* loop) {
uv_timer_t* timer;
/* Call timer callbacks */
for (timer = RB_MIN(uv_timer_tree_s, &loop->timers);
timer != NULL && timer->due <= loop->time;
timer = RB_MIN(uv_timer_tree_s, &loop->timers)) {
uv_timer_stop(timer);
uv_timer_again(timer);
timer->timer_cb((uv_timer_t*) timer);
}
}
...@@ -2208,7 +2208,7 @@ void uv_tty_endgame(uv_loop_t* loop, uv_tty_t* handle) { ...@@ -2208,7 +2208,7 @@ void uv_tty_endgame(uv_loop_t* loop, uv_tty_t* handle) {
/* TTY shutdown is really just a no-op */ /* TTY shutdown is really just a no-op */
if (handle->stream.conn.shutdown_req->cb) { if (handle->stream.conn.shutdown_req->cb) {
if (handle->flags & UV__HANDLE_CLOSING) { if (handle->flags & UV_HANDLE_CLOSING) {
handle->stream.conn.shutdown_req->cb(handle->stream.conn.shutdown_req, UV_ECANCELED); handle->stream.conn.shutdown_req->cb(handle->stream.conn.shutdown_req, UV_ECANCELED);
} else { } else {
handle->stream.conn.shutdown_req->cb(handle->stream.conn.shutdown_req, 0); handle->stream.conn.shutdown_req->cb(handle->stream.conn.shutdown_req, 0);
...@@ -2221,7 +2221,7 @@ void uv_tty_endgame(uv_loop_t* loop, uv_tty_t* handle) { ...@@ -2221,7 +2221,7 @@ void uv_tty_endgame(uv_loop_t* loop, uv_tty_t* handle) {
return; return;
} }
if (handle->flags & UV__HANDLE_CLOSING && if (handle->flags & UV_HANDLE_CLOSING &&
handle->reqs_pending == 0) { handle->reqs_pending == 0) {
/* The wait handle used for raw reading should be unregistered when the /* The wait handle used for raw reading should be unregistered when the
* wait callback runs. */ * wait callback runs. */
......
...@@ -188,7 +188,7 @@ void uv_udp_close(uv_loop_t* loop, uv_udp_t* handle) { ...@@ -188,7 +188,7 @@ void uv_udp_close(uv_loop_t* loop, uv_udp_t* handle) {
void uv_udp_endgame(uv_loop_t* loop, uv_udp_t* handle) { void uv_udp_endgame(uv_loop_t* loop, uv_udp_t* handle) {
if (handle->flags & UV__HANDLE_CLOSING && if (handle->flags & UV_HANDLE_CLOSING &&
handle->reqs_pending == 0) { handle->reqs_pending == 0) {
assert(!(handle->flags & UV_HANDLE_CLOSED)); assert(!(handle->flags & UV_HANDLE_CLOSED));
uv__handle_close(handle); uv__handle_close(handle);
......
...@@ -73,6 +73,7 @@ ...@@ -73,6 +73,7 @@
'src/inet.c', 'src/inet.c',
'src/queue.h', 'src/queue.h',
'src/threadpool.c', 'src/threadpool.c',
'src/timer.c',
'src/uv-data-getter-setters.c', 'src/uv-data-getter-setters.c',
'src/uv-common.c', 'src/uv-common.c',
'src/uv-common.h', 'src/uv-common.h',
...@@ -123,7 +124,6 @@ ...@@ -123,7 +124,6 @@
'src/win/stream-inl.h', 'src/win/stream-inl.h',
'src/win/tcp.c', 'src/win/tcp.c',
'src/win/tty.c', 'src/win/tty.c',
'src/win/timer.c',
'src/win/udp.c', 'src/win/udp.c',
'src/win/util.c', 'src/win/util.c',
'src/win/winapi.c', 'src/win/winapi.c',
...@@ -168,7 +168,6 @@ ...@@ -168,7 +168,6 @@
'src/unix/stream.c', 'src/unix/stream.c',
'src/unix/tcp.c', 'src/unix/tcp.c',
'src/unix/thread.c', 'src/unix/thread.c',
'src/unix/timer.c',
'src/unix/tty.c', 'src/unix/tty.c',
'src/unix/udp.c', 'src/unix/udp.c',
], ],
......
...@@ -81,6 +81,7 @@ LIBUV_SOURCES = [ ...@@ -81,6 +81,7 @@ LIBUV_SOURCES = [
_libuv_source('uv-common.c'), _libuv_source('uv-common.c'),
_libuv_source('version.c'), _libuv_source('version.c'),
_libuv_source('uv-data-getter-setters.c'), _libuv_source('uv-data-getter-setters.c'),
_libuv_source('timer.c'),
] ]
if WIN: if WIN:
...@@ -116,7 +117,6 @@ if WIN: ...@@ -116,7 +117,6 @@ if WIN:
_libuv_source('win/stream.c'), _libuv_source('win/stream.c'),
_libuv_source('win/tcp.c'), _libuv_source('win/tcp.c'),
_libuv_source('win/thread.c'), _libuv_source('win/thread.c'),
_libuv_source('win/timer.c'),
_libuv_source('win/tty.c'), _libuv_source('win/tty.c'),
_libuv_source('win/udp.c'), _libuv_source('win/udp.c'),
_libuv_source('win/util.c'), _libuv_source('win/util.c'),
...@@ -140,7 +140,6 @@ else: ...@@ -140,7 +140,6 @@ else:
_libuv_source('unix/stream.c'), _libuv_source('unix/stream.c'),
_libuv_source('unix/tcp.c'), _libuv_source('unix/tcp.c'),
_libuv_source('unix/thread.c'), _libuv_source('unix/thread.c'),
_libuv_source('unix/timer.c'),
_libuv_source('unix/tty.c'), _libuv_source('unix/tty.c'),
_libuv_source('unix/udp.c'), _libuv_source('unix/udp.c'),
] ]
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment