* 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:
		@@ -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");
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user