From c9fbab701ff57583733c84fa93889eacf422b861 Mon Sep 17 00:00:00 2001 From: dzwdz Date: Wed, 13 Sep 2023 00:05:06 +0200 Subject: cmd/init: remove /initctl, use intr instead --- src/cmd/init/init.c | 58 ++++++++++++++++++----------------------------------- 1 file changed, 20 insertions(+), 38 deletions(-) (limited to 'src/cmd/init/init.c') diff --git a/src/cmd/init/init.c b/src/cmd/init/init.c index acb6a8f..093e281 100644 --- a/src/cmd/init/init.c +++ b/src/cmd/init/init.c @@ -1,19 +1,18 @@ #include "driver/driver.h" #include #include +#include +#include #include +#include #include #include #include #include -#include - -#define die(fmt, ...) do { fprintf(stderr, "init: " fmt, __VA_ARGS__); exit(1); } while (0) - -static char title[128]; void redirect(const char *exe, const char *out, const char *in) { if (!fork()) { + static char title[128]; snprintf(title, sizeof title, "sh >%s", out); setproctitle(title); @@ -22,9 +21,9 @@ void redirect(const char *exe, const char *out, const char *in) { exit(1); } if (!freopen(out, "a+", stdout)) - die("couldn't open %s\n", out); + err(1, "couldn't open %s", out); if (!freopen(in, "r", stdin)) - die(" couldn't open %s\n", in); + err(1, "couldn't open %s", in); for (;;) { if (!fork()) { @@ -41,9 +40,17 @@ void redirect(const char *exe, const char *out, const char *in) { } } -int main(void) { - hid_t killswitch_pipe[2]; +void shutdown(void) { + printf("[init] intr\n"); + _sys_intr(); + _sys_sleep(1000); + printf("[init] filicide\n"); + _sys_filicide(); + printf("[init] goodbye\n"); + exit(0); +} +int main(void) { freopen("/dev/com1", "a+", stdout); freopen("/dev/com1", "a+", stderr); @@ -56,7 +63,6 @@ int main(void) { "/tmp/", "/vtty", "/net/", - "/initctl", NULL }); } @@ -111,40 +117,16 @@ int main(void) { execv(argv[0], (void*)argv); } - if (_sys_pipe(killswitch_pipe, 0) < 0) { - printf("couldn't create the killswitch pipe, quitting...\n"); - return 1; - } - MOUNT_AT("/initctl") { - close(killswitch_pipe[0]); - initctl_drv(killswitch_pipe[1]); - } - close(killswitch_pipe[1]); - if (!fork()) { - // TODO close on exec - close(killswitch_pipe[0]); redirect("/bin/shell", "/dev/com1", "/dev/com1"); redirect("/bin/shell", "/vtty", "/keyboard"); exit(1); } - char buf[128]; + intr_set(shutdown); for (;;) { - if (_sys_read(killswitch_pipe[0], buf, 128, 0) != 4) { - break; - } - if (memcmp(buf, "intr", 4) == 0) { - _sys_intr(); - } else if (memcmp(buf, "halt", 4) == 0) { - break; - } + // TODO sleep(-1) to sleep forever + // TODO maybe init should collect dead children? + _sys_sleep(86400000); } - printf("[init] intr\n"); - _sys_intr(); - _sys_sleep(1000); - printf("[init] filicide\n"); - _sys_filicide(); - printf("[init] goodbye\n"); - return 0; } -- cgit v1.2.3