diff options
author | Igor Sysoev <igor@sysoev.ru> | 2004-11-11 14:07:14 +0000 |
---|---|---|
committer | Igor Sysoev <igor@sysoev.ru> | 2004-11-11 14:07:14 +0000 |
commit | 1b73583ba2c0e4b72d951218827e0c621427d389 (patch) | |
tree | 9e4d204e2cce91560d5cb8908b8a1a9f2c1d92ee /src/os/win32/ngx_thread.c | |
parent | d6f24959428caed68a509a19ca4fd866d978a69c (diff) | |
download | nginx-1b73583ba2c0e4b72d951218827e0c621427d389.tar.gz nginx-1b73583ba2c0e4b72d951218827e0c621427d389.zip |
nginx-0.1.5-RELEASE importrelease-0.1.5
*) Bugfix: on Solaris and Linux there may be too many "recvmsg()
returned not enough data" alerts.
*) Bugfix: there were the "writev() failed (22: Invalid argument)"
errors on Solaris in proxy mode without sendfile. On other platforms
that do not support sendfile at all the process got caught in an
endless loop.
*) Bugfix: segmentation fault on Solaris in proxy mode and using
sendfile.
*) Bugfix: segmentation fault on Solaris.
*) Bugfix: on-line upgrade did not work on Linux.
*) Bugfix: the ngx_http_autoindex_module module did not escape the
spaces, the quotes, and the percent signs in the directory listing.
*) Change: the decrease of the copy operations.
*) Feature: the userid_p3p directive.
Diffstat (limited to 'src/os/win32/ngx_thread.c')
-rw-r--r-- | src/os/win32/ngx_thread.c | 68 |
1 files changed, 68 insertions, 0 deletions
diff --git a/src/os/win32/ngx_thread.c b/src/os/win32/ngx_thread.c new file mode 100644 index 000000000..8fae0e379 --- /dev/null +++ b/src/os/win32/ngx_thread.c @@ -0,0 +1,68 @@ + +/* + * Copyright (C) Igor Sysoev + */ + + +#include <ngx_config.h> +#include <ngx_core.h> + + +ngx_int_t ngx_threads_n; + + +static size_t stack_size; + + +ngx_err_t ngx_create_thread(ngx_tid_t *tid, void* (*func)(void *arg), void *arg, + ngx_log_t *log) +{ + ngx_err_t err; + + *tid = CreateThread(NULL, stack_size, + (LPTHREAD_START_ROUTINE) func, arg, 0, NULL); + + if (*tid != NULL) { + return 0; + } + + err = ngx_errno; + ngx_log_error(NGX_LOG_ALERT, log, err, "CreateThread() failed"); + return err; +} + + +ngx_int_t ngx_init_threads(int n, size_t size, ngx_cycle_t *cycle) +{ + stack_size = size; + + return NGX_OK; +} + + +ngx_err_t ngx_thread_key_create(ngx_tls_key_t *key) +{ + *key = TlsAlloc(); + + if (*key == TLS_OUT_OF_INDEXES) { + return ngx_errno; + } + + return 0; +} + + +ngx_err_t ngx_thread_set_tls(ngx_tls_key_t *key, void *data) +{ + if (TlsSetValue(*key, data) == 0) { + return ngx_errno; + } + + return 0; +} + + +ngx_mutex_t *ngx_mutex_init(ngx_log_t *log, ngx_uint_t flags) +{ + return (ngx_mutex_t *) 1; +} |