From: Linus Kardell Date: Thu, 22 Nov 2018 10:35:08 +0000 (+0100) Subject: base-files: fix unkillable processes after restart X-Git-Tag: v18.06.2~283 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=709d080da5c357d7139044b668bacf1d154fc976;p=oweals%2Fopenwrt.git base-files: fix unkillable processes after restart When restart is run on an init script, the script traps SIGTERM. This is done as a workaround for scripts named the same name as the program they start. In that case, the init script process will have the same name as the program process, and so when the init script runs killall, it will kill itself. So SIGTERM is trapped to make the init script unkillable. However, the trap is retained when the init script runs start, and thus processes started by restart will not respond to SIGTERM, and will thus be unkillable unless you use SIGKILL. This fixes that by removing the trap before running start. Signed-off-by: Linus Kardell (cherry picked from commit 2ac1a57677ce4e21513dca2a8efab1eb6e0a9c58) --- diff --git a/package/base-files/files/etc/rc.common b/package/base-files/files/etc/rc.common index 3e237170b4..d9773a0c5a 100755 --- a/package/base-files/files/etc/rc.common +++ b/package/base-files/files/etc/rc.common @@ -23,6 +23,7 @@ reload() { restart() { trap '' TERM stop "$@" + trap - TERM start "$@" }