# HG changeset patch # User Igor Sysoev # Date 1075826634 0 # Node ID 2a054028729875c48f3db8e354d79c1510a126fe # Parent e885208c518b8a76c356a48382916da2254dfdb0 nginx-0.0.2-2004-02-03-19:43:54 import diff -r e885208c518b -r 2a0540287298 auto/lib/make --- a/auto/lib/make Mon Feb 02 21:19:52 2004 +0000 +++ b/auto/lib/make Tue Feb 03 16:43:54 2004 +0000 @@ -12,7 +12,18 @@ if [ $MD5 != NO ]; then echo "$MD5/libmd5.a:" >> $MAKEFILE - echo " cd $MD5 && \$(MAKE) x86-elf" >> $MAKEFILE + + case $PLATFORM in + + SunOS:*) + echo " cd $MD5 && \$(MAKE) x86-solaris" >> $MAKEFILE + ;; + + *) + echo " cd $MD5 && \$(MAKE) x86-elf" >> $MAKEFILE + ;; + esac + echo >> $MAKEFILE fi diff -r e885208c518b -r 2a0540287298 auto/os/linux --- a/auto/os/linux Mon Feb 02 21:19:52 2004 +0000 +++ b/auto/os/linux Tue Feb 03 16:43:54 2004 +0000 @@ -1,8 +1,8 @@ CORE_INCS="$UNIX_INCS" CORE_DEPS="$UNIX_DEPS $LINUX_DEPS" -CORE_SRCS="$UNIX_SRCS $LINUX_SRCS $SELECT_SRCS $POLL_SRCS" -EVENT_MODULES="$EVENT_MODULES $SELECT_MODULE $POLL_MODULE" +CORE_SRCS="$UNIX_SRCS $LINUX_SRCS" +EVENT_MODULES="$EVENT_MODULES" ZLIB_LIB="-lz" diff -r e885208c518b -r 2a0540287298 auto/os/solaris --- a/auto/os/solaris Mon Feb 02 21:19:52 2004 +0000 +++ b/auto/os/solaris Tue Feb 03 16:43:54 2004 +0000 @@ -1,8 +1,8 @@ CORE_INCS="$UNIX_INCS" CORE_DEPS="$UNIX_DEPS $SOLARIS_DEPS" -CORE_SRCS="$UNIX_SRCS $SOLARIS_SRCS $SELECT_SRCS $POLL_SRCS" -EVENT_MODULES="$EVENT_MODULES $SELECT_MODULE $POLL_MODULE" +CORE_SRCS="$UNIX_SRCS $SOLARIS_SRCS " +EVENT_MODULES="$EVENT_MODULES" MD5_LIB="-lmd5" ZLIB_LIB="-lz" diff -r e885208c518b -r 2a0540287298 src/core/nginx.c --- a/src/core/nginx.c Mon Feb 02 21:19:52 2004 +0000 +++ b/src/core/nginx.c Tue Feb 03 16:43:54 2004 +0000 @@ -82,6 +82,7 @@ ngx_uint_t ngx_connection_counter; ngx_int_t ngx_process; +ngx_pid_t ngx_pid; ngx_pid_t ngx_new_binary; ngx_int_t ngx_inherited; @@ -122,6 +123,7 @@ #endif log = ngx_log_init_errlog(); + ngx_pid = ngx_getpid(); /* init_cycle->log is required for signal handlers */ @@ -179,12 +181,6 @@ } } - if (dup2(cycle->log->file->fd, STDERR_FILENO) == -1) { - ngx_log_error(NGX_LOG_EMERG, cycle->log, ngx_errno, - "dup2(STDERR) failed"); - return 1; - } - if (ccf->pid.len == 0) { ccf->pid.len = sizeof(NGINX_PID) - 1; ccf->pid.data = NGINX_PID; diff -r e885208c518b -r 2a0540287298 src/core/ngx_config.h --- a/src/core/ngx_config.h Mon Feb 02 21:19:52 2004 +0000 +++ b/src/core/ngx_config.h Tue Feb 03 16:43:54 2004 +0000 @@ -2,9 +2,6 @@ #define _NGX_CONFIG_H_INCLUDED_ -#include - - #if 1 /* STUB to allocate a big ngx_connections */ #undef FD_SETSIZE @@ -36,6 +33,8 @@ #else /* posix */ +#include + #endif diff -r e885208c518b -r 2a0540287298 src/core/ngx_cycle.c --- a/src/core/ngx_cycle.c Mon Feb 02 21:19:52 2004 +0000 +++ b/src/core/ngx_cycle.c Tue Feb 03 16:43:54 2004 +0000 @@ -228,6 +228,14 @@ } } + /* TODO: Win32 DuplicateHandle ? */ + if (dup2(cycle->log->file->fd, STDERR_FILENO) == -1) { + ngx_log_error(NGX_LOG_EMERG, log, ngx_errno, + "dup2(STDERR) failed"); + failed = 1; + } + + if (failed) { /* rollback the new cycle configuration */ @@ -262,6 +270,7 @@ return NULL; } + /* commit the new cycle configuration */ pool->log = cycle->log; @@ -438,6 +447,12 @@ file[i].fd = fd; } + + /* TODO: Win32 DuplicateHandle ? */ + if (dup2(cycle->log->file->fd, STDERR_FILENO) == -1) { + ngx_log_error(NGX_LOG_EMERG, cycle->log, ngx_errno, + "dup2(STDERR) failed"); + } } diff -r e885208c518b -r 2a0540287298 src/core/ngx_log.c --- a/src/core/ngx_log.c Mon Feb 02 21:19:52 2004 +0000 +++ b/src/core/ngx_log.c Tue Feb 03 16:43:54 2004 +0000 @@ -79,7 +79,7 @@ /* pid#tid */ len += ngx_snprintf(errstr + len, max - len, - PID_T_FMT "#%d: ", ngx_getpid(), /* STUB */ 0); + PID_T_FMT "#%d: ", ngx_pid, /* STUB */ 0); if (log->data) { len += ngx_snprintf(errstr + len, max - len, diff -r e885208c518b -r 2a0540287298 src/event/ngx_event.c --- a/src/event/ngx_event.c Mon Feb 02 21:19:52 2004 +0000 +++ b/src/event/ngx_event.c Tue Feb 03 16:43:54 2004 +0000 @@ -16,6 +16,7 @@ #if (HAVE_DEVPOLL) extern ngx_module_t ngx_devpoll_module; +extern ngx_event_module_t ngx_devpoll_module_ctx; #endif #if (HAVE_AIO) @@ -386,6 +387,7 @@ old_ecf = NULL; } + for (m = 0; ngx_modules[m]; m++) { if (ngx_modules[m]->type != NGX_EVENT_MODULE) { continue; @@ -397,14 +399,19 @@ ecf->use = ngx_modules[m]->ctx_index; ecf->name = module->name->data; - if (old_ecf && old_ecf->use != ecf->use) { + if (ngx_process == NGX_PROCESS_SINGLE + && old_ecf + && old_ecf->use != ecf->use) + { ngx_conf_log_error(NGX_LOG_EMERG, cf, 0, + "when the server runs without a master process " "the \"%s\" event type must be the same as " "in previous configuration - \"%s\" " "and it can not be changed on the fly, " "to change it you need to stop server " "and start it again", value[1].data, old_ecf->name); + return NGX_CONF_ERROR; } diff -r e885208c518b -r 2a0540287298 src/os/unix/ngx_daemon.c --- a/src/os/unix/ngx_daemon.c Mon Feb 02 21:19:52 2004 +0000 +++ b/src/os/unix/ngx_daemon.c Tue Feb 03 16:43:54 2004 +0000 @@ -19,6 +19,8 @@ exit(0); } + ngx_pid = ngx_getpid(); + if (setsid() == -1) { ngx_log_error(NGX_LOG_EMERG, log, ngx_errno, "setsid() failed"); return NGX_ERROR; diff -r e885208c518b -r 2a0540287298 src/os/unix/ngx_freebsd_config.h --- a/src/os/unix/ngx_freebsd_config.h Mon Feb 02 21:19:52 2004 +0000 +++ b/src/os/unix/ngx_freebsd_config.h Tue Feb 03 16:43:54 2004 +0000 @@ -28,6 +28,8 @@ #include #include +#include + #ifndef HAVE_SELECT #define HAVE_SELECT 1 diff -r e885208c518b -r 2a0540287298 src/os/unix/ngx_linux_config.h --- a/src/os/unix/ngx_linux_config.h Mon Feb 02 21:19:52 2004 +0000 +++ b/src/os/unix/ngx_linux_config.h Tue Feb 03 16:43:54 2004 +0000 @@ -26,13 +26,6 @@ #include #include #include - -#if (HAVE_SENDFILE64) -#include -#else -extern ssize_t sendfile(int s, int fd, int32_t *offset, size_t size); -#endif - #include #include /* TCP_CORK */ #include @@ -41,6 +34,14 @@ #include #include +#include + +#if (HAVE_SENDFILE64) +#include +#else +extern ssize_t sendfile(int s, int fd, int32_t *offset, size_t size); +#endif + #ifndef HAVE_SELECT diff -r e885208c518b -r 2a0540287298 src/os/unix/ngx_process.c --- a/src/os/unix/ngx_process.c Mon Feb 02 21:19:52 2004 +0000 +++ b/src/os/unix/ngx_process.c Tue Feb 03 16:43:54 2004 +0000 @@ -46,6 +46,7 @@ return NGX_ERROR; case 0: + ngx_pid = ngx_getpid(); proc(cycle, data); break; diff -r e885208c518b -r 2a0540287298 src/os/unix/ngx_process.h --- a/src/os/unix/ngx_process.h Mon Feb 02 21:19:52 2004 +0000 +++ b/src/os/unix/ngx_process.h Tue Feb 03 16:43:54 2004 +0000 @@ -49,6 +49,7 @@ void ngx_respawn_processes(ngx_cycle_t *cycle); void ngx_process_get_status(void); +extern ngx_pid_t ngx_pid; extern ngx_uint_t ngx_last_process; extern ngx_process_t ngx_processes[NGX_MAX_PROCESSES]; diff -r e885208c518b -r 2a0540287298 src/os/unix/ngx_solaris_config.h --- a/src/os/unix/ngx_solaris_config.h Mon Feb 02 21:19:52 2004 +0000 +++ b/src/os/unix/ngx_solaris_config.h Tue Feb 03 16:43:54 2004 +0000 @@ -32,6 +32,8 @@ #include #include +#include + #ifndef HAVE_SELECT #define HAVE_SELECT 1