summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2014-06-10 11:17:39 -0400
committerNick Mathewson <nickm@torproject.org>2014-06-10 11:17:39 -0400
commit55c7a559df5f349de21ca37ecfe19b736085c317 (patch)
tree693582eed608c4b806164656d969d0c14a959fe7 /src
parent307aa7eb43c25f0009de33f9aea4376c329b4fe5 (diff)
parentcca6198c777dba463aeb4a8fba6a953cde9576a8 (diff)
downloadtor-55c7a559df5f349de21ca37ecfe19b736085c317.tar.gz
tor-55c7a559df5f349de21ca37ecfe19b736085c317.zip
Merge remote-tracking branch 'public/bug12227_024'
Diffstat (limited to 'src')
-rw-r--r--src/common/tortls.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/src/common/tortls.c b/src/common/tortls.c
index a6444b8188..ea0f21cb27 100644
--- a/src/common/tortls.c
+++ b/src/common/tortls.c
@@ -1477,10 +1477,13 @@ prune_v2_cipher_list(void)
inp = outp = v2_cipher_list;
while (*inp) {
- unsigned char cipherid[2];
+ unsigned char cipherid[3];
const SSL_CIPHER *cipher;
/* Is there no better way to do this? */
set_uint16(cipherid, htons(*inp));
+ cipherid[2] = 0; /* If ssl23_get_cipher_by_char finds no cipher starting
+ * with a two-byte 'cipherid', it may look for a v2
+ * cipher with the appropriate 3 bytes. */
cipher = m->get_cipher_by_char(cipherid);
if (cipher) {
tor_assert((cipher->id & 0xffff) == *inp);