Mail Archives: cygwin/2002/06/04/11:07:33
Ah the additional handles come from this.
fork call CreateProcess as follows
rc = CreateProcess (myself->progname, /* image to run */
myself->progname, /* what we send in arg0 */
sec_attribs,
sec_attribs,
TRUE, /* inherit handles from parent */
c_flags,
NULL, /* environment filled in later */
0, /* use current drive/directory */
&si,
&pi);
notice the inherit handles from parent,
fixup_before_fork calls,
WSADuplicateSocketA (get_socket (), win_proc_id, prot_info_ptr)
now this doesn't actually create a new handle. It just stores the info in
prot_info_ptr,
but fixup_after_fork calls,
new_sock = WSASocketA (FROM_PROTOCOL_INFO,
FROM_PROTOCOL_INFO,
FROM_PROTOCOL_INFO,
prot_info_ptr, 0, 0)
and this creates the new handle,
then set_io_handle ((HANDLE) new_sock);
and the old handle disappears into oblivion.
I don't know why it's written this way. It would seem easier to just use
the same Duplicated handle from the CreateProcess. I'm thinking that
maybe on Win9x it doesn't work the same (but I haven't even tested it)
Hope this helps.
David
--
Unsubscribe info: http://cygwin.com/ml/#unsubscribe-simple
Bug reporting: http://cygwin.com/bugs.html
Documentation: http://cygwin.com/docs.html
FAQ: http://cygwin.com/faq/
- Raw text -