base-files: fix unkillable processes after restart
authorLinus Kardell <linus@telliq.com>
Thu, 22 Nov 2018 10:35:08 +0000 (11:35 +0100)
committerLinus Kardell <linus@telliq.com>
Thu, 22 Nov 2018 12:15:10 +0000 (13:15 +0100)
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 <linus@telliq.com>
package/base-files/files/etc/rc.common

index 3e237170b4cb0809172b36c2b4fff6148930edda..d9773a0c5aaec092feb5cdae9decc798b5a6b714 100755 (executable)
@@ -23,6 +23,7 @@ reload() {
 restart() {
        trap '' TERM
        stop "$@"
+       trap - TERM
        start "$@"
 }