diff options
-rw-r--r-- | src/common/mempool.c | 4 | ||||
-rw-r--r-- | src/or/relay.c | 18 |
2 files changed, 20 insertions, 2 deletions
diff --git a/src/common/mempool.c b/src/common/mempool.c index 9f1fd394bd..dcdb27c3c7 100644 --- a/src/common/mempool.c +++ b/src/common/mempool.c @@ -517,7 +517,7 @@ mp_pool_log_status(mp_pool_t *pool, int severity) " bytes in %d partially full chunks", U64_PRINTF_ARG(bu), U64_PRINTF_ARG(ba), n_used); bytes_used += bu; - bytes_allocated += bu; + bytes_allocated += ba; bu = ba = 0; for (chunk = pool->full_chunks; chunk; chunk = chunk->next) { ++n_full; @@ -528,7 +528,7 @@ mp_pool_log_status(mp_pool_t *pool, int severity) " bytes in %d full chunks", U64_PRINTF_ARG(bu), U64_PRINTF_ARG(ba), n_full); bytes_used += bu; - bytes_allocated += bu; + bytes_allocated += ba; log_fn(severity, LD_MM, "Total: "U64_FORMAT"/"U64_FORMAT" bytes allocated " "for cell pools are full.", diff --git a/src/or/relay.c b/src/or/relay.c index a5bea0a717..933d079285 100644 --- a/src/or/relay.c +++ b/src/or/relay.c @@ -1478,6 +1478,9 @@ circuit_consider_sending_sendme(circuit_t *circ, crypt_path_t *layer_hint) #define assert_active_circuits_ok_paranoid(conn) #endif +/** DOCDOC */ +static int total_cells_allocated = 0; + #ifdef ENABLE_CELL_POOL static mp_pool_t *cell_pool = NULL; /** Allocate structures to hold cells. */ @@ -1509,6 +1512,7 @@ clean_cell_pool(void) static INLINE void packed_cell_free(packed_cell_t *cell) { + --total_cells_allocated; mp_pool_release(cell); } @@ -1516,11 +1520,23 @@ packed_cell_free(packed_cell_t *cell) static INLINE packed_cell_t * packed_cell_alloc(void) { + ++total_cells_allocated; return mp_pool_get(cell_pool); } void dump_cell_pool_usage(int severity) { + circuit_t *c; + int n_circs = 0; + int n_cells = 0; + for (c = _circuit_get_global_list(); c; c = c->next) { + n_cells += c->n_conn_cells.n; + if (!CIRCUIT_IS_ORIGIN(c)) + n_cells += TO_OR_CIRCUIT(c)->p_conn_cells.n; + ++n_circs; + } + log(severity, LD_MM, "%d cells allocated on %d circuits. %d cells leaked.", + n_cells, n_circs, total_cells_allocated - n_cells); mp_pool_log_status(cell_pool, severity); } #else @@ -1544,12 +1560,14 @@ clean_cell_pool(void) static INLINE void packed_cell_free(packed_cell_t *cell) { + --total_cells_allocated; tor_free(cell); } static INLINE packed_cell_t * packed_cell_alloc(void) { + ++total_cells_allocated; return tor_malloc(sizeof(packed_cell_t)); } void |