summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2017-12-11 16:02:10 -0500
committerNick Mathewson <nickm@torproject.org>2017-12-11 16:02:10 -0500
commit252db6ad26900235f8904fa6b8d510551b9176cf (patch)
tree6105b6089e1a8c9dafb5d54e6d5ffabb18b7f445
parentea929e8456d065a25d7eb5e2e0e41e0f303ebe9d (diff)
parent057139d3830bb94df8031bb6e8e385cef53352bc (diff)
downloadtor-252db6ad26900235f8904fa6b8d510551b9176cf.tar.gz
tor-252db6ad26900235f8904fa6b8d510551b9176cf.zip
Merge branch 'maint-0.3.2'
-rw-r--r--changes/bug245905
-rw-r--r--src/or/scheduler_kist.c11
2 files changed, 12 insertions, 4 deletions
diff --git a/changes/bug24590 b/changes/bug24590
new file mode 100644
index 0000000000..77e039f8d2
--- /dev/null
+++ b/changes/bug24590
@@ -0,0 +1,5 @@
+ o Minor bugfixes (scheduler, KIST):
+ - Avoid a possible integer overflow when computing the available space on
+ the TCP buffer of a channel. This has no security implications but can
+ make KIST not behave properly by allowing more cells on a already
+ saturated connection. Fixes bug 24590; bugfix on 0.3.2.1-alpha.
diff --git a/src/or/scheduler_kist.c b/src/or/scheduler_kist.c
index e02926e478..7028b7fa89 100644
--- a/src/or/scheduler_kist.c
+++ b/src/or/scheduler_kist.c
@@ -264,10 +264,13 @@ update_socket_info_impl, (socket_table_ent_t *ent))
* ^ ((cwnd * mss) * factor) bytes
*/
- /* Assuming all these values from the kernel are uint32_t still, they will
- * always fit into a int64_t tcp_space variable. */
- tcp_space = (ent->cwnd - ent->unacked) * (int64_t)ent->mss;
- if (tcp_space < 0) {
+ /* 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. */
+ if (ent->cwnd >= ent->unacked) {
+ tcp_space = (ent->cwnd - ent->unacked) * (int64_t)(ent->mss);
+ } else {
tcp_space = 0;
}