annotate src/core/ngx_shmtx.c @ 680:597573166f34 NGINX_1_3_3

nginx 1.3.3 *) Feature: entity tags support and the "etag" directive. *) Bugfix: trailing dot in a source value was not ignored if the "map" directive was used with the "hostnames" parameter. *) Bugfix: incorrect location might be used to process a request if a URI was changed via a "rewrite" directive before an internal redirect to a named location.
author Igor Sysoev <http://sysoev.ru>
date Tue, 10 Jul 2012 00:00:00 +0400
parents d0f7a625f27c
children 6db6e93f55ee
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
1
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
2 /*
73e8476f9142 nginx 0.3.27
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: 650
diff changeset
4 * Copyright (C) Nginx, Inc.
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
5 */
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
6
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
7
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
8 #include <ngx_config.h>
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
9 #include <ngx_core.h>
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
10
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
11
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
12 #if (NGX_HAVE_ATOMIC_OPS)
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
13
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
14
650
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
15 static void ngx_shmtx_wakeup(ngx_shmtx_t *mtx);
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
16
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
17
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
18 ngx_int_t
650
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
19 ngx_shmtx_create(ngx_shmtx_t *mtx, ngx_shmtx_sh_t *addr, u_char *name)
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
20 {
650
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
21 mtx->lock = &addr->lock;
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
22
624
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
23 if (mtx->spin == (ngx_uint_t) -1) {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
24 return NGX_OK;
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
25 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
26
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
27 mtx->spin = 2048;
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
28
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
29 #if (NGX_HAVE_POSIX_SEM)
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
30
650
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
31 mtx->wait = &addr->wait;
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
32
624
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
33 if (sem_init(&mtx->sem, 1, 0) == -1) {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
34 ngx_log_error(NGX_LOG_ALERT, ngx_cycle->log, ngx_errno,
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
35 "sem_init() failed");
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
36 } else {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
37 mtx->semaphore = 1;
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
38 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
39
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
40 #endif
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
41
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
42 return NGX_OK;
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
43 }
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
44
624
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
45
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
46 void
680
597573166f34 nginx 1.3.3
Igor Sysoev <http://sysoev.ru>
parents: 660
diff changeset
47 ngx_shmtx_destroy(ngx_shmtx_t *mtx)
624
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
48 {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
49 #if (NGX_HAVE_POSIX_SEM)
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
50
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
51 if (mtx->semaphore) {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
52 if (sem_destroy(&mtx->sem) == -1) {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
53 ngx_log_error(NGX_LOG_ALERT, ngx_cycle->log, ngx_errno,
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
54 "sem_destroy() failed");
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
55 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
56 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
57
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
58 #endif
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
59 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
60
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
61
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
62 ngx_uint_t
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
63 ngx_shmtx_trylock(ngx_shmtx_t *mtx)
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
64 {
650
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
65 return (*mtx->lock == 0 && ngx_atomic_cmp_set(mtx->lock, 0, ngx_pid));
624
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
66 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
67
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
68
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
69 void
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
70 ngx_shmtx_lock(ngx_shmtx_t *mtx)
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
71 {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
72 ngx_uint_t i, n;
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
73
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
74 ngx_log_debug0(NGX_LOG_DEBUG_CORE, ngx_cycle->log, 0, "shmtx lock");
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
75
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
76 for ( ;; ) {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
77
650
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
78 if (*mtx->lock == 0 && ngx_atomic_cmp_set(mtx->lock, 0, ngx_pid)) {
624
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
79 return;
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
80 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
81
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
82 if (ngx_ncpu > 1) {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
83
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
84 for (n = 1; n < mtx->spin; n <<= 1) {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
85
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
86 for (i = 0; i < n; i++) {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
87 ngx_cpu_pause();
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
88 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
89
650
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
90 if (*mtx->lock == 0
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
91 && ngx_atomic_cmp_set(mtx->lock, 0, ngx_pid))
624
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
92 {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
93 return;
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
94 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
95 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
96 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
97
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
98 #if (NGX_HAVE_POSIX_SEM)
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
99
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
100 if (mtx->semaphore) {
650
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
101 (void) ngx_atomic_fetch_add(mtx->wait, 1);
624
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
102
650
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
103 if (*mtx->lock == 0 && ngx_atomic_cmp_set(mtx->lock, 0, ngx_pid)) {
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
104 return;
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
105 }
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
106
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
107 ngx_log_debug1(NGX_LOG_DEBUG_CORE, ngx_cycle->log, 0,
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
108 "shmtx wait %uA", *mtx->wait);
624
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
109
650
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
110 while (sem_wait(&mtx->sem) == -1) {
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
111 ngx_err_t err;
624
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
112
650
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
113 err = ngx_errno;
624
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
114
650
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
115 if (err != NGX_EINTR) {
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
116 ngx_log_error(NGX_LOG_ALERT, ngx_cycle->log, err,
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
117 "sem_wait() failed while waiting on shmtx");
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
118 break;
624
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
119 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
120
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
121 ngx_log_debug0(NGX_LOG_DEBUG_CORE, ngx_cycle->log, 0,
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
122 "shmtx awoke");
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
123 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
124
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
125 continue;
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
126 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
127
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
128 #endif
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
129
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
130 ngx_sched_yield();
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
131 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
132 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
133
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
134
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
135 void
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
136 ngx_shmtx_unlock(ngx_shmtx_t *mtx)
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
137 {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
138 if (mtx->spin != (ngx_uint_t) -1) {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
139 ngx_log_debug0(NGX_LOG_DEBUG_CORE, ngx_cycle->log, 0, "shmtx unlock");
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
140 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
141
650
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
142 if (ngx_atomic_cmp_set(mtx->lock, ngx_pid, 0)) {
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
143 ngx_shmtx_wakeup(mtx);
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
144 }
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
145 }
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
146
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
147
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
148 ngx_uint_t
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
149 ngx_shmtx_force_unlock(ngx_shmtx_t *mtx, ngx_pid_t pid)
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
150 {
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
151 ngx_log_debug0(NGX_LOG_DEBUG_CORE, ngx_cycle->log, 0,
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
152 "shmtx forced unlock");
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
153
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
154 if (ngx_atomic_cmp_set(mtx->lock, pid, 0)) {
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
155 ngx_shmtx_wakeup(mtx);
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
156 return 1;
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
157 }
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
158
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
159 return 0;
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
160 }
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
161
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
162
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
163 static void
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
164 ngx_shmtx_wakeup(ngx_shmtx_t *mtx)
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
165 {
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
166 #if (NGX_HAVE_POSIX_SEM)
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
167 ngx_atomic_uint_t wait;
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
168
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
169 if (!mtx->semaphore) {
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
170 return;
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
171 }
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
172
624
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
173 for ( ;; ) {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
174
650
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
175 wait = *mtx->wait;
624
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
176
650
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
177 if (wait == 0) {
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
178 return;
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
179 }
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
180
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
181 if (ngx_atomic_cmp_set(mtx->wait, wait, wait - 1)) {
624
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
182 break;
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
183 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
184 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
185
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
186 ngx_log_debug1(NGX_LOG_DEBUG_CORE, ngx_cycle->log, 0,
650
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
187 "shmtx wake %uA", wait);
624
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
188
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
189 if (sem_post(&mtx->sem) == -1) {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
190 ngx_log_error(NGX_LOG_ALERT, ngx_cycle->log, ngx_errno,
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
191 "sem_post() failed while wake shmtx");
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
192 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
193
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
194 #endif
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
195 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
196
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
197
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
198 #else
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
199
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
200
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
201 ngx_int_t
650
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
202 ngx_shmtx_create(ngx_shmtx_t *mtx, ngx_shmtx_sh_t *addr, u_char *name)
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
203 {
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
204 if (mtx->name) {
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
205
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
206 if (ngx_strcmp(name, mtx->name) == 0) {
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
207 mtx->name = name;
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
208 return NGX_OK;
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
209 }
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
210
680
597573166f34 nginx 1.3.3
Igor Sysoev <http://sysoev.ru>
parents: 660
diff changeset
211 ngx_shmtx_destroy(mtx);
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
212 }
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
213
284
3dbecd747fbb nginx 0.5.12
Igor Sysoev <http://sysoev.ru>
parents: 258
diff changeset
214 mtx->fd = ngx_open_file(name, NGX_FILE_RDWR, NGX_FILE_CREATE_OR_OPEN,
3dbecd747fbb nginx 0.5.12
Igor Sysoev <http://sysoev.ru>
parents: 258
diff changeset
215 NGX_FILE_DEFAULT_ACCESS);
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
216
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
217 if (mtx->fd == NGX_INVALID_FILE) {
258
6ae1357b7b7c nginx 0.4.14
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
218 ngx_log_error(NGX_LOG_EMERG, ngx_cycle->log, ngx_errno,
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
219 ngx_open_file_n " \"%s\" failed", name);
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
220 return NGX_ERROR;
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
221 }
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
222
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
223 if (ngx_delete_file(name) == NGX_FILE_ERROR) {
258
6ae1357b7b7c nginx 0.4.14
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
224 ngx_log_error(NGX_LOG_ALERT, ngx_cycle->log, ngx_errno,
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
225 ngx_delete_file_n " \"%s\" failed", name);
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
226 }
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
227
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
228 mtx->name = name;
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
229
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
230 return NGX_OK;
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
231 }
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
232
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
233
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
234 void
680
597573166f34 nginx 1.3.3
Igor Sysoev <http://sysoev.ru>
parents: 660
diff changeset
235 ngx_shmtx_destroy(ngx_shmtx_t *mtx)
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
236 {
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
237 if (ngx_close_file(mtx->fd) == NGX_FILE_ERROR) {
258
6ae1357b7b7c nginx 0.4.14
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
238 ngx_log_error(NGX_LOG_ALERT, ngx_cycle->log, ngx_errno,
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
239 ngx_close_file_n " \"%s\" failed", mtx->name);
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
240 }
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
241 }
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
242
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
243
624
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
244 ngx_uint_t
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
245 ngx_shmtx_trylock(ngx_shmtx_t *mtx)
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
246 {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
247 ngx_err_t err;
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
248
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
249 err = ngx_trylock_fd(mtx->fd);
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
250
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
251 if (err == 0) {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
252 return 1;
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
253 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
254
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
255 if (err == NGX_EAGAIN) {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
256 return 0;
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
257 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
258
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
259 #if __osf__ /* Tru64 UNIX */
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
260
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
261 if (err == NGX_EACCESS) {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
262 return 0;
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
263 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
264
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
265 #endif
624
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
266
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
267 ngx_log_abort(err, ngx_trylock_fd_n " %s failed", mtx->name);
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
268
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
269 return 0;
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
270 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
271
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
272
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
273 void
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
274 ngx_shmtx_lock(ngx_shmtx_t *mtx)
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
275 {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
276 ngx_err_t err;
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
277
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
278 err = ngx_lock_fd(mtx->fd);
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
279
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
280 if (err == 0) {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
281 return;
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
282 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
283
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
284 ngx_log_abort(err, ngx_lock_fd_n " %s failed", mtx->name);
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
285 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
286
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
287
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
288 void
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
289 ngx_shmtx_unlock(ngx_shmtx_t *mtx)
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
290 {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
291 ngx_err_t err;
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
292
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
293 err = ngx_unlock_fd(mtx->fd);
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
294
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
295 if (err == 0) {
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
296 return;
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
297 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
298
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
299 ngx_log_abort(err, ngx_unlock_fd_n " %s failed", mtx->name);
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
300 }
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
301
650
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
302
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
303 ngx_uint_t
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
304 ngx_shmtx_force_unlock(ngx_shmtx_t *mtx, ngx_pid_t pid)
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
305 {
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
306 return 0;
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
307 }
4d05413aebad nginx 1.1.9
Igor Sysoev <http://sysoev.ru>
parents: 624
diff changeset
308
624
d4da38525468 nginx 1.0.2
Igor Sysoev <http://sysoev.ru>
parents: 284
diff changeset
309 #endif