summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2016-12-20 18:14:21 -0500
committerNick Mathewson <nickm@torproject.org>2016-12-20 18:14:21 -0500
commita9c8a5ff18c1944ddcea0116419edc2f199583b8 (patch)
treeef32ca6e619c2c31d3ecc8da6f737a945c6cbe27
parentb49369badd28d5895f1d26b74be888298246b05a (diff)
parentb18bde23cf9c0afc95a83c3bfc7205218add4ddd (diff)
downloadtor-a9c8a5ff18c1944ddcea0116419edc2f199583b8.tar.gz
tor-a9c8a5ff18c1944ddcea0116419edc2f199583b8.zip
Merge branch 'maint-0.2.6' into maint-0.2.7
-rw-r--r--changes/bug2101811
-rw-r--r--src/or/rendcache.c6
-rw-r--r--src/or/routerparse.c6
3 files changed, 18 insertions, 5 deletions
diff --git a/changes/bug21018 b/changes/bug21018
new file mode 100644
index 0000000000..49a8b47a25
--- /dev/null
+++ b/changes/bug21018
@@ -0,0 +1,11 @@
+ o Major bugfixes (parsing, security):
+
+ - Fix a bug in parsing that could cause clients to read a single
+ byte past the end of an allocated region. This bug could be
+ used to cause hardened clients (built with
+ --enable-expensive-hardening) to crash if they tried to visit
+ a hostile hidden service. Non-hardened clients are only
+ affected depending on the details of their platform's memory
+ allocator. Fixes bug 21018; bugfix on 0.2.0.8-alpha. Found by
+ using libFuzzer. Also tracked as TROVE-2016-12-002 and as
+ CVE-2016-1254.
diff --git a/src/or/rendcache.c b/src/or/rendcache.c
index d4bdd68698..e7b1ce979a 100644
--- a/src/or/rendcache.c
+++ b/src/or/rendcache.c
@@ -801,8 +801,10 @@ rend_cache_store_v2_desc_as_client(const char *desc,
intro_size);
if (n_intro_points <= 0) {
log_warn(LD_REND, "Failed to parse introduction points. Either the "
- "service has published a corrupt descriptor or you have "
- "provided invalid authorization data.");
+ "service has published a corrupt descriptor, or you have "
+ "provided invalid authorization data, or (maybe!) the "
+ "server is deliberately serving broken data in an attempt "
+ "to crash you with bug 21018.");
goto err;
} else if (n_intro_points > MAX_INTRO_POINTS) {
log_warn(LD_REND, "Found too many introduction points on a hidden "
diff --git a/src/or/routerparse.c b/src/or/routerparse.c
index 6b6e21d5d0..7804af934f 100644
--- a/src/or/routerparse.c
+++ b/src/or/routerparse.c
@@ -4104,7 +4104,7 @@ get_next_token(memarea_t *area,
if (tok->tp == ERR_) {
/* No keyword matched; call it an "K_opt" or "A_unrecognized" */
- if (**s == '@')
+ if (*s < eol && **s == '@')
tok->tp = A_UNKNOWN_;
else
tok->tp = K_OPT;
@@ -5153,7 +5153,7 @@ rend_decrypt_introduction_points(char **ipos_decrypted,
crypto_cipher_free(cipher);
len = ipos_encrypted_size - 2 - client_entries_len - CIPHER_IV_LEN;
- dec = tor_malloc(len);
+ dec = tor_malloc_zero(len + 1);
declen = crypto_cipher_decrypt_with_iv(session_key, dec, len,
ipos_encrypted + 2 + client_entries_len,
ipos_encrypted_size - 2 - client_entries_len);
@@ -5185,7 +5185,7 @@ rend_decrypt_introduction_points(char **ipos_decrypted,
"small.");
return -1;
}
- dec = tor_malloc_zero(ipos_encrypted_size - CIPHER_IV_LEN - 1);
+ dec = tor_malloc_zero(ipos_encrypted_size - CIPHER_IV_LEN - 1 + 1);
declen = crypto_cipher_decrypt_with_iv(descriptor_cookie, dec,
ipos_encrypted_size -