]> git.kaiwu.me - nginx.git/commitdiff
test that zone has the same addresses in different processes
authorIgor Sysoev <igor@sysoev.ru>
Tue, 2 Jun 2009 13:57:59 +0000 (13:57 +0000)
committerIgor Sysoev <igor@sysoev.ru>
Tue, 2 Jun 2009 13:57:59 +0000 (13:57 +0000)
src/core/ngx_cycle.c
src/core/ngx_slab.h

index fc65765b0006de0056dffb487c64e3788225c89d..47d5f56d868f54071300989de268706b47933471 100644 (file)
@@ -463,11 +463,8 @@ ngx_init_cycle(ngx_cycle_t *old_cycle)
             goto failed;
         }
 
-        if (!shm_zone[i].shm.exists) {
-
-            if (ngx_init_zone_pool(cycle, &shm_zone[i]) != NGX_OK) {
-                goto failed;
-            }
+        if (ngx_init_zone_pool(cycle, &shm_zone[i]) != NGX_OK) {
+            goto failed;
         }
 
         if (shm_zone[i].init(&shm_zone[i], NULL) != NGX_OK) {
@@ -885,8 +882,21 @@ ngx_init_zone_pool(ngx_cycle_t *cycle, ngx_shm_zone_t *zn)
 
     sp = (ngx_slab_pool_t *) zn->shm.addr;
 
+    if (zn->shm.exists) {
+
+        if (sp == sp->addr) {
+            return NGX_OK;
+        }
+
+        ngx_log_error(NGX_LOG_EMERG, cycle->log, 0,
+                      "shared zone \"%V\" has no equal addresses: %p vs %p",
+                      &zn->shm.name, sp->addr, sp);
+        return NGX_ERROR;
+    }
+
     sp->end = zn->shm.addr + zn->shm.size;
     sp->min_shift = 3;
+    sp->addr = zn->shm.addr;
 
 #if (NGX_HAVE_ATOMIC_OPS)
 
index 89c4687f620299c777d4031a1204619d2b39e80f..291e1b51e13ddcb9d4a6e1fc030c28f29e7a3190 100644 (file)
@@ -39,6 +39,7 @@ typedef struct {
     u_char            zero;
 
     void             *data;
+    void             *addr;
 } ngx_slab_pool_t;