* fhandler.cc (fhandler_base::fork_fixup): Protect dup'ed handle and record it
as non-inheritable for debugging purposes in case there is a subsequent fork or exec. * fhandler_tty.cc (fhandler_tty_common::fixup_after_fork): Allow fork_fixup to call ProtecHandle.
This commit is contained in:
parent
3cf6936e3b
commit
a448b8cf34
@ -1,3 +1,11 @@
|
||||
Fri Oct 5 21:01:14 2001 Christopher Faylor <cgf@cygnus.com>
|
||||
|
||||
* fhandler.cc (fhandler_base::fork_fixup): Protect dup'ed handle and
|
||||
record it as non-inheritable for debugging purposes in case there is a
|
||||
subsequent fork or exec.
|
||||
* fhandler_tty.cc (fhandler_tty_common::fixup_after_fork): Allow
|
||||
fork_fixup to call ProtecHandle.
|
||||
|
||||
Fri Oct 5 14:22:47 2001 Christopher Faylor <cgf@cygnus.com>
|
||||
|
||||
* path.cc (get_raw_device_number): Correct length arguments for
|
||||
|
@ -1624,9 +1624,16 @@ fhandler_base::fork_fixup (HANDLE parent, HANDLE &h, const char *name)
|
||||
{
|
||||
if (!get_close_on_exec ())
|
||||
debug_printf ("handle %p already opened", h);
|
||||
else if (!DuplicateHandle (parent, h, hMainProc, &h, 0, !get_close_on_exec (),
|
||||
DUPLICATE_SAME_ACCESS))
|
||||
else if (!DuplicateHandle (parent, h, hMainProc, &h, 0, 0,
|
||||
DUPLICATE_SAME_ACCESS))
|
||||
system_printf ("%s - %E, handle %s<%p>", get_name (), name, h);
|
||||
#ifdef DEBUG
|
||||
else
|
||||
{
|
||||
ProtectHandle1 (h, name);
|
||||
setclexec_pid (h, 0);
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
void
|
||||
|
@ -1143,15 +1143,9 @@ fhandler_tty_common::fixup_after_fork (HANDLE parent)
|
||||
if (ioctl_done_event)
|
||||
fork_fixup (parent, ioctl_done_event, "ioctl_done_event");
|
||||
if (output_mutex)
|
||||
{
|
||||
fork_fixup (parent, output_mutex, "output_mutex");
|
||||
ProtectHandle (output_mutex);
|
||||
}
|
||||
fork_fixup (parent, output_mutex, "output_mutex");
|
||||
if (input_mutex)
|
||||
{
|
||||
fork_fixup (parent, input_mutex, "input_mutex");
|
||||
ProtectHandle (input_mutex);
|
||||
}
|
||||
fork_fixup (parent, input_mutex, "input_mutex");
|
||||
if (input_available_event)
|
||||
fork_fixup (parent, input_available_event, "input_available_event");
|
||||
fork_fixup (parent, inuse, "inuse");
|
||||
|
Loading…
x
Reference in New Issue
Block a user