From 40f37188a63c988c66bfece95280b67158998e64 Mon Sep 17 00:00:00 2001 From: Matt Caswell Date: Tue, 3 Feb 2015 14:54:13 +0000 Subject: Introduce a DTLS_RECORD_LAYER type for DTLS record layer state Reviewed-by: Richard Levitte --- ssl/d1_lib.c | 10 ++++++++++ 1 file changed, 10 insertions(+) (limited to 'ssl/d1_lib.c') diff --git a/ssl/d1_lib.c b/ssl/d1_lib.c index ad6561cb0d..717925811d 100644 --- a/ssl/d1_lib.c +++ b/ssl/d1_lib.c @@ -131,6 +131,12 @@ int dtls1_new(SSL *s) return (0); } memset(d1, 0, sizeof *d1); + + if(!DTLS_RECORD_LAYER_new(&s->rlayer)) { + OPENSSL_free(d1); + ssl3_free(s); + return 0; + } /* d1->handshake_epoch=0; */ @@ -218,6 +224,8 @@ static void dtls1_clear_queues(SSL *s) void dtls1_free(SSL *s) { + DTLS_RECORD_LAYER_free(&s->rlayer); + ssl3_free(s); dtls1_clear_queues(s); @@ -242,6 +250,8 @@ void dtls1_clear(SSL *s) unsigned int mtu; unsigned int link_mtu; + DTLS_RECORD_LAYER_clear(&s->rlayer); + if (s->d1) { unprocessed_rcds = s->d1->unprocessed_rcds.q; processed_rcds = s->d1->processed_rcds.q; -- cgit v1.2.3