diff options
author | Anatol Belski <ab@php.net> | 2017-02-11 16:46:17 +0100 |
---|---|---|
committer | Anatol Belski <ab@php.net> | 2017-02-11 16:46:17 +0100 |
commit | d94c2c796a1b032d53b382681f8413cc3d02d2da (patch) | |
tree | 997716b336cc7893728936bae36e76d81425b9c8 | |
parent | cefa8ddcc9acc60b2e464b7eac69ee6f25ff19b9 (diff) | |
download | php-git-d94c2c796a1b032d53b382681f8413cc3d02d2da.tar.gz |
move winsock specific stuff into dllmain
-rw-r--r-- | main/main.c | 17 | ||||
-rw-r--r-- | win32/dllmain.c | 13 |
2 files changed, 11 insertions, 19 deletions
diff --git a/main/main.c b/main/main.c index 9e139eff72..daa8235406 100644 --- a/main/main.c +++ b/main/main.c @@ -2057,10 +2057,6 @@ int php_module_startup(sapi_module_struct *sf, zend_module_entry *additional_mod zend_module_entry *module; #ifdef PHP_WIN32 - WORD wVersionRequested = MAKEWORD(2, 0); - WSADATA wsaData; -#endif -#ifdef PHP_WIN32 php_os = "WINNT"; old_invalid_parameter_handler = @@ -2146,14 +2142,6 @@ int php_module_startup(sapi_module_struct *sf, zend_module_entry *additional_mod tzset(); #endif -#ifdef PHP_WIN32 - /* start up winsock services */ - if (WSAStartup(wVersionRequested, &wsaData) != 0) { - php_printf("\nwinsock.dll unusable. %d\n", WSAGetLastError()); - return FAILURE; - } -#endif - le_index_ptr = zend_register_list_destructors_ex(NULL, NULL, "index pointer", 0); /* Register constants */ @@ -2416,11 +2404,6 @@ void php_module_shutdown(void) zend_shutdown(); -#ifdef PHP_WIN32 - /*close winsock */ - WSACleanup(); -#endif - /* Destroys filter & transport registries too */ php_shutdown_stream_wrappers(module_number); diff --git a/win32/dllmain.c b/win32/dllmain.c index 1c34fb1b26..2e5151dcf9 100644 --- a/win32/dllmain.c +++ b/win32/dllmain.c @@ -40,6 +40,9 @@ BOOL WINAPI DllMain(HINSTANCE inst, DWORD reason, LPVOID dummy) switch (reason) { case DLL_PROCESS_ATTACH: + WORD wVersionRequested = MAKEWORD(2, 0); + WSADATA wsaData; + /* * We do not need to check the return value of php_win32_init_gettimeofday() * because the symbol bare minimum symbol we need is always available on our @@ -59,12 +62,18 @@ BOOL WINAPI DllMain(HINSTANCE inst, DWORD reason, LPVOID dummy) fprintf(stderr, "ioutil initialization failed"); return ret; } + + ret = ret && (0 == WSAStartup(wVersionRequested, &wsaData)); + if (!ret) { + fprintf(stderr, "winsock initialization failed %d", WSAGetLastError()); + return ret; + } break; -#if 0 /* prepared */ case DLL_PROCESS_DETACH: - /* pass */ + WSACleanup(); break; +#if 0 /* prepared */ case DLL_THREAD_ATTACH: /* pass */ break; |