[asterisk-commits] russell: trunk r165662 - in /trunk: ./ res/res_musiconhold.c
SVN commits to the Asterisk project
asterisk-commits at lists.digium.com
Thu Dec 18 12:54:48 CST 2008
Author: russell
Date: Thu Dec 18 12:54:47 2008
New Revision: 165662
URL: http://svn.digium.com/view/asterisk?view=rev&rev=165662
Log:
Merged revisions 165661 via svnmerge from
https://origsvn.digium.com/svn/asterisk/branches/1.4
........
r165661 | russell | 2008-12-18 12:52:18 -0600 (Thu, 18 Dec 2008) | 7 lines
Set the process group ID on the MOH process so that all children will get killed
(closes issue #14099)
Reported by: caspy
Patches:
res_musiconhold.c.patch.killpg.try2 uploaded by caspy (license 645)
........
Modified:
trunk/ (props changed)
trunk/res/res_musiconhold.c
Propchange: trunk/
------------------------------------------------------------------------------
Binary property 'branch-1.4-merged' - no diff available.
Modified: trunk/res/res_musiconhold.c
URL: http://svn.digium.com/view/asterisk/trunk/res/res_musiconhold.c?view=diff&rev=165662&r1=165661&r2=165662
==============================================================================
--- trunk/res/res_musiconhold.c (original)
+++ trunk/res/res_musiconhold.c Thu Dec 18 12:54:47 2008
@@ -516,6 +516,7 @@
ast_log(LOG_WARNING, "chdir() failed: %s\n", strerror(errno));
_exit(1);
}
+ setpgid(0, getpid());
if (ast_test_flag(class, MOH_CUSTOM)) {
execv(argv[0], argv);
} else {
@@ -597,11 +598,11 @@
class->srcfd = -1;
pthread_testcancel();
if (class->pid > 1) {
- kill(class->pid, SIGHUP);
+ killpg(class->pid, SIGHUP);
usleep(100000);
- kill(class->pid, SIGTERM);
+ killpg(class->pid, SIGTERM);
usleep(100000);
- kill(class->pid, SIGKILL);
+ killpg(class->pid, SIGKILL);
class->pid = 0;
}
} else {
@@ -1465,11 +1466,11 @@
/* Back when this was just mpg123, SIGKILL was fine. Now we need
* to give the process a reason and time enough to kill off its
* children. */
- kill(pid, SIGHUP);
+ killpg(pid, SIGHUP);
usleep(100000);
- kill(pid, SIGTERM);
+ killpg(pid, SIGTERM);
usleep(100000);
- kill(pid, SIGKILL);
+ killpg(pid, SIGKILL);
while ((ast_wait_for_input(moh->srcfd, 100) > 0) && (bytes = read(moh->srcfd, buff, 8192)) && time(NULL) < stop_time)
tbytes = tbytes + bytes;
ast_debug(1, "mpg123 pid %d and child died after %d bytes read\n", pid, tbytes);
More information about the asterisk-commits
mailing list