[3/6] winhttp: Clean up locks after closing libssl and libcrypto.
Hans Leidekker
hans at codeweavers.com
Tue Oct 27 04:04:05 CDT 2009
SSL_CTX_free() triggers a call to the locking callback.
Found by valgrind.
---
dlls/winhttp/net.c | 13 ++++++-------
1 files changed, 6 insertions(+), 7 deletions(-)
diff --git a/dlls/winhttp/net.c b/dlls/winhttp/net.c
index 28b3972..53911d6 100644
--- a/dlls/winhttp/net.c
+++ b/dlls/winhttp/net.c
@@ -316,13 +316,6 @@ void netconn_unload( void )
#if defined(SONAME_LIBSSL) && defined(SONAME_LIBCRYPTO)
if (libcrypto_handle)
{
- if (ssl_locks)
- {
- int i;
-
- for (i = 0; i < num_ssl_locks; i++) DeleteCriticalSection( &ssl_locks[i] );
- HeapFree( GetProcessHeap(), 0, ssl_locks );
- }
wine_dlclose( libcrypto_handle, NULL, 0 );
}
if (libssl_handle)
@@ -331,6 +324,12 @@ void netconn_unload( void )
pSSL_CTX_free( ctx );
wine_dlclose( libssl_handle, NULL, 0 );
}
+ if (ssl_locks)
+ {
+ int i;
+ for (i = 0; i < num_ssl_locks; i++) DeleteCriticalSection( &ssl_locks[i] );
+ HeapFree( GetProcessHeap(), 0, ssl_locks );
+ }
#endif
}
--
1.6.3.3
More information about the wine-patches
mailing list