Fix memory leak on missed session reuse
diff --git a/library/ssl_tls.c b/library/ssl_tls.c
index 2095424..910205e 100644
--- a/library/ssl_tls.c
+++ b/library/ssl_tls.c
@@ -2461,6 +2461,13 @@
return( POLARSSL_ERR_SSL_BAD_HS_CERTIFICATE );
}
+ /* In case we tried to reuse a session but it failed */
+ if( ssl->session_negotiate->peer_cert != NULL )
+ {
+ x509_free( ssl->session_negotiate->peer_cert );
+ polarssl_free( ssl->session_negotiate->peer_cert );
+ }
+
if( ( ssl->session_negotiate->peer_cert = (x509_cert *) polarssl_malloc(
sizeof( x509_cert ) ) ) == NULL )
{