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:
46
ssl/d1_lib.c
46
ssl/d1_lib.c
@@ -63,9 +63,7 @@
|
||||
|
||||
const char *dtls1_version_str="DTLSv1" OPENSSL_VERSION_PTEXT;
|
||||
|
||||
static long dtls1_default_timeout(void);
|
||||
|
||||
static SSL3_ENC_METHOD DTLSv1_enc_data={
|
||||
SSL3_ENC_METHOD DTLSv1_enc_data={
|
||||
dtls1_enc,
|
||||
tls1_mac,
|
||||
tls1_setup_key_block,
|
||||
@@ -79,49 +77,17 @@ static SSL3_ENC_METHOD DTLSv1_enc_data={
|
||||
tls1_alert_code,
|
||||
};
|
||||
|
||||
static SSL_METHOD DTLSv1_data= {
|
||||
DTLS1_VERSION,
|
||||
dtls1_new,
|
||||
dtls1_clear,
|
||||
dtls1_free,
|
||||
ssl_undefined_function,
|
||||
ssl_undefined_function,
|
||||
ssl3_read,
|
||||
ssl3_peek,
|
||||
ssl3_write,
|
||||
ssl3_shutdown,
|
||||
ssl3_renegotiate,
|
||||
ssl3_renegotiate_check,
|
||||
dtls1_get_message,
|
||||
dtls1_read_bytes,
|
||||
dtls1_write_app_data_bytes,
|
||||
dtls1_dispatch_alert,
|
||||
ssl3_ctrl,
|
||||
ssl3_ctx_ctrl,
|
||||
ssl3_get_cipher_by_char,
|
||||
ssl3_put_cipher_by_char,
|
||||
ssl3_pending,
|
||||
ssl3_num_ciphers,
|
||||
ssl3_get_cipher,
|
||||
ssl_bad_method,
|
||||
dtls1_default_timeout,
|
||||
&DTLSv1_enc_data,
|
||||
ssl_undefined_void_function,
|
||||
ssl3_callback_ctrl,
|
||||
ssl3_ctx_callback_ctrl,
|
||||
};
|
||||
|
||||
static long dtls1_default_timeout(void)
|
||||
long dtls1_default_timeout(void)
|
||||
{
|
||||
/* 2 hours, the 24 hours mentioned in the DTLSv1 spec
|
||||
* is way too long for http, the cache would over fill */
|
||||
return(60*60*2);
|
||||
}
|
||||
|
||||
SSL_METHOD *dtlsv1_base_method(void)
|
||||
{
|
||||
return(&DTLSv1_data);
|
||||
}
|
||||
IMPLEMENT_dtls1_meth_func(dtls1_base_method,
|
||||
ssl_undefined_function,
|
||||
ssl_undefined_function,
|
||||
ssl_bad_method)
|
||||
|
||||
int dtls1_new(SSL *s)
|
||||
{
|
||||
|
Reference in New Issue
Block a user