[asterisk-commits] tilghman: trunk r116467 - in /trunk: ./	res/res_agi.c
    SVN commits to the Asterisk project 
    asterisk-commits at lists.digium.com
       
    Wed May 14 16:39:06 CDT 2008
    
    
  
Author: tilghman
Date: Wed May 14 16:39:06 2008
New Revision: 116467
URL: http://svn.digium.com/view/asterisk?view=rev&rev=116467
Log:
Merged revisions 116466 via svnmerge from 
https://origsvn.digium.com/svn/asterisk/branches/1.4
........
r116466 | tilghman | 2008-05-14 16:38:09 -0500 (Wed, 14 May 2008) | 7 lines
Avoid zombies when the channel exits before the AGI.
(closes issue #12648)
 Reported by: gkloepfer
 Patches: 
       20080514__bug12648.diff.txt uploaded by Corydon76 (license 14)
 Tested by: gkloepfer
........
Modified:
    trunk/   (props changed)
    trunk/res/res_agi.c
Propchange: trunk/
------------------------------------------------------------------------------
Binary property 'branch-1.4-merged' - no diff available.
Modified: trunk/res/res_agi.c
URL: http://svn.digium.com/view/asterisk/trunk/res/res_agi.c?view=diff&rev=116467&r1=116466&r2=116467
==============================================================================
--- trunk/res/res_agi.c (original)
+++ trunk/res/res_agi.c Wed May 14 16:39:06 2008
@@ -2681,9 +2681,13 @@
 	if (pid > -1) {
 		const char *sighup = pbx_builtin_getvar_helper(chan, "AGISIGHUP");
 		if (ast_strlen_zero(sighup) || !ast_false(sighup)) {
-			if (kill(pid, SIGHUP))
+			if (kill(pid, SIGHUP)) {
 				ast_log(LOG_WARNING, "unable to send SIGHUP to AGI process %d: %s\n", pid, strerror(errno));
-		}
+			} else { /* Give the process a chance to die */
+				usleep(1);
+			}
+		}
+		waitpid(pid, status, WNOHANG);
 	}
 	fclose(readf);
 	return returnstatus;
    
    
More information about the asterisk-commits
mailing list