diff options
author | Jo-Philipp Wich <jow@openwrt.org> | 2011-10-27 16:52:31 +0000 |
---|---|---|
committer | Jo-Philipp Wich <jow@openwrt.org> | 2011-10-27 16:52:31 +0000 |
commit | 1b7836ca8c465cca7a2765025d17b0cc877b77dc (patch) | |
tree | ab9c109329b45db569595901df915f173f19fb53 /package/base-files/files/lib/upgrade | |
parent | 356538e943156a232f9c6a1fb3e6160d4c87bb4e (diff) | |
download | upstream-1b7836ca8c465cca7a2765025d17b0cc877b77dc.tar.gz upstream-1b7836ca8c465cca7a2765025d17b0cc877b77dc.tar.bz2 upstream-1b7836ca8c465cca7a2765025d17b0cc877b77dc.zip |
[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')
-rw-r--r-- | package/base-files/files/lib/upgrade/common.sh | 24 |
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 |