* autoload.cc (std_dll_init): Add a retry loop.
This commit is contained in:
		| @@ -1,3 +1,7 @@ | |||||||
|  | 2010-10-01  Christopher Faylor  <me+cygwin@cgf.cx> | ||||||
|  |  | ||||||
|  | 	* autoload.cc (std_dll_init): Add a retry loop. | ||||||
|  |  | ||||||
| 2010-09-30  Corinna Vinschen  <corinna@vinschen.de> | 2010-09-30  Corinna Vinschen  <corinna@vinschen.de> | ||||||
|  |  | ||||||
| 	* fhandler.cc: Drop including nfs.h. | 	* fhandler.cc: Drop including nfs.h. | ||||||
|   | |||||||
| @@ -208,7 +208,6 @@ union retchain | |||||||
| __attribute__ ((used, noinline)) static long long | __attribute__ ((used, noinline)) static long long | ||||||
| std_dll_init () | std_dll_init () | ||||||
| { | { | ||||||
|   HANDLE h; |  | ||||||
|   struct func_info *func = (struct func_info *) __builtin_return_address (0); |   struct func_info *func = (struct func_info *) __builtin_return_address (0); | ||||||
|   struct dll_info *dll = func->dll; |   struct dll_info *dll = func->dll; | ||||||
|   retchain ret; |   retchain ret; | ||||||
| @@ -222,21 +221,31 @@ std_dll_init () | |||||||
|     while (InterlockedIncrement (&dll->here)); |     while (InterlockedIncrement (&dll->here)); | ||||||
|   else if (!dll->handle) |   else if (!dll->handle) | ||||||
|     { |     { | ||||||
|  |       HANDLE h; | ||||||
|       fenv_t fpuenv; |       fenv_t fpuenv; | ||||||
|       fegetenv (&fpuenv); |       fegetenv (&fpuenv); | ||||||
|       WCHAR dll_path[MAX_PATH]; |       WCHAR dll_path[MAX_PATH]; | ||||||
|       /* http://www.microsoft.com/technet/security/advisory/2269637.mspx */ |       /* http://www.microsoft.com/technet/security/advisory/2269637.mspx */ | ||||||
|       wcpcpy (wcpcpy (dll_path, windows_system_directory), dll->name); |       wcpcpy (wcpcpy (dll_path, windows_system_directory), dll->name); | ||||||
|  |       dll->handle = NULL; | ||||||
|  |       /* MSDN seems to imply that LoadLibrary can fail mysteriously, so, | ||||||
|  | 	 since there have been reports of this in the mailing list, retry | ||||||
|  | 	 several times before giving up.  */ | ||||||
|  |       for (int i = 1; !dll->handle && i <= 5; i++) | ||||||
| 	if ((h = LoadLibraryW (dll_path)) != NULL) | 	if ((h = LoadLibraryW (dll_path)) != NULL) | ||||||
| 	  dll->handle = h; | 	  dll->handle = h; | ||||||
|       else if (!(func->decoration & 1)) |         /* FIXME: This isn't quite right.  Probably should check for specific | ||||||
| 	api_fatal ("could not load %W, %E", dll_path); | 	   error codes. */ | ||||||
|       else | 	else if ((func->decoration & 1)) | ||||||
| 	  dll->handle = INVALID_HANDLE_VALUE; | 	  dll->handle = INVALID_HANDLE_VALUE; | ||||||
|  | 	else if (i < 5) | ||||||
|  | 	  yield (); | ||||||
|  | 	else | ||||||
|  | 	  api_fatal ("could not load %W, %E", dll_path); | ||||||
|       fesetenv (&fpuenv); |       fesetenv (&fpuenv); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   /* Set "arguments for dll_chain. */ |   /* Set "arguments" for dll_chain. */ | ||||||
|   ret.low = (long) dll->init; |   ret.low = (long) dll->init; | ||||||
|   ret.high = (long) func; |   ret.high = (long) func; | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user