Generate SIGHUP for terminal process group on tty master close
* fhandler_tty.cc (fhandler_pty_slave::write): Move causing of SIGHUP into fhandler_pty_master::close(). (fhandler_pty_slave::read): Ditto. (fhandler_pty_master::close): Ditto. Signed-off-by: Corinna Vinschen <corinna@vinschen.de>
This commit is contained in:
		
				
					committed by
					
						 Corinna Vinschen
						Corinna Vinschen
					
				
			
			
				
	
			
			
			
						parent
						
							4c3946c350
						
					
				
				
					commit
					511eb2f264
				
			| @@ -1,3 +1,10 @@ | |||||||
|  | 2015-06-08  Takashi Yano  <takashi.yano@nifty.ne.jp> | ||||||
|  |  | ||||||
|  | 	* fhandler_tty.cc (fhandler_pty_slave::write): Move causing of SIGHUP | ||||||
|  | 	into fhandler_pty_master::close(). | ||||||
|  | 	(fhandler_pty_slave::read): Ditto. | ||||||
|  | 	(fhandler_pty_master::close): Ditto. | ||||||
|  |  | ||||||
| 2015-06-08  Corinna Vinschen  <corinna@vinschen.de> | 2015-06-08  Corinna Vinschen  <corinna@vinschen.de> | ||||||
|  |  | ||||||
| 	* include/cygwin/version.h (CYGWIN_VERSION_DLL_MINOR): Bump to 4. | 	* include/cygwin/version.h (CYGWIN_VERSION_DLL_MINOR): Bump to 4. | ||||||
|   | |||||||
| @@ -622,7 +622,6 @@ fhandler_pty_slave::write (const void *ptr, size_t len) | |||||||
| 	default: | 	default: | ||||||
| 	  __seterrno_from_win_error (err); | 	  __seterrno_from_win_error (err); | ||||||
| 	} | 	} | ||||||
|       raise (SIGHUP);		/* FIXME: Should this be SIGTTOU? */ |  | ||||||
|       towrite = -1; |       towrite = -1; | ||||||
|     } |     } | ||||||
|   return towrite; |   return towrite; | ||||||
| @@ -749,7 +748,12 @@ fhandler_pty_slave::read (void *ptr, size_t& len) | |||||||
| 	  goto out; | 	  goto out; | ||||||
| 	} | 	} | ||||||
|       if (!bytes_available (bytes_in_pipe)) |       if (!bytes_available (bytes_in_pipe)) | ||||||
| 	raise (SIGHUP); | 	{ | ||||||
|  | 	  ReleaseMutex (input_mutex); | ||||||
|  | 	  set_errno (EIO); | ||||||
|  | 	  totalread = -1; | ||||||
|  | 	  goto out; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|       /* On first peek determine no. of bytes to flush. */ |       /* On first peek determine no. of bytes to flush. */ | ||||||
|       if (!ptr && len == UINT_MAX) |       if (!ptr && len == UINT_MAX) | ||||||
| @@ -779,9 +783,10 @@ fhandler_pty_slave::read (void *ptr, size_t& len) | |||||||
| 	  if (!ReadFile (get_handle (), buf, readlen, &n, NULL)) | 	  if (!ReadFile (get_handle (), buf, readlen, &n, NULL)) | ||||||
| 	    { | 	    { | ||||||
| 	      termios_printf ("read failed, %E"); | 	      termios_printf ("read failed, %E"); | ||||||
| 	      raise (SIGHUP); | 	      ReleaseMutex (input_mutex); | ||||||
| 	      bytes_in_pipe = 0; | 	      set_errno (EIO); | ||||||
| 	      ptr = NULL; | 	      totalread = -1; | ||||||
|  | 	      goto out; | ||||||
| 	    } | 	    } | ||||||
| 	  else | 	  else | ||||||
| 	    { | 	    { | ||||||
| @@ -790,7 +795,12 @@ fhandler_pty_slave::read (void *ptr, size_t& len) | |||||||
| 		 change after successful read. So we have to peek into the pipe | 		 change after successful read. So we have to peek into the pipe | ||||||
| 		 again to see if input is still available */ | 		 again to see if input is still available */ | ||||||
| 	      if (!bytes_available (bytes_in_pipe)) | 	      if (!bytes_available (bytes_in_pipe)) | ||||||
| 		raise (SIGHUP); | 		{ | ||||||
|  | 		  ReleaseMutex (input_mutex); | ||||||
|  | 		  set_errno (EIO); | ||||||
|  | 		  totalread = -1; | ||||||
|  | 		  goto out; | ||||||
|  | 		} | ||||||
| 	      if (n) | 	      if (n) | ||||||
| 		{ | 		{ | ||||||
| 		  len -= n; | 		  len -= n; | ||||||
| @@ -1269,6 +1279,8 @@ fhandler_pty_master::close () | |||||||
|   else if (obi.HandleCount == 1) |   else if (obi.HandleCount == 1) | ||||||
|     { |     { | ||||||
|       termios_printf("Closing last master of pty%d", get_minor ()); |       termios_printf("Closing last master of pty%d", get_minor ()); | ||||||
|  |       if (get_ttyp ()->getsid () > 0) | ||||||
|  | 	kill (get_ttyp ()->getsid (), SIGHUP); | ||||||
|       SetEvent (input_available_event); |       SetEvent (input_available_event); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user