Fixed memory leak in ssl_free() and ssl_reset() for active session
diff --git a/library/ssl_tls.c b/library/ssl_tls.c
index 4194ac0..44cb92b 100644
--- a/library/ssl_tls.c
+++ b/library/ssl_tls.c
@@ -3025,6 +3025,13 @@
ssl->transform = NULL;
}
+ if( ssl->session )
+ {
+ ssl_session_free( ssl->session );
+ free( ssl->session );
+ ssl->session = NULL;
+ }
+
if( ( ret = ssl_handshake_init( ssl ) ) != 0 )
return( ret );
@@ -3891,6 +3898,12 @@
free( ssl->session_negotiate );
}
+ if( ssl->session )
+ {
+ ssl_session_free( ssl->session );
+ free( ssl->session );
+ }
+
if ( ssl->hostname != NULL)
{
memset( ssl->hostname, 0, ssl->hostname_len );