bytes_to_long_long isn't used anywhere any more, so let's remove it
[openssl.git] / ssl / t1_srvr.c
index 6e765e587fe6d85fe6796ac3e651fd2076a0d520..1c1149e49fe19b6a956200b96474009ca2418c38 100644 (file)
@@ -80,11 +80,18 @@ SSL_METHOD *TLSv1_server_method(void)
 
        if (init)
                {
-               memcpy((char *)&TLSv1_server_data,(char *)tlsv1_base_method(),
-                       sizeof(SSL_METHOD));
-               TLSv1_server_data.ssl_accept=ssl3_accept;
-               TLSv1_server_data.get_ssl_method=tls1_get_server_method;
-               init=0;
+               CRYPTO_w_lock(CRYPTO_LOCK_SSL_METHOD);
+
+               if (init)
+                       {
+                       memcpy((char *)&TLSv1_server_data,(char *)tlsv1_base_method(),
+                               sizeof(SSL_METHOD));
+                       TLSv1_server_data.ssl_accept=ssl3_accept;
+                       TLSv1_server_data.get_ssl_method=tls1_get_server_method;
+                       init=0;
+                       }
+                       
+               CRYPTO_w_unlock(CRYPTO_LOCK_SSL_METHOD);
                }
        return(&TLSv1_server_data);
        }