fix more race conditions
Submitted by: "Patrick McCormick" <patrick@tellme.com> PR: 262
This commit is contained in:
parent
ba5ba5490d
commit
929f116733
8
CHANGES
8
CHANGES
@ -1928,10 +1928,10 @@ des-cbc 3624.96k 5258.21k 5530.91k 5624.30k 5628.26k
|
|||||||
[Bodo Moeller]
|
[Bodo Moeller]
|
||||||
|
|
||||||
*) Fix initialization code race conditions in
|
*) Fix initialization code race conditions in
|
||||||
SSLv23_client_method(), SSLv23_server_method(),
|
SSLv23_method(), SSLv23_client_method(), SSLv23_server_method(),
|
||||||
SSLv2_client_method(), SSLv2_server_method(),
|
SSLv2_method(), SSLv2_client_method(), SSLv2_server_method(),
|
||||||
SSLv3_client_method(), SSLv3_server_method(),
|
SSLv3_method(), SSLv3_client_method(), SSLv3_server_method(),
|
||||||
TLSv1_client_method(), TLSv1_server_method(),
|
TLSv1_method(), TLSv1_client_method(), TLSv1_server_method(),
|
||||||
ssl2_get_cipher_by_char(),
|
ssl2_get_cipher_by_char(),
|
||||||
ssl3_get_cipher_by_char().
|
ssl3_get_cipher_by_char().
|
||||||
[Patrick McCormick <patrick@tellme.com>, Bodo Moeller]
|
[Patrick McCormick <patrick@tellme.com>, Bodo Moeller]
|
||||||
|
@ -78,6 +78,10 @@ SSL_METHOD *SSLv23_method(void)
|
|||||||
static int init=1;
|
static int init=1;
|
||||||
static SSL_METHOD SSLv23_data;
|
static SSL_METHOD SSLv23_data;
|
||||||
|
|
||||||
|
if (init)
|
||||||
|
{
|
||||||
|
CRYPTO_w_lock(CRYPTO_LOCK_SSL_METHOD);
|
||||||
|
|
||||||
if (init)
|
if (init)
|
||||||
{
|
{
|
||||||
memcpy((char *)&SSLv23_data,(char *)sslv23_base_method(),
|
memcpy((char *)&SSLv23_data,(char *)sslv23_base_method(),
|
||||||
@ -87,6 +91,9 @@ SSL_METHOD *SSLv23_method(void)
|
|||||||
SSLv23_data.get_ssl_method=ssl23_get_method;
|
SSLv23_data.get_ssl_method=ssl23_get_method;
|
||||||
init=0;
|
init=0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CRYPTO_w_unlock(CRYPTO_LOCK_SSL_METHOD);
|
||||||
|
}
|
||||||
return(&SSLv23_data);
|
return(&SSLv23_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -75,6 +75,10 @@ SSL_METHOD *SSLv2_method(void)
|
|||||||
static int init=1;
|
static int init=1;
|
||||||
static SSL_METHOD SSLv2_data;
|
static SSL_METHOD SSLv2_data;
|
||||||
|
|
||||||
|
if (init)
|
||||||
|
{
|
||||||
|
CRYPTO_w_lock(CRYPTO_LOCK_SSL_METHOD);
|
||||||
|
|
||||||
if (init)
|
if (init)
|
||||||
{
|
{
|
||||||
memcpy((char *)&SSLv2_data,(char *)sslv2_base_method(),
|
memcpy((char *)&SSLv2_data,(char *)sslv2_base_method(),
|
||||||
@ -84,6 +88,9 @@ SSL_METHOD *SSLv2_method(void)
|
|||||||
SSLv2_data.get_ssl_method=ssl2_get_method;
|
SSLv2_data.get_ssl_method=ssl2_get_method;
|
||||||
init=0;
|
init=0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CRYPTO_w_unlock(CRYPTO_LOCK_SSL_METHOD);
|
||||||
|
}
|
||||||
return(&SSLv2_data);
|
return(&SSLv2_data);
|
||||||
}
|
}
|
||||||
#else /* !OPENSSL_NO_SSL2 */
|
#else /* !OPENSSL_NO_SSL2 */
|
||||||
|
@ -74,6 +74,10 @@ SSL_METHOD *SSLv3_method(void)
|
|||||||
static int init=1;
|
static int init=1;
|
||||||
static SSL_METHOD SSLv3_data;
|
static SSL_METHOD SSLv3_data;
|
||||||
|
|
||||||
|
if (init)
|
||||||
|
{
|
||||||
|
CRYPTO_w_lock(CRYPTO_LOCK_SSL_METHOD);
|
||||||
|
|
||||||
if (init)
|
if (init)
|
||||||
{
|
{
|
||||||
memcpy((char *)&SSLv3_data,(char *)sslv3_base_method(),
|
memcpy((char *)&SSLv3_data,(char *)sslv3_base_method(),
|
||||||
@ -83,6 +87,9 @@ SSL_METHOD *SSLv3_method(void)
|
|||||||
SSLv3_data.get_ssl_method=ssl3_get_method;
|
SSLv3_data.get_ssl_method=ssl3_get_method;
|
||||||
init=0;
|
init=0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CRYPTO_w_unlock(CRYPTO_LOCK_SSL_METHOD);
|
||||||
|
}
|
||||||
return(&SSLv3_data);
|
return(&SSLv3_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -74,6 +74,10 @@ SSL_METHOD *TLSv1_method(void)
|
|||||||
static int init=1;
|
static int init=1;
|
||||||
static SSL_METHOD TLSv1_data;
|
static SSL_METHOD TLSv1_data;
|
||||||
|
|
||||||
|
if (init)
|
||||||
|
{
|
||||||
|
CRYPTO_w_lock(CRYPTO_LOCK_SSL_METHOD);
|
||||||
|
|
||||||
if (init)
|
if (init)
|
||||||
{
|
{
|
||||||
memcpy((char *)&TLSv1_data,(char *)tlsv1_base_method(),
|
memcpy((char *)&TLSv1_data,(char *)tlsv1_base_method(),
|
||||||
@ -83,6 +87,10 @@ SSL_METHOD *TLSv1_method(void)
|
|||||||
TLSv1_data.get_ssl_method=tls1_get_method;
|
TLSv1_data.get_ssl_method=tls1_get_method;
|
||||||
init=0;
|
init=0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CRYPTO_w_unlock(CRYPTO_LOCK_SSL_METHOD);
|
||||||
|
}
|
||||||
|
|
||||||
return(&TLSv1_data);
|
return(&TLSv1_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user