aboutsummaryrefslogtreecommitdiff
path: root/cmd/shutdown.c
diff options
context:
space:
mode:
Diffstat (limited to 'cmd/shutdown.c')
-rw-r--r--cmd/shutdown.c79
1 files changed, 33 insertions, 46 deletions
diff --git a/cmd/shutdown.c b/cmd/shutdown.c
index 0d11cc5..39145ec 100644
--- a/cmd/shutdown.c
+++ b/cmd/shutdown.c
@@ -19,19 +19,15 @@
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
+#include <signal.h>
#include <stdio.h>
#include <errno.h>
#include <sys/reboot.h>
#include <linux/reboot.h>
-#include "telinit.h"
#include "util.h"
-#define STRINIFY(x) #x
-#define STRINIFY_VALUE(x) STRINIFY(x)
-#define PROGRAM_NAME STRINIFY_VALUE(PROGNAME)
-
#define FL_FORCE 0x01
#define FL_NOSYNC 0x02
@@ -48,9 +44,9 @@ static const struct option options[] = {
static const char *shortopt = "hVprfn";
static const char *defact_str = "power-off";
-static int defact = TI_SHUTDOWN;
+static int defact = RB_POWER_OFF;
-static NORETURN void usage(int status)
+static NORETURN void usage(const char *progname, int status)
{
fprintf(status == EXIT_SUCCESS ? stdout : stderr,
"%s [OPTIONS...]\n\n"
@@ -63,32 +59,34 @@ static NORETURN void usage(int status)
" init system.\n"
" -n, --no-sync Don't sync storage media before power-off or reboot.\n\n"
"If no option is specified, the default action is %s.\n",
- PROGRAM_NAME, defact_str);
+ progname, defact_str);
exit(status);
}
-static NORETURN void version(void)
+static NORETURN void version(const char *progname)
{
- fputs(
-PROGRAM_NAME " (Pygos init) " PACKAGE_VERSION "\n"
+ fprintf(stdout,
+"%s (Pygos init) %s\n"
"Copyright (C) 2018 David Oberhollenzer\n"
"License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>.\n"
"This is free software: you are free to change and redistribute it.\n"
"There is NO WARRANTY, to the extent permitted by law.\n",
- stdout);
+ progname, PACKAGE_VERSION);
exit(EXIT_SUCCESS);
}
int main(int argc, char **argv)
{
- int c, fd, flags = 0;
- ti_msg_t msg;
- ssize_t ret;
+ int c, ret, flags = 0;
+ char *ptr;
+
+ ptr = strrchr(argv[0], '/');
+ ptr = (ptr == NULL) ? argv[0] : (ptr + 1);
- if (!strcmp(PROGRAM_NAME, "reboot")) {
+ if (strcmp(ptr, "reboot") == 0) {
defact_str = "reboot";
- defact = TI_REBOOT;
+ defact = RB_AUTOBOOT;
}
while (1) {
@@ -104,53 +102,42 @@ int main(int argc, char **argv)
flags |= FL_NOSYNC;
break;
case 'p':
- defact = TI_SHUTDOWN;
+ defact = RB_POWER_OFF;
break;
case 'r':
- defact = TI_REBOOT;
+ defact = RB_AUTOBOOT;
break;
case 'V':
- version();
+ version(ptr);
case 'h':
- usage(EXIT_SUCCESS);
+ usage(ptr, EXIT_SUCCESS);
default:
- exit(EXIT_FAILURE);
+ usage(ptr, EXIT_FAILURE);
}
}
if (flags & FL_FORCE) {
if (!(flags & FL_NOSYNC))
sync();
-
- switch (defact) {
- case TI_REBOOT:
- reboot(RB_AUTOBOOT);
- break;
- case TI_SHUTDOWN:
- reboot(RB_POWER_OFF);
- break;
- }
-
+ reboot(defact);
perror("reboot system call");
return EXIT_FAILURE;
}
- fd = opensock();
- if (fd < 0)
- return EXIT_FAILURE;
-
- msg.type = defact;
-retry:
- ret = write(fd, &msg, sizeof(msg));
+ switch (defact) {
+ case RB_AUTOBOOT:
+ ret = kill(1, SIGINT);
+ break;
+ case RB_POWER_OFF:
+ ret = kill(1, SIGTERM);
+ break;
+ default:
+ return EXIT_SUCCESS;
+ }
- if (ret < 0) {
- if (errno == EINTR)
- goto retry;
- perror("write on init socket");
- close(fd);
+ if (ret) {
+ perror("sending signal to init");
return EXIT_FAILURE;
}
-
- close(fd);
return EXIT_SUCCESS;
}