diff options
author | dzwdz | 2022-07-11 21:54:51 +0200 |
---|---|---|
committer | dzwdz | 2022-07-11 21:54:51 +0200 |
commit | 2e79a2e5af3affa7a6a3becdffb1c91d89af90af (patch) | |
tree | c253761c4ec010ad14b08f9ee8dfc1a50411b30f /src/init/main.c | |
parent | 6c01d9a7e34e1fccc2775b0e2187ac5e50dd4392 (diff) |
user: reorganize the userland sources
Diffstat (limited to 'src/init/main.c')
-rw-r--r-- | src/init/main.c | 89 |
1 files changed, 0 insertions, 89 deletions
diff --git a/src/init/main.c b/src/init/main.c deleted file mode 100644 index 88553e9..0000000 --- a/src/init/main.c +++ /dev/null @@ -1,89 +0,0 @@ -#include <init/driver/driver.h> -#include <init/fs/misc.h> -#include <init/shell.h> -#include <init/stdlib.h> -#include <init/tar.h> -#include <init/tests/main.h> -#include <shared/flags.h> -#include <shared/syscalls.h> -#include <stdint.h> - -extern char _bss_start; // provided by the linker -extern char _bss_end; -extern char _initrd; - -void read_file(const char *path, size_t len); - -__attribute__((section(".text.startup"))) -int main(void) { - // allocate bss - _syscall_memflag(&_bss_start, &_bss_end - &_bss_start, MEMFLAG_PRESENT); - - file_reopen(stdout, "/com1", 0); - printf("preinit\n"); - - /* move everything provided by the kernel to /kdev */ - MOUNT("/kdev/", fs_passthru(NULL)); - if (!fork2_n_mount("/")) { - const char *l[] = {"/kdev/", NULL}; - fs_whitelist(l); - } - if (!fork2_n_mount("/")) fs_dir_inject("/kdev/"); // TODO should be part of fs_whitelist - - MOUNT("/init/", tar_driver(&_initrd)); - MOUNT("/tmp/", tmpfs_drv()); - MOUNT("/keyboard", ps2_drv()); - MOUNT("/vga_tty", ansiterm_drv()); - - MOUNT("/bind/", fs_passthru(NULL)); - - if (_syscall_fork(0, NULL)) { - /* (used to) expose a bug in the kernel - * the program will flow like this: - * 1. we launch the forked init - * 2. the forked init launches both shells - * 3. one of the shells quit - * 4. the forked init picks it up and quits - * - * then, in process_kill, the other shell will be deathbedded - * - * before i implement(ed) reparenting, it was a lingering running child - * of a dead process, which is invalid state - */ - _syscall_await(); - _syscall_exit(1); - } - - if (!_syscall_fork(0, NULL)) { - if (!file_reopen(stdout, "/kdev/com1", 0)) { - printf("couldn't open /kdev/com1\n"); // TODO borked - _syscall_exit(1); - } - if (!file_reopen(stdin, "/kdev/com1", 0)) { - printf("couldn't open /kdev/com1\n"); - _syscall_exit(1); - } - - shell_loop(); - _syscall_exit(1); - } - - - if (!_syscall_fork(0, NULL)) { - if (!file_reopen(stdout, "/vga_tty", 0)) { - printf("couldn't open /vga_tty\n"); // TODO borked - _syscall_exit(1); - } - if (!file_reopen(stdin, "/keyboard", 0)) { - printf("couldn't open /keyboard\n"); - _syscall_exit(1); - } - - shell_loop(); - _syscall_exit(1); - } - - _syscall_await(); - printf("init: quitting\n"); - _syscall_exit(0); -} |