[asterisk-commits] tilghman: trunk r178303 - /trunk/utils/astcanary.c

SVN commits to the Asterisk project asterisk-commits at lists.digium.com
Tue Feb 24 11:51:36 CST 2009


Author: tilghman
Date: Tue Feb 24 11:51:36 2009
New Revision: 178303

URL: http://svn.digium.com/svn-view/asterisk?view=rev&rev=178303
Log:
Cause astcanary to exit if Asterisk exits abnormally and doesn't kill astcanary.
Also, add some documentation supporting the use of astcanary.
(closes issue #14538)
 Reported by: KNK
 Patches: 
       asterisk-1.6.x-astcanary.diff uploaded by KNK (license 545)

Modified:
    trunk/utils/astcanary.c

Modified: trunk/utils/astcanary.c
URL: http://svn.digium.com/svn-view/asterisk/trunk/utils/astcanary.c?view=diff&rev=178303&r1=178302&r2=178303
==============================================================================
--- trunk/utils/astcanary.c (original)
+++ trunk/utils/astcanary.c Tue Feb 24 11:51:36 2009
@@ -30,7 +30,7 @@
  * At one time, canaries were carried along with coal miners down
  * into a mine.  Their purpose was to alert the miners when they
  * had drilled into a pocket of methane gas or another noxious
- * substance.  The canary, being the most sensitive animal would
+ * substance.  The canary, being the most sensitive animal, would
  * immediately fall over.  Seeing this, the miners could take
  * action to escape the mine, seeing an imminent danger.
  *
@@ -57,6 +57,18 @@
  * the same time.  This is also why this canary must exist as a
  * completely separate process and not simply as a thread within
  * Asterisk itself.
+ *
+ * Quote:
+ * "The nice value set with setpriority() shall be applied to the
+ * process. If the process is multi-threaded, the nice value shall
+ * affect all system scope threads in the process."
+ *
+ * Source:
+ * http://www.opengroup.org/onlinepubs/000095399/functions/setpriority.html
+ *
+ * In answer to the question, what aren't system scope threads, the
+ * answer is, in Asterisk, nothing.  Process scope threads are the
+ * alternative, but they aren't supported in Linux.
  */
 
 static const char explanation[] =
@@ -77,7 +89,7 @@
 	int fd;
 	/* Run at normal priority */
 	setpriority(PRIO_PROCESS, 0, 0);
-	for (;;) {
+	for (; getppid() != 1;) {
 		/* Update the modification times (checked from Asterisk) */
 		if (utime(argv[1], NULL)) {
 			/* Recreate the file if it doesn't exist */
@@ -96,7 +108,7 @@
 		sleep(5);
 	}
 
-	/* Never reached */
+	/* Reached if asterisk (our parent process) dies - its chldren are inherited by the init process (pid is 1). */
 	return 0;
 }
 




More information about the asterisk-commits mailing list