mirror of
				git://git.code.sf.net/p/cdesktopenv/code
				synced 2025-03-09 15:50:02 +00:00 
			
		
		
		
	Fix blocked signals after fork(2)ing external command in subshell
When the classic fork/exec mechanism was used (via sh_fork()) to
run an external command from within a non-forking subshell, SIGINT
was blocked until that subshell was exited. If a subsequent loop
was run in the subshell, it became uninterruptible, e.g.:
   $ arch/*/bin/ksh -c '(/usr/bin/true; while :; do :; done); exit'
   ^C^C^C^C^C
src/cmd/ksh93/sh/xec.c:
- sh_fork() did not reset the savesig variable in the parent part
  of the fork when running in a virtual subshell. This had the
  effect of delaying signal handling until exiting the subshell.
  There is no reason for that subshell check that I can discern, so
  this removes it.
      I've verified that this causes no regression test failures
  even when ksh is compiled with -DSHOPT_SPAWN=0 which means the
  classic fork/exec mechanism is always used.
Fixes: https://github.com/ksh93/ksh/issues/86
			
			
This commit is contained in:
		
							parent
							
								
									56fe602800
								
							
						
					
					
						commit
						70f6d758c0
					
				
					 3 changed files with 11 additions and 8 deletions
				
			
		|  | @ -17,4 +17,4 @@ | |||
| *                  David Korn <dgk@research.att.com>                   * | ||||
| *                                                                      * | ||||
| ***********************************************************************/ | ||||
| #define SH_RELEASE	"93u+m 2020-07-25" | ||||
| #define SH_RELEASE	"93u+m 2020-07-29" | ||||
|  |  | |||
|  | @ -2951,13 +2951,10 @@ pid_t sh_fork(Shell_t *shp,int flags, int *jobid) | |||
| 	shp->savesig = -1; | ||||
| 	while(_sh_fork(shp,parent=fork(),flags,jobid) < 0); | ||||
| 	sh_stats(STAT_FORKS); | ||||
| 	if(!shp->subshell) | ||||
| 	{ | ||||
| 		sig = shp->savesig; | ||||
| 		shp->savesig = 0; | ||||
| 		if(sig>0) | ||||
| 			kill(getpid(),sig); | ||||
| 	} | ||||
| 	sig = shp->savesig; | ||||
| 	shp->savesig = 0; | ||||
| 	if(sig>0) | ||||
| 		kill(getpid(),sig); | ||||
| 	job_fork(parent); | ||||
| 	return(parent); | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue