X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/2a49908006b177c4d6354309333d06b1b96e4887..2236410f4582ab45ae8c384dd6eeeef5d10aab15:/lunaix-os/usr/init/init.c diff --git a/lunaix-os/usr/init/init.c b/lunaix-os/usr/init/init.c index 7e1785a..1b80f49 100644 --- a/lunaix-os/usr/init/init.c +++ b/lunaix-os/usr/init/init.c @@ -1,39 +1,59 @@ #include #include #include +#include #include #include +#define must_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); \ + return err; \ + } \ + } while (0) + int main(int argc, const char** argv) { int err = 0; + 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); + if ((err = open("/dev/tty", 0)) < 0) { syslog(2, "fail to open tty (%d)\n", errno); - return 0; + return err; } if ((err = dup(err)) < 0) { syslog(2, "fail to setup tty i/o (%d)\n", errno); - return 0; + return err; } - printf("(%p) user space!\n", (void*)main); - if ((err = symlink("/usr", "/mnt/lunaix-os/usr"))) { syslog(2, "symlink /usr:/mnt/lunaix-os/usr (%d)\n", errno); - return 0; + return err; } pid_t pid; if (!(pid = fork())) { - err = execve("/usr/sh", NULL, NULL); + err = execve("/usr/bin/sh", NULL, NULL); printf("fail to execute (%d)\n", errno); _exit(err); } - waitpid(pid, NULL, 0); + waitpid(pid, &err, 0); + + if (WEXITSTATUS(err)) { + printf("shell exit abnormally (%d)", err); + } - return 0; + return err; } \ No newline at end of file