summaryrefslogtreecommitdiff
path: root/src/init
diff options
context:
space:
mode:
authorLaurent Bercot <ska-skaware@skarnet.org>2020-12-09 18:19:21 +0000
committerLaurent Bercot <ska-skaware@skarnet.org>2020-12-09 18:19:21 +0000
commitca8d2c96ea09cb33ff6fef33c0314c24fc6a026a (patch)
tree08cfbbbb0c7dc84154dea30e86fe2adc582d1d45 /src/init
parent2fa0acdd248c006270010196ad02e530d8ab09ea (diff)
downloads6-linux-init-ca8d2c96ea09cb33ff6fef33c0314c24fc6a026a.tar.xz
Make it work with the new s6. Add s6-linux-init-nuke.
Diffstat (limited to 'src/init')
-rw-r--r--src/init/s6-linux-init-maker.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/src/init/s6-linux-init-maker.c b/src/init/s6-linux-init-maker.c
index 1e6de62..7c315a6 100644
--- a/src/init/s6-linux-init-maker.c
+++ b/src/init/s6-linux-init-maker.c
@@ -120,7 +120,8 @@ static int container_crash_script (buffer *b, char const *data)
EXECLINE_EXTBINPREFIX "foreground\n{\n "
EXECLINE_EXTBINPREFIX "fdmove -c 1 2\n "
S6_LINUX_INIT_EXTBINPREFIX "s6-linux-init-echo -- \"s6-svscan crashed. Killing everything and exiting.\"\n}\n"
- EXECLINE_EXTBINPREFIX "foreground { kill -9 -1 }\n"
+ EXECLINE_EXTBINPREFIX "foreground { "
+ S6_LINUX_INIT_EXTBINPREFIX "s6-linux-init-nuke }\n"
EXECLINE_EXTBINPREFIX "wait { }\n"
S6_LINUX_INIT_EXTBINPREFIX "s6-linux-init-hpr -fnp\n") >= 0 ;
}
@@ -134,6 +135,9 @@ static int container_exit_script (buffer *b, char const *data)
EXECLINE_EXTBINPREFIX "multisubstitute\n{\n"
" importas -uD0 -- EXITCODE exitcode\n "
" importas -uDh -- HALTCODE haltcode\n}\n"
+ EXECLINE_EXTBINPREFIX "fdclose 1\n"
+ EXECLINE_EXTBINPREFIX "fdclose 2\n"
+ EXECLINE_EXTBINPREFIX "wait { }\n"
EXECLINE_EXTBINPREFIX "ifelse -X { test $HALTCODE = r } { "
S6_LINUX_INIT_EXTBINPREFIX "s6-linux-init-hpr -fnr }\n"
EXECLINE_EXTBINPREFIX "ifelse -X { test $HALTCODE = p } { "
@@ -547,7 +551,6 @@ static inline void make_image (char const *base)
auto_dir(base, "run-image/" SCANDIR, 0, 0, 0755) ;
auto_dir(base, "run-image/" SCANDIR "/.s6-svscan", 0, 0, 0755) ;
auto_script(base, "run-image/" SCANDIR "/.s6-svscan/SIGTERM", &put_shebang_options, 0) ;
- auto_script(base, "run-image/" SCANDIR "/.s6-svscan/SIGHUP", &put_shebang_options, 0) ;
auto_script(base, "run-image/" SCANDIR "/.s6-svscan/SIGQUIT", &put_shebang_options, 0) ;
auto_script(base, "run-image/" SCANDIR "/.s6-svscan/SIGINT", &sig_script, "-r") ;
auto_script(base, "run-image/" SCANDIR "/.s6-svscan/SIGUSR1", &sig_script, "-p") ;