summaryrefslogtreecommitdiff
path: root/src/or/relay.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/or/relay.c')
-rw-r--r--src/or/relay.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/src/or/relay.c b/src/or/relay.c
index 32e8f6b8f4..8732c658ce 100644
--- a/src/or/relay.c
+++ b/src/or/relay.c
@@ -779,6 +779,11 @@ connection_edge_process_relay_cell(cell_t *cell, circuit_t *circ,
num_seen++;
log_fn(LOG_DEBUG,"Now seen %d relay cells here.", num_seen);
+ if (rh.length > RELAY_PAYLOAD_SIZE) {
+ log_fn(LOG_WARN, "Relay cell length field too long. Closing circuit.");
+ return -1;
+ }
+
/* either conn is NULL, in which case we've got a control cell, or else
* conn points to the recognized stream. */