diff options
author | Nick Mathewson <nickm@torproject.org> | 2018-06-21 09:20:03 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2018-06-21 09:20:03 -0400 |
commit | 2ad062ee601bc30594b81a33404662fbd59ef8b1 (patch) | |
tree | 95b8a086f37938c09cebacc9ffa1ae06bb230682 /src/or/relay.c | |
parent | d46969e8208394640d9fe84edbc428329d4ec642 (diff) | |
parent | 46b06cd6999439608f4a8a34bb68f6fe6a6311e9 (diff) | |
download | tor-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.c | 24 |
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); |