diff options
author | Dr. Stephen Henson <steve@openssl.org> | 2011-07-20 15:17:20 +0000 |
---|---|---|
committer | Dr. Stephen Henson <steve@openssl.org> | 2011-07-20 15:17:20 +0000 |
commit | ac02a4b68a77a8a6d9248cb0eb1542f8303cd23d (patch) | |
tree | 70f91dab79f7fd2fa2bfd5d45a8790972b4c5e1d /ssl | |
parent | 4ba063d3c5c133b9cfe2b2312ee20672f24ef95c (diff) |
PR: 2555
Submitted by: Robin Seggelmann <seggelmann@fh-muenster.de>
Reviewed by: steve
Fix DTLS sequence number bug
Diffstat (limited to 'ssl')
-rw-r--r-- | ssl/d1_srvr.c | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/ssl/d1_srvr.c b/ssl/d1_srvr.c index 2736c26e8e..c3144da0c2 100644 --- a/ssl/d1_srvr.c +++ b/ssl/d1_srvr.c @@ -165,6 +165,8 @@ int dtls1_accept(SSL *s) s->in_handshake++; if (!SSL_in_init(s) || SSL_in_before(s)) SSL_clear(s); + s->d1->listen = listen; + if (s->cert == NULL) { SSLerr(SSL_F_DTLS1_ACCEPT,SSL_R_NO_CERTIFICATE_SET); @@ -274,6 +276,12 @@ int dtls1_accept(SSL *s) s->init_num=0; + /* Reflect ClientHello sequence to remain stateless while listening */ + if (listen) + { + memcpy(s->s3->write_sequence, s->s3->read_sequence, sizeof(s->s3->write_sequence)); + } + /* If we're just listening, stop here */ if (listen && s->state == SSL3_ST_SW_SRVR_HELLO_A) { |