Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/etc Prevent waiting for processes to exit forever by introdu...



details:   https://anonhg.NetBSD.org/src/rev/c09e36572597
branches:  trunk
changeset: 970887:c09e36572597
user:      christos <christos%NetBSD.org@localhost>
date:      Sun Apr 05 21:03:08 2020 +0000

description:
Prevent waiting for processes to exit forever by introducing _rc_kill_ntries,
which if set, will SIGKILL the processes that did not die yet.

diffstat:

 etc/rc.subr |  59 +++++++++++++++++++++++++++++++++++++++++++----------------
 1 files changed, 43 insertions(+), 16 deletions(-)

diffs (94 lines):

diff -r ca99e2bd9ad3 -r c09e36572597 etc/rc.subr
--- a/etc/rc.subr       Sun Apr 05 20:59:38 2020 +0000
+++ b/etc/rc.subr       Sun Apr 05 21:03:08 2020 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: rc.subr,v 1.103 2018/09/23 23:02:39 kre Exp $
+# $NetBSD: rc.subr,v 1.104 2020/04/05 21:03:08 christos Exp $
 #
 # Copyright (c) 1997-2011 The NetBSD Foundation, Inc.
 # All rights reserved.
@@ -43,6 +43,7 @@
 _rc_original_stdout_fd=
 _rc_original_stderr_fd=
 _rc_postprocessor_fd=
+_rc_kill_ntries=
 "
 
 #
@@ -313,35 +314,61 @@
 }
 
 #
+# kill_pids signal pid [pid ...]
+#      kills the given pids with signal. 
+#      returns the list of pids killed successfully.
+#
+kill_pids()
+{
+       local signal=$1
+       shift
+       local list="$@"
+       local j=
+       local nlist=
+       for j in $list; do
+               if kill -$signal $j 2>/dev/null; then
+                       nlist="${nlist}${nlist:+ }$j"
+               fi
+       done
+       echo $nlist
+}
+
+#
 # wait_for_pids pid [pid ...]
 #      spins until none of the pids exist
+#      if _rc_kill_ntries is set and exceeded, it SIGKILLS the remaining
+#      pids
 #
 wait_for_pids()
 {
-       _list="$@"
-       if [ -z "$_list" ]; then
+       local ntries=0
+       local prefix=
+       local list="$@"
+
+       if [ -z "$list" ]; then
                return
        fi
-       _prefix=
+
        while true; do
-               _nlist="";
-               for _j in $_list; do
-                       if kill -0 $_j 2>/dev/null; then
-                               _nlist="${_nlist}${_nlist:+ }$_j"
-                       fi
-               done
-               if [ -z "$_nlist" ]; then
+               local nlist=$(kill_pids 0 $list)
+               if [ -z "$nlist" ]; then
                        break
                fi
-               if [ "$_list" != "$_nlist" ]; then
-                       _list=$_nlist
-                       echo -n ${_prefix:-"Waiting for PIDS: "}$_list
-                       _prefix=", "
+               if [ "$list" != "$nlist" ]; then
+                       list=$nlist
+                       echo -n ${prefix:-"Waiting for PIDS: "}$list
+                       prefix=", "
                fi
                # We want this to be a tight loop for a fast exit
                sleep 0.05
+               ntries=$((ntries + 1))
+               if [ -n "${_rc_kill_ntries}" ]; then
+                       if [ ${ntries} -gt ${_rc_kill_ntries} ]; then
+                               kill_pids 9 $list > /dev/null
+                       fi
+               fi
        done
-       if [ -n "$_prefix" ]; then
+       if [ -n "$prefix" ]; then
                echo "."
        fi
 }



Home | Main Index | Thread Index | Old Index