summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/supervision/s6-supervise.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/src/supervision/s6-supervise.c b/src/supervision/s6-supervise.c
index 60ba85c..881d29a 100644
--- a/src/supervision/s6-supervise.c
+++ b/src/supervision/s6-supervise.c
@@ -62,6 +62,7 @@ static state_t state = DOWN ;
static int flagdying = 0 ;
static int cont = 1 ;
static int notifyfd = -1 ;
+static char const *servicename = 0 ;
static inline void settimeout (int secs)
{
@@ -305,7 +306,7 @@ static void trystart (void)
}
else if (!pid)
{
- char const *cargv[2] = { "run", 0 } ;
+ char const *cargv[3] = { "run", servicename, 0 } ;
((char *)PROG)[strlen(PROG)] = ' ' ;
selfpipe_finish() ;
if (notifyp[0] >= 0) close(notifyp[0]) ;
@@ -455,7 +456,7 @@ static int uplastup_z (void)
{
char fmt0[UINT_FMT] ;
char fmt1[UINT_FMT] ;
- char *cargv[4] = { "finish", fmt0, fmt1, 0 } ;
+ char *cargv[5] = { "finish", fmt0, fmt1, servicename, 0 } ;
selfpipe_finish() ;
fmt0[uint_fmt(fmt0, WIFSIGNALED(status.wstat) ? 256 : WEXITSTATUS(status.wstat))] = 0 ;
fmt1[uint_fmt(fmt1, WTERMSIG(status.wstat))] = 0 ;
@@ -765,6 +766,7 @@ int main (int argc, char const *const *argv)
PROG = "s6-supervise" ;
if (argc < 2) strerr_dieusage(100, USAGE) ;
if (chdir(argv[1]) < 0) strerr_diefu2sys(111, "chdir to ", argv[1]) ;
+ servicename = argv[1] ;
{
size_t proglen = strlen(PROG) ;
size_t namelen = strlen(argv[1]) ;