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 *dtls1_get_server_method(int ver)
|
||||
return(NULL);
|
||||
}
|
||||
|
||||
SSL_METHOD *DTLSv1_server_method(void)
|
||||
{
|
||||
static int init=1;
|
||||
static SSL_METHOD DTLSv1_server_data;
|
||||
|
||||
if (init)
|
||||
{
|
||||
CRYPTO_w_lock(CRYPTO_LOCK_SSL_METHOD);
|
||||
|
||||
if (init)
|
||||
{
|
||||
memcpy((char *)&DTLSv1_server_data,(char *)dtlsv1_base_method(),
|
||||
sizeof(SSL_METHOD));
|
||||
DTLSv1_server_data.ssl_accept=dtls1_accept;
|
||||
DTLSv1_server_data.get_ssl_method=dtls1_get_server_method;
|
||||
init=0;
|
||||
}
|
||||
|
||||
CRYPTO_w_unlock(CRYPTO_LOCK_SSL_METHOD);
|
||||
}
|
||||
return(&DTLSv1_server_data);
|
||||
}
|
||||
IMPLEMENT_dtls1_meth_func(DTLSv1_server_method,
|
||||
dtls1_accept,
|
||||
ssl_undefined_function,
|
||||
dtls1_get_server_method)
|
||||
|
||||
int dtls1_accept(SSL *s)
|
||||
{
|
||||
|
Reference in New Issue
Block a user