aboutsummaryrefslogtreecommitdiff
path: root/src/core
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2023-09-12 08:24:29 -0400
committerNick Mathewson <nickm@torproject.org>2023-09-12 08:24:29 -0400
commit1da5a9b3bccdb60e81fcf11e0c1fa4190ca67929 (patch)
treeea5bb9f9620f782b80ca4fd7e59a2b763cac4e4b /src/core
parent449f988c8f5e610b2a030a0c2577afd4bb74dc4a (diff)
downloadtor-1da5a9b3bccdb60e81fcf11e0c1fa4190ca67929.tar.gz
tor-1da5a9b3bccdb60e81fcf11e0c1fa4190ca67929.zip
Correct a comment on channel_should_write_to_kernel.
This issue was originally called out by pseudonymisaTor on !707; the comment in this commit takes a different approach to explaining what is going on.
Diffstat (limited to 'src/core')
-rw-r--r--src/core/or/scheduler_kist.c14
1 files changed, 10 insertions, 4 deletions
diff --git a/src/core/or/scheduler_kist.c b/src/core/or/scheduler_kist.c
index 69804247c8..c4b15a9950 100644
--- a/src/core/or/scheduler_kist.c
+++ b/src/core/or/scheduler_kist.c
@@ -447,10 +447,16 @@ update_socket_written(socket_table_t *table, channel_t *chan, size_t bytes)
* by only writing a channel's outbuf to the kernel if it has 8 cells or more
* in it.
*
- * Note: The number 8 has been picked for no particular reasons except that it
- * is 4096 bytes which is a common number for buffering. A TLS record can hold
- * up to 16KiB thus using 8 cells means that a relay will at most send a TLS
- * record of 4KiB or 1/4 of the maximum capacity of a TLS record.
+ * Note: The number 8 was picked so that, when using 512-byte cells, it
+ * would produce 4096 bytes: a common number for buffering. A TLS
+ * record can hold up to 16KiB; thus, using 8 512-byte cells means that
+ * a relay will at most send a TLS record of 4KiB or 1/4 of the maximum
+ * capacity of a TLS record.
+ *
+ * Of course, the above calculation became incorrect when we moved to
+ * 514-byte cells in order to accommodate a 4-byte circuit ID; we may
+ * want to consider profiling with '7' to see if it produces better
+ * results. (TODO)
*/
MOCK_IMPL(int, channel_should_write_to_kernel,
(outbuf_table_t *table, channel_t *chan))