X-Git-Url: https://git.openssl.org/gitweb/?p=openssl.git;a=blobdiff_plain;f=ssl%2Fs3_meth.c;h=cdddb17b627d775dc65f6e5f77810d9f36ecf628;hp=3d66b4643aae60a6ebc5a4b4e9831b4511bb2e6c;hb=cb2182676bdf652070bc272a3896d957763a4324;hpb=58964a492275ca9a59a0cd9c8155cb2491b4b909 diff --git a/ssl/s3_meth.c b/ssl/s3_meth.c index 3d66b4643a..cdddb17b62 100644 --- a/ssl/s3_meth.c +++ b/ssl/s3_meth.c @@ -57,11 +57,11 @@ */ #include -#include "objects.h" +#include #include "ssl_locl.h" -static SSL_METHOD *ssl3_get_method(ver) -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()); @@ -69,20 +69,9 @@ int ver; return(NULL); } -SSL_METHOD *SSLv3_method() - { - 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); - }