summaryrefslogtreecommitdiff
path: root/package/base-files/files/lib/upgrade/common.sh
diff options
context:
space:
mode:
authorjow <jow@3c298f89-4303-0410-b956-a3cf2f4a3e73>2011-10-27 16:52:31 +0000
committerjow <jow@3c298f89-4303-0410-b956-a3cf2f4a3e73>2011-10-27 16:52:31 +0000
commit32e96fff7803b534f61c44b80cfbec632ca9a89a (patch)
treeab9c109329b45db569595901df915f173f19fb53 /package/base-files/files/lib/upgrade/common.sh
parentf6c379666dc69617804a5d9aff19d866da9b42bd (diff)
[package] base-files: sysupgrade: kill all but essential processes before starting the update
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@28626 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/base-files/files/lib/upgrade/common.sh')
-rw-r--r--package/base-files/files/lib/upgrade/common.sh24
1 files changed, 24 insertions, 0 deletions
diff --git a/package/base-files/files/lib/upgrade/common.sh b/package/base-files/files/lib/upgrade/common.sh
index 65ce816db2..2126ca1c38 100644
--- a/package/base-files/files/lib/upgrade/common.sh
+++ b/package/base-files/files/lib/upgrade/common.sh
@@ -77,6 +77,30 @@ run_ramfs() { # <command> [...]
exec /bin/busybox ash -c "$*"
}
+kill_remaining() { # [ <signal> ]
+ 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*) : ;;
+
+ # Killable process
+ *)
+ if [ $pid -ne $$ ] && [ $ppid -ne $$ ]; then
+ echo -n "${cmd##*/} "
+ kill -$sig $pid 2>/dev/null
+ fi
+ ;;
+ esac
+ done
+ echo ""
+}
+
run_hooks() {
local arg="$1"; shift
for func in "$@"; do