* cygthread.cc (cygthread::exit_thread): Define new method.
* cygthread.h (cygthread::exit_thread): Declare new method. * fhandler.h (fhandler_tty_master::hThread): Delete. (fhandler_tty_master::output_thread): Define. * fhandler_tty.cc (fhandler_tty_master::fhandler_tty_master): Adjust constructor. (fhandler_tty_master::init): Use cygthread rather than handle. (process_output): Use cygthread method to exit. (fhandler_tty_master::fixup_after_fork): Set output_thread to NULL after fork. (fhandler_tty_master::fixup_after_exec): Set output_thread to NULL after spawn/exec. * tty.cc (tty_list::terminate): Detach from output_thread using cygthread method.
This commit is contained in:
		| @@ -1,3 +1,20 @@ | |||||||
|  | 2002-08-01  Christopher Faylor  <cgf@redhat.com> | ||||||
|  |  | ||||||
|  | 	* cygthread.cc (cygthread::exit_thread): Define new method. | ||||||
|  | 	* cygthread.h (cygthread::exit_thread): Declare new method. | ||||||
|  | 	* fhandler.h (fhandler_tty_master::hThread): Delete. | ||||||
|  | 	(fhandler_tty_master::output_thread): Define. | ||||||
|  | 	* fhandler_tty.cc (fhandler_tty_master::fhandler_tty_master): Adjust | ||||||
|  | 	constructor. | ||||||
|  | 	(fhandler_tty_master::init): Use cygthread rather than handle. | ||||||
|  | 	(process_output): Use cygthread method to exit. | ||||||
|  | 	(fhandler_tty_master::fixup_after_fork): Set output_thread to NULL | ||||||
|  | 	after fork. | ||||||
|  | 	(fhandler_tty_master::fixup_after_exec): Set output_thread to NULL | ||||||
|  | 	after spawn/exec. | ||||||
|  | 	* tty.cc (tty_list::terminate): Detach from output_thread using | ||||||
|  | 	cygthread method. | ||||||
|  |  | ||||||
| 2002-08-01  Christopher Faylor  <cgf@redhat.com> | 2002-08-01  Christopher Faylor  <cgf@redhat.com> | ||||||
|  |  | ||||||
| 	* syscalls.cc (_link): Revert previous change and just always | 	* syscalls.cc (_link): Revert previous change and just always | ||||||
|   | |||||||
| @@ -147,6 +147,13 @@ HANDLE () | |||||||
|   return ev; |   return ev; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | void | ||||||
|  | cygthread::exit_thread () | ||||||
|  | { | ||||||
|  |   SetEvent (ev); | ||||||
|  |   ExitThread (0); | ||||||
|  | } | ||||||
|  |  | ||||||
| void | void | ||||||
| cygthread::detach () | cygthread::detach () | ||||||
| { | { | ||||||
|   | |||||||
| @@ -27,4 +27,5 @@ class cygthread | |||||||
|   operator HANDLE (); |   operator HANDLE (); | ||||||
|   static bool is (); |   static bool is (); | ||||||
|   void * operator new (size_t); |   void * operator new (size_t); | ||||||
|  |   void exit_thread (); | ||||||
| }; | }; | ||||||
|   | |||||||
| @@ -921,12 +921,13 @@ class fhandler_pty_master: public fhandler_tty_common | |||||||
|   bool hit_eof (); |   bool hit_eof (); | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | class cygthread; | ||||||
| class fhandler_tty_master: public fhandler_pty_master | class fhandler_tty_master: public fhandler_pty_master | ||||||
| { | { | ||||||
|  public: |  public: | ||||||
|   /* Constructor */ |   /* Constructor */ | ||||||
|   fhandler_console *console;	// device handler to perform real i/o. |   fhandler_console *console;	// device handler to perform real i/o. | ||||||
|   HANDLE hThread;		// process_output thread handle. |   cygthread *output_thread;		// process_output thread | ||||||
|  |  | ||||||
|   fhandler_tty_master (int unit); |   fhandler_tty_master (int unit); | ||||||
|   int init (int); |   int init (int); | ||||||
|   | |||||||
| @@ -37,7 +37,7 @@ static DWORD WINAPI process_output (void *);		// Output queue thread | |||||||
| static DWORD WINAPI process_ioctl (void *);		// Ioctl requests thread | static DWORD WINAPI process_ioctl (void *);		// Ioctl requests thread | ||||||
|  |  | ||||||
| fhandler_tty_master::fhandler_tty_master (int unit) | fhandler_tty_master::fhandler_tty_master (int unit) | ||||||
|   : fhandler_pty_master (FH_TTYM, unit), console (NULL), hThread (NULL) |   : fhandler_pty_master (FH_TTYM, unit), console (NULL), output_thread (NULL) | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -69,9 +69,8 @@ fhandler_tty_master::init (int ntty) | |||||||
|   h = new cygthread (process_ioctl, NULL, "ttyioctl"); |   h = new cygthread (process_ioctl, NULL, "ttyioctl"); | ||||||
|   SetThreadPriority (*h, THREAD_PRIORITY_HIGHEST); |   SetThreadPriority (*h, THREAD_PRIORITY_HIGHEST); | ||||||
|  |  | ||||||
|   h = new cygthread (process_output, NULL, "ttyout"); |   output_thread = new cygthread (process_output, NULL, "ttyout"); | ||||||
|   hThread = *h; |   SetThreadPriority (*output_thread, THREAD_PRIORITY_HIGHEST); | ||||||
|   SetThreadPriority (h, THREAD_PRIORITY_HIGHEST); |  | ||||||
|  |  | ||||||
|   return 0; |   return 0; | ||||||
| } | } | ||||||
| @@ -377,15 +376,13 @@ process_output (void *) | |||||||
|   for (;;) |   for (;;) | ||||||
|     { |     { | ||||||
|       int n = tty_master->process_slave_output (buf, OUT_BUFFER_SIZE, 0); |       int n = tty_master->process_slave_output (buf, OUT_BUFFER_SIZE, 0); | ||||||
|  |       if (n <= 0) | ||||||
|  | 	{ | ||||||
| 	  if (n < 0) | 	  if (n < 0) | ||||||
| 	{ |  | ||||||
| 	    termios_printf ("ReadFile %E"); | 	    termios_printf ("ReadFile %E"); | ||||||
| 	  ExitThread (0); | 	  cygthread *t = tty_master->output_thread; | ||||||
| 	} | 	  tty_master->output_thread = NULL; | ||||||
|       if (n == 0) | 	  t->exit_thread (); | ||||||
| 	{ |  | ||||||
| 	  /* End of file.  */ |  | ||||||
| 	  ExitThread (0); |  | ||||||
| 	} | 	} | ||||||
|       n = tty_master->console->write ((void *) buf, (size_t) n); |       n = tty_master->console->write ((void *) buf, (size_t) n); | ||||||
|       tty_master->get_ttyp ()->write_error = n == -1 ? get_errno () : 0; |       tty_master->get_ttyp ()->write_error = n == -1 ? get_errno () : 0; | ||||||
| @@ -1186,6 +1183,7 @@ fhandler_tty_master::fixup_after_fork (HANDLE child) | |||||||
| { | { | ||||||
|   this->fhandler_pty_master::fixup_after_fork (child); |   this->fhandler_pty_master::fixup_after_fork (child); | ||||||
|   console->fixup_after_fork (child); |   console->fixup_after_fork (child); | ||||||
|  |   output_thread = NULL;		// It's unreachable now | ||||||
| } | } | ||||||
|  |  | ||||||
| void | void | ||||||
| @@ -1193,7 +1191,7 @@ fhandler_tty_master::fixup_after_exec (HANDLE) | |||||||
| { | { | ||||||
|   console->close (); |   console->close (); | ||||||
|   init_console (); |   init_console (); | ||||||
|   return; |   output_thread = NULL;		// It's unreachable now | ||||||
| } | } | ||||||
|  |  | ||||||
| int | int | ||||||
|   | |||||||
| @@ -305,10 +305,11 @@ _read (int fd, void *ptr, size_t len) | |||||||
|       DWORD wait = cfd->is_nonblocking () ? 0 : INFINITE; |       DWORD wait = cfd->is_nonblocking () ? 0 : INFINITE; | ||||||
|  |  | ||||||
|       /* Could block, so let user know we at least got here.  */ |       /* Could block, so let user know we at least got here.  */ | ||||||
|       syscall_printf ("read (%d, %p, %d) %sblocking, sigcatchers %d", fd, ptr, len, wait ? "" : "non", sigcatchers); |       syscall_printf ("read (%d, %p, %d) %sblocking, sigcatchers %d", | ||||||
|  | 		      fd, ptr, len, wait ? "" : "non", sigcatchers); | ||||||
|  |  | ||||||
|       if (wait && (!cfd->is_slow () || cfd->get_r_no_interrupt ())) |       if (wait && (!cfd->is_slow () || cfd->get_r_no_interrupt ())) | ||||||
| 	debug_printf ("non-interruptible read\n"); | 	debug_printf ("no need to call ready_for_read\n"); | ||||||
|       else if (!cfd->ready_for_read (fd, wait)) |       else if (!cfd->ready_for_read (fd, wait)) | ||||||
| 	{ | 	{ | ||||||
| 	  res = -1; | 	  res = -1; | ||||||
|   | |||||||
| @@ -25,6 +25,7 @@ details. */ | |||||||
| #include "cygwin/cygserver_transport.h" | #include "cygwin/cygserver_transport.h" | ||||||
| #include "cygwin/cygserver.h" | #include "cygwin/cygserver.h" | ||||||
| #include "shared_info.h" | #include "shared_info.h" | ||||||
|  | #include "cygthread.h" | ||||||
|  |  | ||||||
| extern fhandler_tty_master *tty_master; | extern fhandler_tty_master *tty_master; | ||||||
|  |  | ||||||
| @@ -144,8 +145,8 @@ tty_list::terminate (void) | |||||||
|       ForceCloseHandle1 (t->to_slave, to_pty); |       ForceCloseHandle1 (t->to_slave, to_pty); | ||||||
|       ForceCloseHandle1 (t->from_slave, from_pty); |       ForceCloseHandle1 (t->from_slave, from_pty); | ||||||
|       CloseHandle (tty_master->inuse); |       CloseHandle (tty_master->inuse); | ||||||
|       // FIXME This should be using a cygthread object |       if (tty_master->output_thread) | ||||||
|       WaitForSingleObject (tty_master->hThread, INFINITE); | 	tty_master->output_thread->detach (); | ||||||
|       t->init (); |       t->init (); | ||||||
|  |  | ||||||
|       char buf[20]; |       char buf[20]; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user