diff options
author | dzwdz | 2022-07-11 17:29:31 +0200 |
---|---|---|
committer | dzwdz | 2022-07-11 17:29:31 +0200 |
commit | 5c4fb3b3c58a2d850031e9449b5d65887e42f1c7 (patch) | |
tree | a0ddb2000f4de00e56a6c1d90147ec1316fb3915 /src/init/main.c | |
parent | 8da0f7c04d3005f50d13d799a395d0ed8bad95ec (diff) |
init/stdlib: a more posix-y file api
Diffstat (limited to 'src/init/main.c')
-rw-r--r-- | src/init/main.c | 26 |
1 files changed, 15 insertions, 11 deletions
diff --git a/src/init/main.c b/src/init/main.c index 705da8f..1674f8c 100644 --- a/src/init/main.c +++ b/src/init/main.c @@ -19,7 +19,7 @@ int main(void) { // allocate bss _syscall_memflag(&_bss_start, &_bss_end - &_bss_start, MEMFLAG_PRESENT); - file_open(&__stdout, "/com1", 0); + stdout = file_open("/com1", 0); printf("preinit\n"); /* move everything provided by the kernel to /kdev */ @@ -37,8 +37,6 @@ int main(void) { MOUNT("/bind/", fs_passthru(NULL)); - file_close(&__stdout); - if (_syscall_fork(0, NULL)) { /* (used to) expose a bug in the kernel * the program will flow like this: @@ -57,8 +55,12 @@ int main(void) { } if (!_syscall_fork(0, NULL)) { - if (file_open(&__stdout, "/kdev/com1", 0) < 0 || file_open(&__stdin, "/kdev/com1", 0) < 0) + libc_file *new = file_open("/kdev/com1", 0); + if (!new) { + printf("couldn't open /kdev/com1\n"); _syscall_exit(1); + } + stdout = stdin = new; // TODO file_clone, this is bad shell_loop(); _syscall_exit(1); @@ -66,10 +68,17 @@ int main(void) { if (!_syscall_fork(0, NULL)) { - if (file_open(&__stdout, "/vga_tty", 0) < 0) + libc_file *new; + new = file_open("/vga_tty", 0); + if (!new) { + printf("couldn't open /vga_tty\n"); _syscall_exit(1); + } + file_close(stdout); + stdout = new; - if (file_open(&__stdin, "/keyboard", 0) < 0) { + stdin = file_open("/keyboard", 0); + if (!stdin) { printf("couldn't open /keyboard\n"); _syscall_exit(1); } @@ -78,11 +87,6 @@ int main(void) { _syscall_exit(1); } - - // try to find any working output - if (file_open(&__stdout, "/kdev/com1", 0) < 0) - file_open(&__stdout, "/kdev/vga_tty", 0); - _syscall_await(); printf("init: quitting\n"); _syscall_exit(0); |