Luna/apps/init.cpp

54 lines
1.4 KiB
C++
Raw Normal View History

#include <errno.h>
#include <fcntl.h>
#include <stdio.h>
#include <stdlib.h>
#include <sys/stat.h>
2023-03-18 20:55:16 +00:00
#include <sys/syscall.h>
#include <sys/sysmacros.h>
#include <sys/wait.h>
#include <unistd.h>
#define xmknod(path, mode, maj, min) \
if (mknod(path, mode, makedev(maj, min)) < 0) exit(255);
// Too early for console logs (/dev/console is created here!), so we have to resort to exiting with a weird exit code in
// case of failure.
static void populate_devfs()
{
if (mkdir("/dev", 0755) < 0 && errno != EEXIST) exit(255);
xmknod("/dev/console", 0666, 1, 0);
xmknod("/dev/null", 0666, 2, 0);
2023-03-30 19:19:16 +00:00
xmknod("/dev/zero", 0666, 2, 1);
}
int main()
{
if (getpid() != 1)
{
2023-03-19 18:19:20 +00:00
fprintf(stderr, "error: init not running as PID 1.\n");
return 1;
}
populate_devfs();
2023-03-19 18:19:20 +00:00
// Before this point, we don't even have an stdin, stdout and stderr. Set it up now so that child processes (and us)
// can print stuff.
stdin = fopen("/dev/console", "r");
stdout = fopen("/dev/console", "w");
stderr = fopen("/dev/console", "w");
2023-03-18 22:58:56 +00:00
pid_t ret = fork();
2023-03-18 22:45:48 +00:00
if (ret == 0)
{
2023-03-23 21:19:54 +00:00
char* argv[] = { "/bin/sh", NULL };
char* envp[] = { "PATH=/bin:/sbin", NULL };
execve(argv[0], argv, envp);
2023-03-23 21:19:54 +00:00
perror("execv");
return 1;
2023-03-18 22:45:48 +00:00
}
2023-03-23 21:19:54 +00:00
while (1) wait(NULL);
}