aboutsummaryrefslogtreecommitdiff
path: root/src/or/relay.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2018-06-21 09:20:03 -0400
committerNick Mathewson <nickm@torproject.org>2018-06-21 09:20:03 -0400
commit2ad062ee601bc30594b81a33404662fbd59ef8b1 (patch)
tree95b8a086f37938c09cebacc9ffa1ae06bb230682 /src/or/relay.c
parentd46969e8208394640d9fe84edbc428329d4ec642 (diff)
parent46b06cd6999439608f4a8a34bb68f6fe6a6311e9 (diff)
downloadtor-2ad062ee601bc30594b81a33404662fbd59ef8b1.tar.gz
tor-2ad062ee601bc30594b81a33404662fbd59ef8b1.zip
Merge branch 'mikeperry_bug26214-rebased_squashed'
Diffstat (limited to 'src/or/relay.c')
-rw-r--r--src/or/relay.c24
1 files changed, 22 insertions, 2 deletions
diff --git a/src/or/relay.c b/src/or/relay.c
index 143580a310..af03cd4748 100644
--- a/src/or/relay.c
+++ b/src/or/relay.c
@@ -1765,8 +1765,7 @@ connection_edge_process_relay_cell(cell_t *cell, circuit_t *circ,
circuit_resume_edge_reading(circ, layer_hint);
/* We count circuit-level sendme's as valid delivered data because
- * they are rate limited. Note that we cannot count stream
- * sendme's because the other end could send as many as they like.
+ * they are rate limited.
*/
if (CIRCUIT_IS_ORIGIN(circ)) {
circuit_read_valid_data(TO_ORIGIN_CIRCUIT(circ),
@@ -1796,6 +1795,27 @@ connection_edge_process_relay_cell(cell_t *cell, circuit_t *circ,
rh.stream_id);
return 0;
}
+
+ /* Don't allow the other endpoint to request more than our maximim
+ * (ie initial) stream SENDME window worth of data. Well-behaved
+ * stock clients will not request more than this max (as per the check
+ * in the while loop of connection_edge_consider_sending_sendme()).
+ */
+ if (conn->package_window + STREAMWINDOW_INCREMENT >
+ STREAMWINDOW_START_MAX) {
+ static struct ratelim_t stream_warn_ratelim = RATELIM_INIT(600);
+ log_fn_ratelim(&stream_warn_ratelim,LOG_PROTOCOL_WARN, LD_PROTOCOL,
+ "Unexpected stream sendme cell. Closing circ (window %d).",
+ conn->package_window);
+ return -END_CIRC_REASON_TORPROTOCOL;
+ }
+
+ /* At this point, the stream sendme is valid */
+ if (CIRCUIT_IS_ORIGIN(circ)) {
+ circuit_read_valid_data(TO_ORIGIN_CIRCUIT(circ),
+ rh.length);
+ }
+
conn->package_window += STREAMWINDOW_INCREMENT;
log_debug(domain,"stream-level sendme, packagewindow now %d.",
conn->package_window);