annotate src/os/unix/ngx_errno.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 eb208e0cf44d
children 981b4c44593b
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
1
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
2 /*
f0b350454894 nginx 0.1.0
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: 640
diff changeset
4 * Copyright (C) Nginx, Inc.
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
5 */
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
6
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
7
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
8 #include <ngx_config.h>
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
9 #include <ngx_core.h>
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
10
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
11
604
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
12 /*
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
13 * The strerror() messages are copied because:
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
14 *
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
15 * 1) strerror() and strerror_r() functions are not Async-Signal-Safe,
640
eb208e0cf44d nginx 1.1.4
Igor Sysoev <http://sysoev.ru>
parents: 604
diff changeset
16 * therefore, they cannot be used in signal handlers;
604
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
17 *
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
18 * 2) a direct sys_errlist[] array may be used instead of these functions,
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
19 * but Linux linker warns about its usage:
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
20 *
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
21 * warning: `sys_errlist' is deprecated; use `strerror' or `strerror_r' instead
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
22 * warning: `sys_nerr' is deprecated; use `strerror' or `strerror_r' instead
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
23 *
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
24 * causing false bug reports.
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
25 */
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
26
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
27
604
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
28 static ngx_str_t *ngx_sys_errlist;
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
29 static ngx_str_t ngx_unknown_error = ngx_string("Unknown error");
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
30
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
31
422
88d3e895bdf9 nginx 0.7.23
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
32 u_char *
604
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
33 ngx_strerror(ngx_err_t err, u_char *errstr, size_t size)
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
34 {
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
35 ngx_str_t *msg;
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
36
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
37 msg = ((ngx_uint_t) err < NGX_SYS_NERR) ? &ngx_sys_errlist[err]:
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
38 &ngx_unknown_error;
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
39 size = ngx_min(size, msg->len);
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
40
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
41 return ngx_cpymem(errstr, msg->data, size);
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
42 }
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
43
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
44
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
45 ngx_uint_t
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
46 ngx_strerror_init(void)
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
47 {
604
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
48 char *msg;
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
49 u_char *p;
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
50 size_t len;
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
51 ngx_err_t err;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
52
604
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
53 /*
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
54 * ngx_strerror() is not ready to work at this stage, therefore,
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
55 * malloc() is used and possible errors are logged using strerror().
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
56 */
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
57
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
58 len = NGX_SYS_NERR * sizeof(ngx_str_t);
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
59
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
60 ngx_sys_errlist = malloc(len);
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
61 if (ngx_sys_errlist == NULL) {
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
62 goto failed;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
63 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
64
604
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
65 for (err = 0; err < NGX_SYS_NERR; err++) {
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
66 msg = strerror(err);
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
67 len = ngx_strlen(msg);
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
68
604
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
69 p = malloc(len);
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
70 if (p == NULL) {
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
71 goto failed;
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
72 }
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
73
604
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
74 ngx_memcpy(p, msg, len);
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
75 ngx_sys_errlist[err].len = len;
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
76 ngx_sys_errlist[err].data = p;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
77 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
78
604
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
79 return NGX_OK;
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
80
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
81 failed:
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
82
604
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
83 err = errno;
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
84 ngx_log_stderr(0, "malloc(%uz) failed (%d: %s)", len, err, strerror(err));
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
85
428c6e58046a nginx 0.9.0
Igor Sysoev <http://sysoev.ru>
parents: 422
diff changeset
86 return NGX_ERROR;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
87 }