PRB: Spawn with _P_WAIT Returns Immediately on Win32s (125213)
The information in this article applies to:
- The C Run-Time (CRT), when used with:
- Microsoft Visual C++, 32-bit Editions 1.0
- Microsoft Visual C++, 32-bit Editions 2.0
- Microsoft Visual C++, 32-bit Editions 2.1
- Microsoft Visual C++, 32-bit Editions 2.2
- Microsoft Visual C++, 32-bit Editions 4.0
- Microsoft Visual C++, 32-bit Editions 4.1
This article was previously published under Q125213 SYMPTOMS
If you call _spawnl() with _P_WAIT from a Win32-based application, then
under Windows NT, the call returns after the spawned application has been
terminated. But under Win32s, the call returns immediately, even though the
spawned application is still running.
The return value from _spawnl() with _P_WAIT is zero if the spawned
application is a 16-bit Windows-based application or 0x103 if the
application is a Win32-based application.
CAUSE
This is due to the design of the C Run-time and a limitation of Win32s.
When the CRT does a _P_WAIT spawn, it calls CreateProcess() and checks for
failure. Next, the CRT calls WaitForSingleObject() on the process handle.
Under Windows NT, WaitForSingleObject() pauses the application until the
new process terminates, and then returns TRUE. But under Win32s,
WaitForSingleObject() returns TRUE immediately. Next, the CRT calls
GetExitCodeProcess() to find the exit status. It is a limitation that
GetExitCodeProcess() returns zero for 16-bit Windows-based application on
both Windows NT and Win32s. The return value of 0x103 for Win32-based
applications is incorrect because the application has not yet terminated.
RESOLUTION
There is no way to perform the synchronous spawn with the spawn family
of functions on Win32s. You can only perform an asynchronous spawn.
For an example of a synchronous spawn under Win32s using the Win32 API
and the Universal Thunk, please see the following article in the Microsoft
Knowledge Base:
125212 Performing a Synchronous Spawn Under Win32s
Modification Type: | Major | Last Reviewed: | 12/9/2003 |
---|
Keywords: | kbCRT kbprb KB125213 |
---|
|