X-Git-Url: https://git.openssl.org/gitweb/?p=openssl.git;a=blobdiff_plain;f=ssl%2Fs3_meth.c;h=cdddb17b627d775dc65f6e5f77810d9f36ecf628;hp=d9cd9c2210130020ddd7f3ebd71ab4ec71e208f7;hb=77a926e6769705944e8ac8db37650cd36161be97;hpb=6b691a5c85ddc4e407e32781841fee5c029506cd diff --git a/ssl/s3_meth.c b/ssl/s3_meth.c index d9cd9c2210..cdddb17b62 100644 --- a/ssl/s3_meth.c +++ b/ssl/s3_meth.c @@ -57,16 +57,11 @@ */ #include -#include "objects.h" +#include #include "ssl_locl.h" -#ifndef NOPROTO -static SSL_METHOD *ssl3_get_method(int ver); -#else -static SSL_METHOD *ssl3_get_method(); -#endif - -static SSL_METHOD *ssl3_get_method(int ver) +static const SSL_METHOD *ssl3_get_method(int ver); +static const SSL_METHOD *ssl3_get_method(int ver) { if (ver == SSL3_VERSION) return(SSLv3_method()); @@ -74,20 +69,9 @@ static SSL_METHOD *ssl3_get_method(int ver) return(NULL); } -SSL_METHOD *SSLv3_method(void) - { - static int init=1; - static SSL_METHOD SSLv3_data; +IMPLEMENT_ssl3_meth_func(SSLv3_method, + ssl3_accept, + ssl3_connect, + ssl3_get_method) - if (init) - { - init=0; - memcpy((char *)&SSLv3_data,(char *)sslv3_base_method(), - sizeof(SSL_METHOD)); - SSLv3_data.ssl_connect=ssl3_connect; - SSLv3_data.ssl_accept=ssl3_accept; - SSLv3_data.get_ssl_method=ssl3_get_method; - } - return(&SSLv3_data); - }