summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAnatol Belski <ab@php.net>2017-02-11 16:46:17 +0100
committerAnatol Belski <ab@php.net>2017-02-11 16:46:17 +0100
commitd94c2c796a1b032d53b382681f8413cc3d02d2da (patch)
tree997716b336cc7893728936bae36e76d81425b9c8
parentcefa8ddcc9acc60b2e464b7eac69ee6f25ff19b9 (diff)
downloadphp-git-d94c2c796a1b032d53b382681f8413cc3d02d2da.tar.gz
move winsock specific stuff into dllmain
-rw-r--r--main/main.c17
-rw-r--r--win32/dllmain.c13
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;