X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/32e96fff7803b534f61c44b80cfbec632ca9a89a..f1215ac7aa9d9e148e17787e8820c34c0951c558:/package/base-files/files/lib/upgrade/common.sh diff --git a/package/base-files/files/lib/upgrade/common.sh b/package/base-files/files/lib/upgrade/common.sh index 2126ca1c3..e97958bf9 100644 --- a/package/base-files/files/lib/upgrade/common.sh +++ b/package/base-files/files/lib/upgrade/common.sh @@ -79,20 +79,28 @@ run_ramfs() { # [...] kill_remaining() { # [ ] local sig="${1:-TERM}" - echo -n "Sending $sig to remaing processes ... " - top -bn1 | while read pid ppid user stat vsz pvsz pcpu cmd args; do - case "$pid" in - [0-9]*) : ;; - *) continue ;; - esac - case "$cmd" in - # Skip kernel threads and essential services - \[*\]|*ash*|*init*|*watchdog*|*ssh*|*dropbear*|*telnet*|*login*) : ;; + echo -n "Sending $sig to remaining processes ... " + + local stat + for stat in /proc/[0-9]*/stat; do + local pid name state ppid rest + read pid name state ppid rest < $stat + name="${name#(}"; name="${name%)}" + + local cmdline + read cmdline < /proc/$pid/cmdline + + # Skip kernel threads + [ -n "$cmdline" ] || continue + + case "$name" in + # Skip essential services + *ash*|*init*|*watchdog*|*ssh*|*dropbear*|*telnet*|*login*|*ubusd*|*netifd*|*hostapd*|*wpa_supplicant*|*udhcpc*) : ;; # Killable process *) if [ $pid -ne $$ ] && [ $ppid -ne $$ ]; then - echo -n "${cmd##*/} " + echo -n "$name " kill -$sig $pid 2>/dev/null fi ;;