diff options
author | Ian McFarlane <i.mcfarlane2002@gmail.com> | 2025-05-06 15:14:11 -0400 |
---|---|---|
committer | Ian McFarlane <i.mcfarlane2002@gmail.com> | 2025-05-06 15:14:11 -0400 |
commit | da396afa8b612b8f8ff07d71c57761a627b158eb (patch) | |
tree | b4935b29aca686c6ee17a583cffe149d7bb3c819 /kernel/main.c | |
parent | update forkman with spinlock (diff) | |
parent | start docs (diff) | |
download | comus-da396afa8b612b8f8ff07d71c57761a627b158eb.tar.gz comus-da396afa8b612b8f8ff07d71c57761a627b158eb.tar.bz2 comus-da396afa8b612b8f8ff07d71c57761a627b158eb.zip |
merge main into forkmanforkman
Diffstat (limited to 'kernel/main.c')
-rw-r--r-- | kernel/main.c | 46 |
1 files changed, 40 insertions, 6 deletions
diff --git a/kernel/main.c b/kernel/main.c index c15c38d..52f832b 100644 --- a/kernel/main.c +++ b/kernel/main.c @@ -22,6 +22,44 @@ void kreport(void) gpu_report(); } +void load_init(void) +{ + struct file_system *fs; + struct file *file; + const char *init_vector[] = { NULL }; + + if (pcb_alloc(&init_pcb)) { + WARN("failed to alloc init pcb"); + return; + } + + // get root fs + fs = fs_get_root_file_system(); + if (fs == NULL) { + WARN("failed to get root fs"); + return; + } + + // get init bin + if (fs->open(fs, "bin/init", O_RDONLY, &file)) { + WARN("cannot find init elf"); + return; + } + + if (user_load(init_pcb, file, init_vector, kernel_mem_ctx)) { + WARN("init elf failed to load! bad bad BAD!!"); + file->close(file); + return; + } + + // close file + file->close(file); + + // schedule and dispatch init + schedule(init_pcb); + dispatch(); +} + __attribute__((noreturn)) void main(long magic, volatile void *mboot) { // initalize idt and pic @@ -49,11 +87,7 @@ __attribute__((noreturn)) void main(long magic, volatile void *mboot) kreport(); // load init process - pcb_alloc(&init_pcb); - if (user_load(init_pcb, &fs_disks[0])) - panic("failed to load init"); + load_init(); - // schedule and dispatch init - schedule(init_pcb); - dispatch(); + panic("failed to load init"); } |