Mercurial > hg > nginx-quic
diff src/os/win32/ngx_thread.c @ 461:a88a3e4e158f release-0.1.5
nginx-0.1.5-RELEASE import
*) 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.
author | Igor Sysoev <igor@sysoev.ru> |
---|---|
date | Thu, 11 Nov 2004 14:07:14 +0000 |
parents | |
children | d4ea69372b94 |
line wrap: on
line diff
new file mode 100644 --- /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; +}