annotate src/os/unix/ngx_udp_recv.c @ 694:88a1b4797f2e NGINX_1_3_10

nginx 1.3.10 *) Change: domain names specified in configuration file are now resolved to IPv6 addresses as well as IPv4 ones. *) Change: now if the "include" directive with mask is used on Unix systems, included files are sorted in alphabetical order. *) Change: the "add_header" directive adds headers to 201 responses. *) Feature: the "geo" directive now supports IPv6 addresses in CIDR notation. *) Feature: the "flush" and "gzip" parameters of the "access_log" directive. *) Feature: variables support in the "auth_basic" directive. *) Bugfix: nginx could not be built with the ngx_http_perl_module in some cases. *) Bugfix: a segmentation fault might occur in a worker process if the ngx_http_xslt_module was used. *) Bugfix: nginx could not be built on MacOSX in some cases. Thanks to Piotr Sikora. *) Bugfix: the "limit_rate" directive with high rates might result in truncated responses on 32-bit platforms. Thanks to Alexey Antropov. *) Bugfix: a segmentation fault might occur in a worker process if the "if" directive was used. Thanks to Piotr Sikora. *) Bugfix: a "100 Continue" response was issued with "413 Request Entity Too Large" responses. *) Bugfix: the "image_filter", "image_filter_jpeg_quality" and "image_filter_sharpen" directives might be inherited incorrectly. Thanks to Ian Babrou. *) Bugfix: "crypt_r() failed" errors might appear if the "auth_basic" directive was used on Linux. *) Bugfix: in backup servers handling. Thanks to Thomas Chen. *) Bugfix: proxied HEAD requests might return incorrect response if the "gzip" directive was used.
author Igor Sysoev <http://sysoev.ru>
date Tue, 25 Dec 2012 00:00:00 +0400
parents d0f7a625f27c
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
354
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
1
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
2 /*
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
3 * Copyright (C) Igor Sysoev
660
d0f7a625f27c nginx 1.1.14
Igor Sysoev <http://sysoev.ru>
parents: 582
diff changeset
4 * Copyright (C) Nginx, Inc.
354
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
5 */
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
6
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
7
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
8 #include <ngx_config.h>
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
9 #include <ngx_core.h>
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
10 #include <ngx_event.h>
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
11
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
12
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
13 #if (NGX_HAVE_KQUEUE)
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
14
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
15 ssize_t
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
16 ngx_udp_unix_recv(ngx_connection_t *c, u_char *buf, size_t size)
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
17 {
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
18 ssize_t n;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
19 ngx_err_t err;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
20 ngx_event_t *rev;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
21
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
22 rev = c->read;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
23
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
24 do {
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
25 n = recv(c->fd, buf, size, 0);
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
26
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
27 ngx_log_debug3(NGX_LOG_DEBUG_EVENT, c->log, 0,
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
28 "recv: fd:%d %d of %d", c->fd, n, size);
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
29
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
30 if (n >= 0) {
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
31 if (ngx_event_flags & NGX_USE_KQUEUE_EVENT) {
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
32 rev->available -= n;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
33
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
34 /*
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
35 * rev->available may be negative here because some additional
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
36 * bytes may be received between kevent() and recv()
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
37 */
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
38
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
39 if (rev->available <= 0) {
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
40 rev->ready = 0;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
41 rev->available = 0;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
42 }
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
43 }
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
44
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
45 return n;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
46 }
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
47
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
48 err = ngx_socket_errno;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
49
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
50 if (err == NGX_EAGAIN || err == NGX_EINTR) {
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
51 ngx_log_debug0(NGX_LOG_DEBUG_EVENT, c->log, err,
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
52 "recv() not ready");
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
53 n = NGX_AGAIN;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
54
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
55 } else {
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
56 n = ngx_connection_error(c, err, "recv() failed");
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
57 break;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
58 }
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
59
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
60 } while (err == NGX_EINTR);
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
61
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
62 rev->ready = 0;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
63
582
c456a023113c nginx 0.8.43
Igor Sysoev <http://sysoev.ru>
parents: 354
diff changeset
64 if (n == NGX_ERROR) {
354
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
65 rev->error = 1;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
66 }
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
67
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
68 return n;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
69 }
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
70
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
71 #else /* ! NGX_HAVE_KQUEUE */
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
72
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
73 ssize_t
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
74 ngx_udp_unix_recv(ngx_connection_t *c, u_char *buf, size_t size)
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
75 {
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
76 ssize_t n;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
77 ngx_err_t err;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
78 ngx_event_t *rev;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
79
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
80 rev = c->read;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
81
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
82 do {
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
83 n = recv(c->fd, buf, size, 0);
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
84
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
85 ngx_log_debug3(NGX_LOG_DEBUG_EVENT, c->log, 0,
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
86 "recv: fd:%d %d of %d", c->fd, n, size);
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
87
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
88 if (n >= 0) {
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
89 return n;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
90 }
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
91
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
92 err = ngx_socket_errno;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
93
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
94 if (err == NGX_EAGAIN || err == NGX_EINTR) {
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
95 ngx_log_debug0(NGX_LOG_DEBUG_EVENT, c->log, err,
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
96 "recv() not ready");
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
97 n = NGX_AGAIN;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
98
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
99 } else {
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
100 n = ngx_connection_error(c, err, "recv() failed");
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
101 break;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
102 }
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
103
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
104 } while (err == NGX_EINTR);
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
105
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
106 rev->ready = 0;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
107
582
c456a023113c nginx 0.8.43
Igor Sysoev <http://sysoev.ru>
parents: 354
diff changeset
108 if (n == NGX_ERROR) {
354
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
109 rev->error = 1;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
110 }
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
111
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
112 return n;
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
113 }
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
114
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
115 #endif /* NGX_HAVE_KQUEUE */