Initialize SSL_METHOD structures at compile time. This removes the need
for locking code. The CRYPTO_LOCK_SSL_METHOD lock is now no longer used.
This commit is contained in:
@@ -137,28 +137,10 @@ static SSL_METHOD *ssl2_get_client_method(int ver)
|
||||
return(NULL);
|
||||
}
|
||||
|
||||
SSL_METHOD *SSLv2_client_method(void)
|
||||
{
|
||||
static int init=1;
|
||||
static SSL_METHOD SSLv2_client_data;
|
||||
|
||||
if (init)
|
||||
{
|
||||
CRYPTO_w_lock(CRYPTO_LOCK_SSL_METHOD);
|
||||
|
||||
if (init)
|
||||
{
|
||||
memcpy((char *)&SSLv2_client_data,(char *)sslv2_base_method(),
|
||||
sizeof(SSL_METHOD));
|
||||
SSLv2_client_data.ssl_connect=ssl2_connect;
|
||||
SSLv2_client_data.get_ssl_method=ssl2_get_client_method;
|
||||
init=0;
|
||||
}
|
||||
|
||||
CRYPTO_w_unlock(CRYPTO_LOCK_SSL_METHOD);
|
||||
}
|
||||
return(&SSLv2_client_data);
|
||||
}
|
||||
IMPLEMENT_ssl2_meth_func(SSLv2_client_method,
|
||||
ssl_undefined_function,
|
||||
ssl2_connect,
|
||||
ssl2_get_client_method)
|
||||
|
||||
int ssl2_connect(SSL *s)
|
||||
{
|
||||
|
Reference in New Issue
Block a user