X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=ssl%2Ft1_meth.c;h=53c807de28097b0a008ddb8bd689fac179d0a94f;hb=a54ce007e677ddd3a0cc4a3e4b47e823076117fa;hp=d64b5f4e679e23da1a4167a9f884a1e94b2eefb0;hpb=9b3086fe382e7b0f53b8634d0e75f1a659ab2653;p=oweals%2Fopenssl.git diff --git a/ssl/t1_meth.c b/ssl/t1_meth.c index d64b5f4e67..53c807de28 100644 --- a/ssl/t1_meth.c +++ b/ssl/t1_meth.c @@ -57,38 +57,32 @@ */ #include -#include "objects.h" +#include #include "ssl_locl.h" -#ifndef NOPROTO -static SSL_METHOD *tls1_get_method(int ver); -#else -static SSL_METHOD *tls1_get_method(); -#endif - -static SSL_METHOD *tls1_get_method(ver) -int ver; +static const SSL_METHOD *tls1_get_method(int ver) { + if (ver == TLS1_2_VERSION) + return TLSv1_2_method(); + if (ver == TLS1_1_VERSION) + return TLSv1_1_method(); if (ver == TLS1_VERSION) - return(TLSv1_method()); - else - return(NULL); + return TLSv1_method(); + return NULL; } -SSL_METHOD *TLSv1_method() - { - static int init=1; - static SSL_METHOD TLSv1_data; +IMPLEMENT_tls_meth_func(TLS1_2_VERSION, TLSv1_2_method, + ssl3_accept, + ssl3_connect, + tls1_get_method) - if (init) - { - init=0; - memcpy((char *)&TLSv1_data,(char *)tlsv1_base_method(), - sizeof(SSL_METHOD)); - TLSv1_data.ssl_connect=ssl3_connect; - TLSv1_data.ssl_accept=ssl3_accept; - TLSv1_data.get_ssl_method=tls1_get_method; - } - return(&TLSv1_data); - } +IMPLEMENT_tls_meth_func(TLS1_1_VERSION, TLSv1_1_method, + ssl3_accept, + ssl3_connect, + tls1_get_method) + +IMPLEMENT_tls_meth_func(TLS1_VERSION, TLSv1_method, + ssl3_accept, + ssl3_connect, + tls1_get_method)