throughout. * tty.cc (tty::common_init): Remove call to SetKernelObjectSecurity and edit some comments. * cygheap.h (init_cygheap::ctty): Add new element. * devices.in (device::parse): Remove special handling for /dev/tty. * devices.cc: Regenerate. * dtable.cc (build_fh_pc): Don't reset /dev/tty device. Let the device opener do that. * fhandler_termios.cc (tty_min::set_ctty): Redefine to _pinfo class. * fhandler_tty.cc (fhandler_tty_common::set_close_on_exec): Avoid setting noninherit flag for ctty. * tty.h: Move BOOLs to bools. (tty_min::set_ctty): Redeclare to _pinfo class. * pinfo.cc (_pinfo::set_ctty): Define new function based on tty_min::set_ctty. Change first argument from tty number to tty_min class. * pinfo.h (_pinfo::set_ctty): Declare. * fhandler_console.cc (fhandler_console::get_tty_stuff): Reflect move of set_ctty to _pinfo class. * fhandler_tty.cc (fhandler_tty_slave::open): Treat FH_TTY specially. Use saved cygheap value if it exists. Otherwise convert to real device and save on first time open. (fhandler_tty_common::dup): Potentially set controlling tty if duping a slave tty. * syscalls.cc (setsid): Close controlling tty in cygheap. * tty.cc: Change some BOOLs to bools.
		
			
				
	
	
		
			95 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			95 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /* sigproc.h
 | |
| 
 | |
|    Copyright 1997, 1998, 2000, 2001, 2002, 2003 Red Hat, Inc.
 | |
| 
 | |
| This file is part of Cygwin.
 | |
| 
 | |
| This software is a copyrighted work licensed under the terms of the
 | |
| Cygwin license.  Please consult the file "CYGWIN_LICENSE" for
 | |
| details. */
 | |
| 
 | |
| #ifndef _SIGPROC_H
 | |
| #define _SIGPROC_H
 | |
| #include <signal.h>
 | |
| 
 | |
| #define EXIT_SIGNAL	 0x010000
 | |
| #define EXIT_REPARENTING 0x020000
 | |
| #define EXIT_NOCLOSEALL  0x040000
 | |
| 
 | |
| #ifdef NSIG
 | |
| enum
 | |
| {
 | |
|   __SIGFLUSH	    = -(NSIG + 1),
 | |
|   __SIGSTRACE	    = -(NSIG + 2),
 | |
|   __SIGCOMMUNE	    = -(NSIG + 3),
 | |
|   __SIGPENDING	    = -(NSIG + 4)
 | |
| };
 | |
| #endif
 | |
| 
 | |
| #define SIG_BAD_MASK (1 << (SIGKILL - 1))
 | |
| 
 | |
| enum procstuff
 | |
| {
 | |
|   PROC_ADDCHILD		= 1,	// add a new subprocess to list
 | |
|   PROC_CHILDTERMINATED	= 2,	// a child died
 | |
|   PROC_CLEARWAIT	= 3,	// clear all waits - signal arrived
 | |
|   PROC_WAIT		= 4,	// setup for wait() for subproc
 | |
|   PROC_NOTHING		= 5	// nothing, really
 | |
| };
 | |
| 
 | |
| typedef struct struct_waitq
 | |
| {
 | |
|   int pid;
 | |
|   int options;
 | |
|   int status;
 | |
|   HANDLE ev;
 | |
|   void *rusage;			/* pointer to potential rusage */
 | |
|   struct struct_waitq *next;
 | |
|   HANDLE thread_ev;
 | |
| } waitq;
 | |
| 
 | |
| extern HANDLE signal_arrived;
 | |
| extern HANDLE sigCONT;
 | |
| 
 | |
| bool __stdcall my_parent_is_alive ();
 | |
| int __stdcall sig_dispatch_pending ();
 | |
| #ifdef _PINFO_H
 | |
| extern "C" void __stdcall set_signal_mask (sigset_t newmask, sigset_t& = myself->getsigmask ());
 | |
| #endif
 | |
| int __stdcall handle_sigprocmask (int sig, const sigset_t *set,
 | |
| 				  sigset_t *oldset, sigset_t& opmask)
 | |
|   __attribute__ ((regparm (3)));
 | |
| 
 | |
| extern "C" void __stdcall reset_signal_arrived ();
 | |
| extern "C" int __stdcall call_signal_handler_now ();
 | |
| #ifdef _CYGTLS_H
 | |
| int __stdcall sig_handle (int, sigset_t, int, _threadinfo *) __attribute__ ((regparm (3)));
 | |
| #endif
 | |
| void __stdcall sig_clear (int) __attribute__ ((regparm (1)));
 | |
| void __stdcall sig_set_pending (int) __attribute__ ((regparm (1)));
 | |
| int __stdcall handle_sigsuspend (sigset_t);
 | |
| 
 | |
| int __stdcall proc_subproc (DWORD, DWORD) __attribute__ ((regparm (2)));
 | |
| 
 | |
| class _pinfo;
 | |
| void __stdcall proc_terminate ();
 | |
| void __stdcall sigproc_init ();
 | |
| void __stdcall subproc_init ();
 | |
| void __stdcall sigproc_terminate ();
 | |
| bool __stdcall proc_exists (_pinfo *) __attribute__ ((regparm(1)));
 | |
| bool __stdcall pid_exists (pid_t) __attribute__ ((regparm(1)));
 | |
| int __stdcall sig_send (_pinfo *, int, void * = NULL) __attribute__ ((regparm(3)));
 | |
| void __stdcall signal_fixup_after_fork ();
 | |
| void __stdcall signal_fixup_after_exec ();
 | |
| void __stdcall wait_for_sigthread ();
 | |
| void __stdcall sigalloc ();
 | |
| 
 | |
| extern char myself_nowait_dummy[];
 | |
| 
 | |
| extern struct sigaction *global_sigs;
 | |
| 
 | |
| #define WAIT_SIG_PRIORITY THREAD_PRIORITY_TIME_CRITICAL
 | |
| 
 | |
| #define myself_nowait ((_pinfo *)myself_nowait_dummy)
 | |
| #endif /*_SIGPROC_H*/
 |