comparison src/event/modules/ngx_kqueue_module.c @ 168:3314be145cb9 NGINX_0_3_31

nginx 0.3.31 *) Change: now nginx passes the malformed proxied backend responses. *) Feature: the "listen" directives support the address in the "*:port" form. *) Feature: the EVFILER_TIMER support in MacOSX 10.4. *) Workaround: for MacOSX 64-bit kernel kqueue millisecond timeout bug. Thanks to Andrei Nigmatulin. *) Bugfix: if there were several "listen" directives listening one various addresses inside one server, then server names like "*.domain.tld" worked for first address only; bug appeared in 0.3.18. *) Bugfix: if the HTTPS protocol was used in the "proxy_pass" directive and the request body was in temporarily file then the request was not transferred. *) Bugfix: perl 5.8.8 compatibility.
author Igor Sysoev <http://sysoev.ru>
date Fri, 10 Mar 2006 00:00:00 +0300
parents 91372f004adf
children 1b490fc19afa
comparison
equal deleted inserted replaced
167:544cb5cba207 168:3314be145cb9
488 488
489 if (timer == NGX_TIMER_INFINITE) { 489 if (timer == NGX_TIMER_INFINITE) {
490 tp = NULL; 490 tp = NULL;
491 491
492 } else { 492 } else {
493
494 /*
495 * 64-bit MacOSX kernel has the bug: kernel level ts.tv_nsec is
496 * the int32_t while user level ts.tv_nsec is the long (64-bit),
497 * so on the big endian PowerPC all nanoseconds are lost.
498 * NGX_MACOSX_KEVENT_BUG_SHIFT on these machines is "<< 32".
499 */
500
493 ts.tv_sec = timer / 1000; 501 ts.tv_sec = timer / 1000;
494 ts.tv_nsec = (timer % 1000) * 1000000; 502 ts.tv_nsec = (long) ((timer % 1000) * 1000000)
503 NGX_MACOSX_KEVENT_BUG_SHIFT;
495 tp = &ts; 504 tp = &ts;
496 } 505 }
497 506
498 ngx_log_debug2(NGX_LOG_DEBUG_EVENT, cycle->log, 0, 507 ngx_log_debug2(NGX_LOG_DEBUG_EVENT, cycle->log, 0,
499 "kevent timer: %M, changes: %d", timer, n); 508 "kevent timer: %M, changes: %d", timer, n);