Break out DllMain from crypto/cryptlib.c and use it in shared libs only
Reviewed-by: Andy Polyakov <appro@openssl.org>
This commit is contained in:
parent
2a08d1a05d
commit
84af71a916
3 changed files with 55 additions and 49 deletions
|
@ -31,3 +31,7 @@ GENERATE[arm64cpuid.S]=arm64cpuid.pl $(PERLASM_SCHEME)
|
||||||
INCLUDE[arm64cpuid.o]=.
|
INCLUDE[arm64cpuid.o]=.
|
||||||
GENERATE[armv4cpuid.S]=armv4cpuid.pl $(PERLASM_SCHEME)
|
GENERATE[armv4cpuid.S]=armv4cpuid.pl $(PERLASM_SCHEME)
|
||||||
INCLUDE[armv4cpuid.o]=.
|
INCLUDE[armv4cpuid.o]=.
|
||||||
|
|
||||||
|
IF[{- $config{target} =~ /^(?:Cygwin|mingw|VC-)/ -}]
|
||||||
|
SHARED_SOURCE[../libcrypto]=dllmain.c
|
||||||
|
ENDIF
|
||||||
|
|
|
@ -195,55 +195,6 @@ void OPENSSL_cpuid_setup(void)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (defined(_WIN32) || defined(__CYGWIN__)) && defined(_WINDLL)
|
|
||||||
# ifdef __CYGWIN__
|
|
||||||
/* pick DLL_[PROCESS|THREAD]_[ATTACH|DETACH] definitions */
|
|
||||||
# include <windows.h>
|
|
||||||
/*
|
|
||||||
* this has side-effect of _WIN32 getting defined, which otherwise is
|
|
||||||
* mutually exclusive with __CYGWIN__...
|
|
||||||
*/
|
|
||||||
# endif
|
|
||||||
|
|
||||||
/*
|
|
||||||
* All we really need to do is remove the 'error' state when a thread
|
|
||||||
* detaches
|
|
||||||
*/
|
|
||||||
|
|
||||||
BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved);
|
|
||||||
BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved)
|
|
||||||
{
|
|
||||||
switch (fdwReason) {
|
|
||||||
case DLL_PROCESS_ATTACH:
|
|
||||||
OPENSSL_cpuid_setup();
|
|
||||||
# if defined(_WIN32_WINNT)
|
|
||||||
{
|
|
||||||
IMAGE_DOS_HEADER *dos_header = (IMAGE_DOS_HEADER *) hinstDLL;
|
|
||||||
IMAGE_NT_HEADERS *nt_headers;
|
|
||||||
|
|
||||||
if (dos_header->e_magic == IMAGE_DOS_SIGNATURE) {
|
|
||||||
nt_headers = (IMAGE_NT_HEADERS *) ((char *)dos_header
|
|
||||||
+ dos_header->e_lfanew);
|
|
||||||
if (nt_headers->Signature == IMAGE_NT_SIGNATURE &&
|
|
||||||
hinstDLL !=
|
|
||||||
(HINSTANCE) (nt_headers->OptionalHeader.ImageBase))
|
|
||||||
OPENSSL_NONPIC_relocated = 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
# endif
|
|
||||||
break;
|
|
||||||
case DLL_THREAD_ATTACH:
|
|
||||||
break;
|
|
||||||
case DLL_THREAD_DETACH:
|
|
||||||
OPENSSL_thread_stop();
|
|
||||||
break;
|
|
||||||
case DLL_PROCESS_DETACH:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return (TRUE);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(_WIN32) && !defined(__CYGWIN__)
|
#if defined(_WIN32) && !defined(__CYGWIN__)
|
||||||
# include <tchar.h>
|
# include <tchar.h>
|
||||||
# include <signal.h>
|
# include <signal.h>
|
||||||
|
|
51
crypto/dllmain.c
Normal file
51
crypto/dllmain.c
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
#include "internal/cryptlib_int.h"
|
||||||
|
|
||||||
|
#if defined(_WIN32) || defined(__CYGWIN__)
|
||||||
|
# ifdef __CYGWIN__
|
||||||
|
/* pick DLL_[PROCESS|THREAD]_[ATTACH|DETACH] definitions */
|
||||||
|
# include <windows.h>
|
||||||
|
/*
|
||||||
|
* this has side-effect of _WIN32 getting defined, which otherwise is
|
||||||
|
* mutually exclusive with __CYGWIN__...
|
||||||
|
*/
|
||||||
|
# endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* All we really need to do is remove the 'error' state when a thread
|
||||||
|
* detaches
|
||||||
|
*/
|
||||||
|
|
||||||
|
BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved);
|
||||||
|
BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved)
|
||||||
|
{
|
||||||
|
switch (fdwReason) {
|
||||||
|
case DLL_PROCESS_ATTACH:
|
||||||
|
OPENSSL_cpuid_setup();
|
||||||
|
# if defined(_WIN32_WINNT)
|
||||||
|
{
|
||||||
|
IMAGE_DOS_HEADER *dos_header = (IMAGE_DOS_HEADER *) hinstDLL;
|
||||||
|
IMAGE_NT_HEADERS *nt_headers;
|
||||||
|
|
||||||
|
if (dos_header->e_magic == IMAGE_DOS_SIGNATURE) {
|
||||||
|
nt_headers = (IMAGE_NT_HEADERS *) ((char *)dos_header
|
||||||
|
+ dos_header->e_lfanew);
|
||||||
|
if (nt_headers->Signature == IMAGE_NT_SIGNATURE &&
|
||||||
|
hinstDLL !=
|
||||||
|
(HINSTANCE) (nt_headers->OptionalHeader.ImageBase))
|
||||||
|
OPENSSL_NONPIC_relocated = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
# endif
|
||||||
|
break;
|
||||||
|
case DLL_THREAD_ATTACH:
|
||||||
|
break;
|
||||||
|
case DLL_THREAD_DETACH:
|
||||||
|
OPENSSL_thread_stop();
|
||||||
|
break;
|
||||||
|
case DLL_PROCESS_DETACH:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return (TRUE);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue