]> git.kaiwu.me - nginx.git/commitdiff
do not test a pool block space if we can not allocated from the block 4 times
authorIgor Sysoev <igor@sysoev.ru>
Fri, 5 Jun 2009 13:27:12 +0000 (13:27 +0000)
committerIgor Sysoev <igor@sysoev.ru>
Fri, 5 Jun 2009 13:27:12 +0000 (13:27 +0000)
src/core/ngx_palloc.c
src/core/ngx_palloc.h

index a3f73f45e643e01facd9b9e827c1b3a8e606d96b..fd0476803c911d314cdc0b720cd02ac6a3bbdc07 100644 (file)
@@ -25,6 +25,7 @@ ngx_create_pool(size_t size, ngx_log_t *log)
     p->d.last = (u_char *) p + sizeof(ngx_pool_t);
     p->d.end = (u_char *) p + size;
     p->d.next = NULL;
+    p->d.failed = 0;
 
     size = size - sizeof(ngx_pool_t);
     p->max = (size < NGX_MAX_ALLOC_FROM_POOL) ? size : NGX_MAX_ALLOC_FROM_POOL;
@@ -189,6 +190,7 @@ ngx_palloc_block(ngx_pool_t *pool, size_t size)
 
     new->d.end = m + psize;
     new->d.next = NULL;
+    new->d.failed = 0;
 
     m += sizeof(ngx_pool_data_t);
     m = ngx_align_ptr(m, NGX_ALIGNMENT);
@@ -197,7 +199,7 @@ ngx_palloc_block(ngx_pool_t *pool, size_t size)
     current = pool->current;
 
     for (p = current; p->d.next; p = p->d.next) {
-        if ((size_t) (p->d.end - p->d.last) < NGX_ALIGNMENT) {
+        if (p->d.failed++ > 4) {
             current = p->d.next;
         }
     }
index f9d5216ed63d14579405b78ac1c3ce3f01858429..7706df19c7d3d4f5a62a2d2ab3ce4d9c113ca2f2 100644 (file)
@@ -46,6 +46,7 @@ typedef struct {
     u_char               *last;
     u_char               *end;
     ngx_pool_t           *next;
+    ngx_uint_t            failed;
 } ngx_pool_data_t;