summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2014-08-18 15:21:50 -0400
committerNick Mathewson <nickm@torproject.org>2014-08-18 15:21:50 -0400
commitec59167cae1f5b3057ed722857d78ec78239e991 (patch)
tree9c0799c962f1f562bb0fcee4be1791b2bdcca2c4
parent2937de21803174e14873f68b34ba8a6c62285c45 (diff)
downloadtor-ec59167cae1f5b3057ed722857d78ec78239e991.tar.gz
tor-ec59167cae1f5b3057ed722857d78ec78239e991.zip
When counting memory from closing a connection, count the dir conn too
Fix part of bug 11972
-rw-r--r--changes/bug117925
-rw-r--r--src/or/circuitlist.c25
2 files changed, 23 insertions, 7 deletions
diff --git a/changes/bug11792 b/changes/bug11792
new file mode 100644
index 0000000000..1d381891db
--- /dev/null
+++ b/changes/bug11792
@@ -0,0 +1,5 @@
+ o Minor features (security, OOM):
+ - When closing an edge connection because we've run out of memory,
+ also count the amount of memory that any tunnelled directory
+ connection attached to that connection had consumed. Part of
+ ticket 11792. \ No newline at end of file
diff --git a/src/or/circuitlist.c b/src/or/circuitlist.c
index f3a83503ef..9aeb3eb19a 100644
--- a/src/or/circuitlist.c
+++ b/src/or/circuitlist.c
@@ -1799,6 +1799,21 @@ marked_circuit_free_cells(circuit_t *circ)
cell_queue_clear(& TO_OR_CIRCUIT(circ)->p_chan_cells);
}
+static size_t
+marked_circuit_single_conn_free_bytes(connection_t *conn)
+{
+ size_t result = 0;
+ if (conn->inbuf) {
+ result += buf_allocation(conn->inbuf);
+ buf_clear(conn->inbuf);
+ }
+ if (conn->outbuf) {
+ result += buf_allocation(conn->outbuf);
+ buf_clear(conn->outbuf);
+ }
+ return result;
+}
+
/** Aggressively free buffer contents on all the buffers of all streams in the
* list starting at <b>stream</b>. Return the number of bytes recovered. */
static size_t
@@ -1807,13 +1822,9 @@ marked_circuit_streams_free_bytes(edge_connection_t *stream)
size_t result = 0;
for ( ; stream; stream = stream->next_stream) {
connection_t *conn = TO_CONN(stream);
- if (conn->inbuf) {
- result += buf_allocation(conn->inbuf);
- buf_clear(conn->inbuf);
- }
- if (conn->outbuf) {
- result += buf_allocation(conn->outbuf);
- buf_clear(conn->outbuf);
+ result += marked_circuit_single_conn_free_bytes(conn);
+ if (conn->linked_conn) {
+ result += marked_circuit_single_conn_free_bytes(conn->linked_conn);
}
}
return result;