aboutsummaryrefslogtreecommitdiff
path: root/src/lib/tls/buffers_tls.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2020-01-29 08:49:01 -0500
committerNick Mathewson <nickm@torproject.org>2020-01-29 08:50:03 -0500
commit2985a6018f1123b8843023f09d004f477f59a009 (patch)
treec8d2e5cc8a7ccdf6f48887d4d20e71bdf38bae6c /src/lib/tls/buffers_tls.c
parent19954cffd7710ccac778aa5cf15ae1bc6a5d56fa (diff)
downloadtor-2985a6018f1123b8843023f09d004f477f59a009.tar.gz
tor-2985a6018f1123b8843023f09d004f477f59a009.zip
buf_read_from_tls: Return ERROR_MISC, not WANTWRITE, on BUG().
Fixes bug 32673; bugfix on 0.3.0.4-alpha. We introduced these checks in ee5471f9aab5526 to help diagnose 21369, but we used "-1" when "TOR_TLS_ERROR_MISC" would have been correct. Found by opara. I don't think that this is actually getting triggered in the wild, but if it were, it could cause nasty behavior: spurious WANTREAD/WANTWRITE returns have a way of turning into CPU-eating busy-loops.
Diffstat (limited to 'src/lib/tls/buffers_tls.c')
-rw-r--r--src/lib/tls/buffers_tls.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/src/lib/tls/buffers_tls.c b/src/lib/tls/buffers_tls.c
index e92cb9163f..52be78811d 100644
--- a/src/lib/tls/buffers_tls.c
+++ b/src/lib/tls/buffers_tls.c
@@ -69,9 +69,9 @@ buf_read_from_tls(buf_t *buf, tor_tls_t *tls, size_t at_most)
check_no_tls_errors();
IF_BUG_ONCE(buf->datalen >= INT_MAX)
- return -1;
+ return TOR_TLS_ERROR_MISC;
IF_BUG_ONCE(buf->datalen >= INT_MAX - at_most)
- return -1;
+ return TOR_TLS_ERROR_MISC;
while (at_most > total_read) {
size_t readlen = at_most - total_read;