[tor-commits] [tor/master] refactor logic to decide how much to package from inbuf

asn at torproject.org asn at torproject.org
Mon May 27 11:21:14 UTC 2019


commit e4d1187584038593a75140d9a8e47024c9eba04c
Author: Roger Dingledine <arma at torproject.org>
Date:   Wed Jul 18 21:00:27 2018 -0400

    refactor logic to decide how much to package from inbuf
    
    no actual changes in behavior
---
 src/core/or/relay.c | 13 +++++++------
 1 file changed, 7 insertions(+), 6 deletions(-)

diff --git a/src/core/or/relay.c b/src/core/or/relay.c
index 5197ee613..05fee57a1 100644
--- a/src/core/or/relay.c
+++ b/src/core/or/relay.c
@@ -2102,14 +2102,15 @@ connection_edge_package_raw_inbuf(edge_connection_t *conn, int package_partial,
   if (!bytes_to_process)
     return 0;
 
-  if (!package_partial && bytes_to_process < RELAY_PAYLOAD_SIZE)
-    return 0;
+  length = RELAY_PAYLOAD_SIZE;
 
-  if (bytes_to_process > RELAY_PAYLOAD_SIZE) {
-    length = RELAY_PAYLOAD_SIZE;
-  } else {
-    length = bytes_to_process;
+  if (bytes_to_process < length) { /* not a full payload available */
+    if (package_partial)
+      length = bytes_to_process; /* just take whatever's available now */
+    else
+      return 0; /* nothing to do until we have a full payload */
   }
+
   stats_n_data_bytes_packaged += length;
   stats_n_data_cells_packaged += 1;
 





More information about the tor-commits mailing list