Mercurial > hg > nginx-vendor-0-7
annotate src/os/unix/ngx_alloc.c @ 366:babd3d9efb62 NGINX_0_6_27
nginx 0.6.27
*) Change: now by default the rtsig method is not built on
Linux 2.6.18+.
*) Change: now a request method is not changed while redirection to a
named location via an "error_page" directive.
*) Feature: the "resolver" and "resolver_timeout" directives in SMTP
proxy.
*) Feature: the "post_action" directive supports named locations.
*) Bugfix: a segmentation fault occurred in worker process, if a
request was redirected from proxy, FastCGI, or memcached location to
static named locations.
*) Bugfix: browsers did not repeat SSL handshake if there is no valid
client certificate in first handshake.
Thanks to Alexander V. Inyukhin.
*) Bugfix: if response code 495-497 was redirected via an "error_page"
directive without code change, then nginx tried to allocate too many
memory.
*) Bugfix: memory leak in long-lived non buffered connections.
*) Bugfix: memory leak in resolver.
*) Bugfix: a segmentation fault occurred in worker process, if a
request was redirected from proxy, FastCGI, or memcached location to
static named locations.
*) Bugfix: in the $proxy_host and $proxy_port variables caching.
Thanks to Sergey Bochenkov.
*) Bugfix: a "proxy_pass" directive with variables used incorrectly the
same port as in another "proxy_pass" directive with the same host
name and without variables.
Thanks to Sergey Bochenkov.
*) Bugfix: an alert "sendmsg() failed (9: Bad file descriptor)" on some
64-bit platforms while reconfiguration.
*) Bugfix: a segmentation fault occurred in worker process, if empty
stub block was used second time in SSI.
*) Bugfix: in copying URI part contained escaped symbols into arguments.
author | Igor Sysoev <http://sysoev.ru> |
---|---|
date | Wed, 12 Mar 2008 00:00:00 +0300 |
parents | 6ae1357b7b7c |
children | 706fef7f4dcc |
rev | line source |
---|---|
0 | 1 |
2 /* | |
3 * Copyright (C) Igor Sysoev | |
4 */ | |
5 | |
6 | |
7 #include <ngx_config.h> | |
8 #include <ngx_core.h> | |
9 | |
10 | |
258 | 11 ngx_uint_t ngx_pagesize; |
12 ngx_uint_t ngx_pagesize_shift; | |
138 | 13 ngx_uint_t ngx_cacheline_size; |
0 | 14 |
15 | |
50 | 16 void * |
17 ngx_alloc(size_t size, ngx_log_t *log) | |
0 | 18 { |
19 void *p; | |
20 | |
50 | 21 p = malloc(size); |
22 if (p == NULL) { | |
0 | 23 ngx_log_error(NGX_LOG_EMERG, log, ngx_errno, |
10 | 24 "malloc() %uz bytes failed", size); |
0 | 25 } |
26 | |
10 | 27 ngx_log_debug2(NGX_LOG_DEBUG_ALLOC, log, 0, "malloc: %p:%uz", p, size); |
0 | 28 |
29 return p; | |
30 } | |
31 | |
32 | |
50 | 33 void * |
34 ngx_calloc(size_t size, ngx_log_t *log) | |
0 | 35 { |
36 void *p; | |
37 | |
38 p = ngx_alloc(size, log); | |
39 | |
40 if (p) { | |
41 ngx_memzero(p, size); | |
42 } | |
43 | |
44 return p; | |
45 } | |
46 | |
47 | |
18 | 48 #if (NGX_HAVE_POSIX_MEMALIGN) |
0 | 49 |
50 | 50 void * |
51 ngx_memalign(size_t alignment, size_t size, ngx_log_t *log) | |
0 | 52 { |
53 void *p; | |
54 | |
55 if (posix_memalign(&p, alignment, size) == -1) { | |
56 ngx_log_error(NGX_LOG_EMERG, log, ngx_errno, | |
10 | 57 "posix_memalign() %uz bytes aligned to %uz failed", |
58 size, alignment); | |
0 | 59 } |
60 | |
61 ngx_log_debug2(NGX_LOG_DEBUG_ALLOC, log, 0, | |
10 | 62 "posix_memalign: %p:%uz", p, size); |
0 | 63 |
64 return p; | |
65 } | |
66 | |
18 | 67 #elif (NGX_HAVE_MEMALIGN) |
0 | 68 |
50 | 69 void * |
70 ngx_memalign(size_t alignment, size_t size, ngx_log_t *log) | |
0 | 71 { |
72 void *p; | |
73 | |
50 | 74 p = memalign(alignment, size); |
75 if (p == NULL) { | |
0 | 76 ngx_log_error(NGX_LOG_EMERG, log, ngx_errno, |
10 | 77 "memalign() %uz bytes aligned to %uz failed", |
78 size, alignment); | |
0 | 79 } |
80 | |
81 ngx_log_debug2(NGX_LOG_DEBUG_ALLOC, log, 0, | |
10 | 82 "memalign: %p:%uz", p, size); |
0 | 83 |
84 return p; | |
85 } | |
86 | |
87 #endif |