X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/bdc143a7aa3f51a46eceec62b0b364599533fa21..b1644f824d7f4989a94b8a752aadee26cae25069:/lunaix-os/usr/init/init.c diff --git a/lunaix-os/usr/init/init.c b/lunaix-os/usr/init/init.c index 47fcf68..67a73f9 100644 --- a/lunaix-os/usr/init/init.c +++ b/lunaix-os/usr/init/init.c @@ -1,11 +1,13 @@ #include #include -#include -#include +#include +#include #include #include #include +#include + #define must_mount(src, target, fs, opts) \ do { \ int err = 0; \ @@ -15,6 +17,14 @@ } \ } while (0) +#define maybe_mount(src, target, fs, opts) \ + do { \ + int err = 0; \ + if ((err = mount(src, target, fs, opts))) { \ + syslog(2, "mount fs %s to %s failed (%d)\n", fs, target, errno); \ + } \ + } while (0) + #define check(statement) \ ({ \ int err = 0; \ @@ -31,7 +41,7 @@ init_termios(int fd) { check(tcgetattr(fd, &term)); - term.c_lflag = ICANON | IEXTEN | ISIG | ECHO | ECHOE | ECHONL; + term.c_lflag = ICANON | IEXTEN | ISIG | ECHO | ECHOE; term.c_iflag = ICRNL | IGNBRK; term.c_oflag = ONLCR | OPOST; term.c_cflag = CREAD | CLOCAL | CS8 | CPARENB; @@ -45,16 +55,12 @@ init_termios(int fd) { return 0; } -const char* sh_argv[] = { "/usr/bin/sh", 0 }; +const char* sh_argv[] = { "/bin/sh", 0 }; const char* sh_envp[] = { 0 }; int main(int argc, const char** argv) { - mkdir("/dev"); - mkdir("/sys"); - mkdir("/task"); - must_mount(NULL, "/dev", "devfs", 0); must_mount(NULL, "/sys", "twifs", MNT_RO); must_mount(NULL, "/task", "taskfs", MNT_RO); @@ -65,13 +71,9 @@ main(int argc, const char** argv) check(dup(fd)); - check(symlink("/usr", "/mnt/lunaix-os/usr")); - pid_t pid; int err = 0; if (!(pid = fork())) { - - err = execve(sh_argv[0], sh_argv, sh_envp); printf("fail to execute (%d)\n", errno); _exit(err);