annotate src/os/unix/ngx_udp_recv.c @ 660:d0f7a625f27c NGINX_1_1_14

nginx 1.1.14 *) Feature: multiple "limit_req" limits may be used simultaneously. *) Bugfix: in error handling while connecting to a backend. Thanks to Piotr Sikora. *) Bugfix: in AIO error handling on FreeBSD. *) Bugfix: in the OpenSSL library initialization. *) Bugfix: the "proxy_redirect" directives might not be correctly inherited. *) Bugfix: memory leak during reconfiguration if the "pcre_jit" directive was used.
author Igor Sysoev <http://sysoev.ru>
date Mon, 30 Jan 2012 00:00:00 +0400
parents c456a023113c
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 */