aboutsummaryrefslogtreecommitdiff
path: root/src/or/scheduler_kist.c
diff options
context:
space:
mode:
authorDavid Goulet <dgoulet@torproject.org>2017-12-19 16:20:36 -0500
committerDavid Goulet <dgoulet@torproject.org>2017-12-21 09:32:04 -0500
commit885ba513ff709eb86a71c7daf7c23aafab4862a8 (patch)
treec4007d0ca43b2bb374d68788f45485d8a154c99b /src/or/scheduler_kist.c
parent7e45720cf4c88bff92a6de23ccbdd96d4cab2be5 (diff)
downloadtor-885ba513ff709eb86a71c7daf7c23aafab4862a8.tar.gz
tor-885ba513ff709eb86a71c7daf7c23aafab4862a8.zip
sched: Consider extra_space even if negative in KIST
With extra_space negative, it means that the "notsent" queue is quite large so we must consider that value with the current computed tcp_space. If we end up to have negative space, we should not add more data to the kernel since the notsent queue is just too filled up. Fixes #24665 Signed-off-by: David Goulet <dgoulet@torproject.org>
Diffstat (limited to 'src/or/scheduler_kist.c')
-rw-r--r--src/or/scheduler_kist.c22
1 files changed, 11 insertions, 11 deletions
diff --git a/src/or/scheduler_kist.c b/src/or/scheduler_kist.c
index 9acd89b37f..a50be345b0 100644
--- a/src/or/scheduler_kist.c
+++ b/src/or/scheduler_kist.c
@@ -266,8 +266,7 @@ update_socket_info_impl, (socket_table_ent_t *ent))
/* These values from the kernel are uint32_t, they will always fit into a
* int64_t tcp_space variable but if the congestion window cwnd is smaller
- * than the unacked packets, the remaining TCP space is set to 0 so we don't
- * write more on this channel. */
+ * than the unacked packets, the remaining TCP space is set to 0. */
if (ent->cwnd >= ent->unacked) {
tcp_space = (ent->cwnd - ent->unacked) * (int64_t)(ent->mss);
} else {
@@ -276,20 +275,21 @@ update_socket_info_impl, (socket_table_ent_t *ent))
/* The clamp_double_to_int64 makes sure the first part fits into an int64_t.
* In fact, if sock_buf_size_factor is still forced to be >= 0 in config.c,
- * then it will be positive for sure. Then we subtract a uint32_t. At worst
- * we end up negative, but then we just set extra_space to 0 in the sanity
- * check.*/
+ * then it will be positive for sure. Then we subtract a uint32_t. Getting a
+ * negative value is OK, see after how it is being handled. */
extra_space =
clamp_double_to_int64(
(ent->cwnd * (int64_t)ent->mss) * sock_buf_size_factor) -
ent->notsent;
- if (extra_space < 0) {
- extra_space = 0;
+ if ((tcp_space + extra_space) < 0) {
+ /* This means that the "notsent" queue is just too big so we shouldn't put
+ * more in the kernel for now. */
+ ent->limit = 0;
+ } else {
+ /* Adding two positive int64_t together will always fit in an uint64_t.
+ * And we know this will always be positive. */
+ ent->limit = (uint64_t)tcp_space + (uint64_t)extra_space;
}
-
- /* Finally we set the limit. Adding two positive int64_t together will always
- * fit in an uint64_t. */
- ent->limit = (uint64_t)tcp_space + (uint64_t)extra_space;
return;
#else /* !(defined(HAVE_KIST_SUPPORT)) */