diff options
author | Vsevolod Stakhov <vsevolod@rambler-co.ru> | 2009-01-28 19:19:20 +0300 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@rambler-co.ru> | 2009-01-28 19:19:20 +0300 |
commit | 24e7403974f65b788ad81071d30c092adde97f4e (patch) | |
tree | 86640b5a4b64ad3f21e9feb64da28df3c4f4135b | |
parent | 5a21d1f8f5809db3d3b52f3127120a83ca70f2aa (diff) | |
download | rspamd-24e7403974f65b788ad81071d30c092adde97f4e.tar.gz rspamd-24e7403974f65b788ad81071d30c092adde97f4e.zip |
* Fix bug with calling consolidation function after stop_point
* Use shared memory for storing pool allocator statistics
* Fix bug with processing statfiles results
-rw-r--r-- | src/filter.c | 8 | ||||
-rw-r--r-- | src/mem_pool.c | 50 | ||||
-rw-r--r-- | src/worker.c | 1 |
3 files changed, 42 insertions, 17 deletions
diff --git a/src/filter.c b/src/filter.c index 651aac267..b847831d7 100644 --- a/src/filter.c +++ b/src/filter.c @@ -140,6 +140,8 @@ metric_process_callback (gpointer key, gpointer value, void *data) else { metric_res->score = factor_consolidation_func (task, metric_res->metric->name); } + msg_debug ("process_metric_callback: got result %.2f from consolidation function for metric %s", + metric_res->score, metric_res->metric->name); } static int @@ -196,6 +198,8 @@ continue_process_filters (struct worker_task *task) } cur = LIST_NEXT (cur, next); } + /* Process all metrics */ + g_hash_table_foreach (task->results, metric_process_callback, task); /* All done */ bufferevent_enable (task->bev, EV_WRITE); evbuffer_drain (task->bev->output, EVBUFFER_LENGTH (task->bev->output)); @@ -418,6 +422,7 @@ statfiles_callback (gpointer key, gpointer value, void *arg) res->symbols = g_list_prepend (NULL, st->alias); res->weight = st->classifier->add_result_func (res->weight, weight * st->weight); } + msg_debug ("process_statfiles: result weight: %.2f", res->weight); } } @@ -450,6 +455,7 @@ statfiles_results_callback (gpointer key, gpointer value, void *arg) else { metric_res->score += res->weight; } + msg_debug ("statfiles_results_callback: got total weight %.2f for metric %s", metric_res->score, metric->name); cur_symbol = g_list_first (res->symbols); while (cur_symbol) { @@ -458,6 +464,8 @@ statfiles_results_callback (gpointer key, gpointer value, void *arg) cur_symbol = g_list_next (cur_symbol); } + g_list_free (res->symbols); + } diff --git a/src/mem_pool.c b/src/mem_pool.c index 582b91f0c..59cb35717 100644 --- a/src/mem_pool.c +++ b/src/mem_pool.c @@ -39,10 +39,7 @@ pthread_mutex_t stat_mtx = PTHREAD_MUTEX_INITIALIZER; #undef MEMORY_GREEDY /* Internal statistic */ -static size_t bytes_allocated = 0; -static size_t chunks_allocated = 0; -static size_t chunks_freed = 0; -static size_t shared_chunks_allocated = 0; +static memory_pool_stat_t *stat = NULL; static struct _pool_chain * pool_chain_new (size_t size) @@ -54,7 +51,7 @@ pool_chain_new (size_t size) chain->pos = chain->begin; chain->next = NULL; STAT_LOCK (); - chunks_allocated ++; + stat->chunks_allocated ++; STAT_UNLOCK (); return chain; @@ -78,7 +75,7 @@ pool_chain_new_shared (size_t size) if (fd == -1) { return NULL; } - chain = mmap (NULL, shm->size, PROT_READ|PROT_WRITE, MAP_SHARED, fd, 0); + chain = mmap (NULL, size + sizeof (struct _pool_chain_shared), PROT_READ|PROT_WRITE, MAP_SHARED, fd, 0); chain->begin = ((u_char *)chain) + sizeof (struct _pool_chain_shared); if (chain == MAP_FAILED) { return NULL; @@ -91,7 +88,7 @@ pool_chain_new_shared (size_t size) chain->lock = 0; chain->next = NULL; STAT_LOCK (); - shared_chunks_allocated ++; + stat->shared_chunks_allocated ++; STAT_UNLOCK (); return chain; @@ -101,6 +98,23 @@ memory_pool_t* memory_pool_new (size_t size) { memory_pool_t *new; + + /* Allocate statistic structure if it is not allocated before */ + if (stat == NULL) { +#if defined(HAVE_MMAP_ANON) + stat = mmap (NULL, sizeof (memory_pool_stat_t), PROT_READ|PROT_WRITE, MAP_ANON|MAP_SHARED, -1, 0); + g_assert (stat != MAP_FAILED); +#elif defined(HAVE_MMAP_ZERO) + int fd; + + fd = open ("/dev/zero", O_RDWR); + g_assert (fd != -1); + stat = mmap (NULL, sizeof (memory_pool_stat_t), PROT_READ|PROT_WRITE, MAP_SHARED, fd, 0); + g_assert (chain != MAP_FAILED); +#else +# error No mmap methods are defined +#endif + } new = g_malloc (sizeof (memory_pool_t)); new->cur_pool = pool_chain_new (size); @@ -140,14 +154,14 @@ memory_pool_alloc (memory_pool_t *pool, size_t size) pool->cur_pool = new; new->pos += size; STAT_LOCK (); - bytes_allocated += size; + stat->bytes_allocated += size; STAT_UNLOCK (); return new->begin; } tmp = cur->pos; cur->pos += size; STAT_LOCK (); - bytes_allocated += size; + stat->bytes_allocated += size; STAT_UNLOCK (); return tmp; } @@ -209,14 +223,14 @@ memory_pool_alloc_shared (memory_pool_t *pool, size_t size) cur->next = new; new->pos += size; STAT_LOCK (); - bytes_allocated += size; + stat->bytes_allocated += size; STAT_UNLOCK (); return new->begin; } tmp = cur->pos; cur->pos += size; STAT_LOCK (); - bytes_allocated += size; + stat->bytes_allocated += size; STAT_UNLOCK (); return tmp; } @@ -326,7 +340,7 @@ memory_pool_delete (memory_pool_t *pool) g_free (tmp->begin); g_free (tmp); STAT_LOCK (); - chunks_freed ++; + stat->chunks_freed ++; STAT_UNLOCK (); } /* Unmap shared memory */ @@ -335,7 +349,7 @@ memory_pool_delete (memory_pool_t *pool) cur_shared = cur_shared->next; munmap (tmp_shared, tmp_shared->len + sizeof (struct _pool_chain_shared)); STAT_LOCK (); - chunks_freed ++; + stat->chunks_freed ++; STAT_UNLOCK (); } @@ -345,10 +359,12 @@ memory_pool_delete (memory_pool_t *pool) void memory_pool_stat (memory_pool_stat_t *st) { - st->bytes_allocated = bytes_allocated; - st->chunks_allocated = chunks_allocated; - st->shared_chunks_allocated = shared_chunks_allocated; - st->chunks_freed = chunks_freed; + if (stat) { + st->bytes_allocated = stat->bytes_allocated; + st->chunks_allocated = stat->chunks_allocated; + st->shared_chunks_allocated = stat->shared_chunks_allocated; + st->chunks_freed = stat->chunks_freed; + } } #define FIXED_POOL_SIZE 4095 diff --git a/src/worker.c b/src/worker.c index bed6e3d91..8c97710a1 100644 --- a/src/worker.c +++ b/src/worker.c @@ -84,6 +84,7 @@ free_task (struct worker_task *task) struct mime_part *p; if (task) { + msg_debug ("free_task: free pointer %p", task); if (task->memc_ctx) { memc_close_ctx (task->memc_ctx); } |