aboutsummaryrefslogtreecommitdiff
path: root/src/or/relay.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2013-06-18 10:25:30 -0400
committerNick Mathewson <nickm@torproject.org>2013-06-18 10:25:30 -0400
commitb5d1fded3dfa836ef1f45f6acb74971f75d5caa9 (patch)
treece22de55ffa508033064f7e6165590c00028f459 /src/or/relay.c
parent2974c83735d2ac473fcffea0ff3b453e900d5854 (diff)
parentefa342f5fa2c6700ed8273557b7fb39bdc577120 (diff)
downloadtor-b5d1fded3dfa836ef1f45f6acb74971f75d5caa9.tar.gz
tor-b5d1fded3dfa836ef1f45f6acb74971f75d5caa9.zip
Merge remote-tracking branch 'origin/maint-0.2.4'
Diffstat (limited to 'src/or/relay.c')
-rw-r--r--src/or/relay.c33
1 files changed, 31 insertions, 2 deletions
diff --git a/src/or/relay.c b/src/or/relay.c
index 38776bcd9a..251d3ffa2f 100644
--- a/src/or/relay.c
+++ b/src/or/relay.c
@@ -2039,7 +2039,7 @@ circuit_consider_sending_sendme(circuit_t *circ, crypt_path_t *layer_hint)
#endif
/** The total number of cells we have allocated from the memory pool. */
-static int total_cells_allocated = 0;
+static size_t total_cells_allocated = 0;
/** A memory pool to allocate packed_cell_t objects. */
static mp_pool_t *cell_pool = NULL;
@@ -2119,7 +2119,7 @@ dump_cell_pool_usage(int severity)
}
tor_log(severity, LD_MM,
"%d cells allocated on %d circuits. %d cells leaked.",
- n_cells, n_circs, total_cells_allocated - n_cells);
+ n_cells, n_circs, (int)total_cells_allocated - n_cells);
mp_pool_log_status(cell_pool, severity);
}
@@ -2227,6 +2227,29 @@ cell_queue_pop(cell_queue_t *queue)
return cell;
}
+/** Return the total number of bytes used for each packed_cell in a queue.
+ * Approximate. */
+size_t
+packed_cell_mem_cost(void)
+{
+ return sizeof(packed_cell_t) + MP_POOL_ITEM_OVERHEAD +
+ get_options()->CellStatistics ?
+ (sizeof(insertion_time_elem_t)+MP_POOL_ITEM_OVERHEAD) : 0;
+}
+
+/** Check whether we've got too much space used for cells. If so,
+ * call the OOM handler and return 1. Otherwise, return 0. */
+static int
+cell_queues_check_size(void)
+{
+ size_t alloc = total_cells_allocated * packed_cell_mem_cost();
+ if (alloc >= get_options()->MaxMemInCellQueues) {
+ circuits_handle_oom(alloc);
+ return 1;
+ }
+ return 0;
+}
+
/**
* Update the number of cells available on the circuit's n_chan or p_chan's
* circuit mux.
@@ -2599,6 +2622,12 @@ append_cell_to_circuit_queue(circuit_t *circ, channel_t *chan,
cell_queue_append_packed_copy(queue, cell, chan->wide_circ_ids, 1);
+ if (PREDICT_UNLIKELY(cell_queues_check_size())) {
+ /* We ran the OOM handler */
+ if (circ->marked_for_close)
+ return;
+ }
+
/* If we have too many cells on the circuit, we should stop reading from
* the edge streams for a while. */
if (!streams_blocked && queue->n >= CELL_QUEUE_HIGHWATER_SIZE)