From: Matthias Schiffer Date: Wed, 12 Jul 2017 22:19:32 +0000 (+0200) Subject: base-files: upgrade: don't loop forever trying to kill processes X-Git-Tag: v18.06.0-rc1~2490 X-Git-Url: http://git.cdn.openwrt.org/?a=commitdiff_plain;h=1ab227d68852c1cb869926057774540bded24d41;p=openwrt%2Fstaging%2Fxback.git base-files: upgrade: don't loop forever trying to kill processes When processes don't die on SIGKILL (usually because of kernel bugs), it's better to give up instead of looping forever. upgraded will trigger a reboot in this case (and if this fails, a hardware watchdog will eventually time out and reset the system, if present). Signed-off-by: Matthias Schiffer --- diff --git a/package/base-files/files/lib/upgrade/stage2 b/package/base-files/files/lib/upgrade/stage2 index 5a439f1201..d7f92a4f35 100755 --- a/package/base-files/files/lib/upgrade/stage2 +++ b/package/base-files/files/lib/upgrade/stage2 @@ -78,6 +78,8 @@ switch_to_ramfs() { } kill_remaining() { # [ [ ] ] + local loop_limit=10 + local sig="${1:-TERM}" local loop="${2:-0}" local run=true @@ -108,8 +110,15 @@ kill_remaining() { # [ [ ] ] [ $loop -eq 1 ] && run=true done + + let loop_limit-- + [ $loop_limit -eq 0 ] && { + echo + echo "Failed to kill all processes." + exit 1 + } done - echo "" + echo }