annotate src/os/unix/ngx_shmem.c @ 154:bb61aa162c6b NGINX_0_3_24

nginx 0.3.24 *) Workaround: for bug in FreeBSD kqueue. *) Bugfix: now a response generated by the "post_action" directive is not transferred to a client. *) Bugfix: the memory leaks were occurring if many log files were used. *) Bugfix: the first "proxy_redirect" directive was working inside one location. *) Bugfix: on 64-bit platforms segmentation fault may occurred on start if the many names were used in the "server_name" directives; bug appeared in 0.3.18.
author Igor Sysoev <http://sysoev.ru>
date Wed, 01 Feb 2006 00:00:00 +0300
parents
children af37b7cb6698
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
154
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
1
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
2 /*
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
3 * Copyright (C) Igor Sysoev
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
4 */
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
5
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
6
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
7 #include <ngx_config.h>
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
8 #include <ngx_core.h>
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
9
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
10
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
11 #if (NGX_HAVE_MAP_ANON)
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
12
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
13 ngx_int_t
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
14 ngx_shm_alloc(ngx_shm_t *shm)
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
15 {
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
16 shm->addr = mmap(NULL, shm->size,
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
17 PROT_READ|PROT_WRITE, MAP_ANON|MAP_SHARED, -1, 0);
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
18
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
19 if (shm->addr == MAP_FAILED) {
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
20 ngx_log_error(NGX_LOG_ALERT, shm->log, ngx_errno,
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
21 "mmap(MAP_ANON|MAP_SHARED, %uz) failed", shm->size);
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
22 return NGX_ERROR;
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
23 }
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
24
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
25 return NGX_OK;
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
26 }
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
27
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
28
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
29 void
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
30 ngx_shm_free(ngx_shm_t *shm)
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
31 {
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
32 if (munmap(shm->addr, shm->size) == -1) {
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
33 ngx_log_error(NGX_LOG_ALERT, shm->log, ngx_errno,
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
34 "munmap(%p, %uz) failed", shm->addr, shm->size);
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
35 }
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
36 }
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
37
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
38 #elif (NGX_HAVE_MAP_DEVZERO)
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
39
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
40 ngx_int_t
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
41 ngx_shm_alloc(ngx_shm_t *shm)
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
42 {
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
43 ngx_fd_t fd;
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
44
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
45 fd = open("/dev/zero", O_RDWR);
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
46
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
47 if (fd == -1) {
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
48 ngx_log_error(NGX_LOG_ALERT, shm->log, ngx_errno,
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
49 "open(\"/dev/zero\") failed");
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
50 return NGX_ERROR;
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
51 }
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
52
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
53 shm->addr = mmap(NULL, shm->size, PROT_READ|PROT_WRITE, MAP_SHARED, fd, 0);
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
54
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
55 if (shm->addr == MAP_FAILED) {
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
56 ngx_log_error(NGX_LOG_ALERT, shm->log, ngx_errno,
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
57 "mmap(/dev/zero, MAP_SHARED, %uz) failed", shm->size);
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
58 }
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
59
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
60 if (close(fd) == -1) {
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
61 ngx_log_error(NGX_LOG_ALERT, shm->log, ngx_errno,
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
62 "close(\"/dev/zero\") failed");
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
63 }
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
64
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
65 return (shm->addr == MAP_FAILED) ? NGX_ERROR : NGX_OK;
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
66 }
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
67
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
68
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
69 void
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
70 ngx_shm_free(ngx_shm_t *shm)
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
71 {
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
72 if (munmap(shm->addr, shm->size) == -1) {
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
73 ngx_log_error(NGX_LOG_ALERT, shm->log, ngx_errno,
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
74 "munmap(%p, %uz) failed", shm->addr, shm->size);
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
75 }
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
76 }
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
77
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
78 #elif (NGX_HAVE_SYSVSHM)
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
79
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
80 #include <sys/ipc.h>
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
81 #include <sys/shm.h>
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
82
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
83
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
84 ngx_int_t
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
85 ngx_shm_alloc(ngx_shm_t *shm)
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
86 {
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
87 int id;
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
88
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
89 id = shmget(IPC_PRIVATE, shm->size, (SHM_R|SHM_W|IPC_CREAT));
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
90
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
91 if (id == -1) {
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
92 ngx_log_error(NGX_LOG_ALERT, shm->log, ngx_errno,
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
93 "shmget(%uz) failed", shm->size);
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
94 return NGX_ERROR;
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
95 }
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
96
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
97 ngx_log_debug1(NGX_LOG_DEBUG_CORE, shm->log, 0, "shmget id: %d", id);
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
98
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
99 shm->addr = shmat(id, NULL, 0);
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
100
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
101 if (shm->addr == (void *) -1) {
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
102 ngx_log_error(NGX_LOG_ALERT, shm->log, ngx_errno, "shmat() failed");
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
103 }
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
104
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
105 if (shmctl(id, IPC_RMID, NULL) == -1) {
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
106 ngx_log_error(NGX_LOG_ALERT, shm->log, ngx_errno,
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
107 "shmctl(IPC_RMID) failed");
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
108 }
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
109
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
110 return (shm->addr == (void *) -1) ? NGX_ERROR : NGX_OK;
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
111 }
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
112
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
113
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
114 void
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
115 ngx_shm_free(ngx_shm_t *shm)
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
116 {
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
117 if (shmdt(shm->addr) == -1) {
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
118 ngx_log_error(NGX_LOG_ALERT, shm->log, ngx_errno,
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
119 "shmdt(%p) failed", shm->addr);
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
120 }
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
121 }
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
122
bb61aa162c6b nginx 0.3.24
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
123 #endif