swissChili | e4f0199 | 2021-02-25 15:38:12 -0800 | [diff] [blame] | 1 | #include "alloc.h" |
swissChili | d813792 | 2021-02-17 15:34:07 -0800 | [diff] [blame] | 2 | #include "descriptor_tables.h" |
swissChili | 825d46b | 2021-02-21 10:14:16 -0800 | [diff] [blame] | 3 | #include "io.h" |
| 4 | #include "log.h" |
swissChili | e4f0199 | 2021-02-25 15:38:12 -0800 | [diff] [blame] | 5 | #include "paging.h" |
swissChili | defeb0d | 2021-02-18 15:28:36 -0800 | [diff] [blame] | 6 | #include "timer.h" |
swissChili | 825d46b | 2021-02-21 10:14:16 -0800 | [diff] [blame] | 7 | #include "vga.h" |
swissChili | f544862 | 2021-03-08 20:17:36 -0800 | [diff] [blame] | 8 | #include "vfs.h" |
swissChili | 9752ab3 | 2021-03-05 11:20:13 -0800 | [diff] [blame] | 9 | #include "multiboot.h" |
swissChili | d813792 | 2021-02-17 15:34:07 -0800 | [diff] [blame] | 10 | |
swissChili | 9752ab3 | 2021-03-05 11:20:13 -0800 | [diff] [blame] | 11 | int kmain(struct multiboot *mboot) |
swissChili | d813792 | 2021-02-17 15:34:07 -0800 | [diff] [blame] | 12 | { |
swissChili | e0a79bb | 2021-02-22 19:54:48 -0800 | [diff] [blame] | 13 | init_paging(); |
swissChili | dc25b2b | 2021-02-23 17:07:13 -0800 | [diff] [blame] | 14 | init_vga(); |
swissChili | 0b35bf2 | 2021-02-18 12:49:40 -0800 | [diff] [blame] | 15 | init_descriptor_tables(); |
swissChili | 6c0519e | 2021-03-07 19:40:23 -0800 | [diff] [blame] | 16 | vga_clear(); |
swissChili | d813792 | 2021-02-17 15:34:07 -0800 | [diff] [blame] | 17 | |
swissChili | 825d46b | 2021-02-21 10:14:16 -0800 | [diff] [blame] | 18 | init_timer(20); |
swissChili | e4f0199 | 2021-02-25 15:38:12 -0800 | [diff] [blame] | 19 | init_allocator(); |
swissChili | 19ef418 | 2021-02-21 17:45:51 -0800 | [diff] [blame] | 20 | init_kbd(); |
swissChili | e4f0199 | 2021-02-25 15:38:12 -0800 | [diff] [blame] | 21 | |
swissChili | 6c0519e | 2021-03-07 19:40:23 -0800 | [diff] [blame] | 22 | #ifdef TEST_ALLOC |
| 23 | test_allocator(); |
| 24 | #endif |
swissChili | e4f0199 | 2021-02-25 15:38:12 -0800 | [diff] [blame] | 25 | |
swissChili | 9752ab3 | 2021-03-05 11:20:13 -0800 | [diff] [blame] | 26 | // Load initrd |
| 27 | struct multiboot mb = make_multiboot_physical(mboot); |
| 28 | |
| 29 | kassert(mb.mods_count, "No multiboot modules loaded!"); |
| 30 | kprintf("mboot->mods_addr = %d (0x%x)\n", mb.mods_addr, mb.mods_addr); |
swissChili | 6c0519e | 2021-03-07 19:40:23 -0800 | [diff] [blame] | 31 | uchar *initrd_loc = mb.mods_addr[0]; |
swissChili | 9752ab3 | 2021-03-05 11:20:13 -0800 | [diff] [blame] | 32 | |
swissChili | 6c0519e | 2021-03-07 19:40:23 -0800 | [diff] [blame] | 33 | kprintf("initrd is at 0x%x to 0x%x\n", initrd_loc); |
swissChili | 9752ab3 | 2021-03-05 11:20:13 -0800 | [diff] [blame] | 34 | |
swissChili | f544862 | 2021-03-08 20:17:36 -0800 | [diff] [blame] | 35 | init_vfs(); |
| 36 | kprintf("VFS initialized\n"); |
| 37 | |
| 38 | vga_set_color(LIGHT_GREEN, BLACK); |
| 39 | vga_write("Setup complete!\n"); |
| 40 | vga_set_color(WHITE, BLACK); |
| 41 | |
swissChili | b7fe899 | 2021-03-10 16:25:47 -0800 | [diff] [blame^] | 42 | kprintf("fs_readdir(\"/\")\n"); |
| 43 | |
| 44 | struct fs_dirent dirent; |
| 45 | for (int i = 0; fs_readdir(&root, i, &dirent); i++) |
| 46 | { |
| 47 | kprintf("name: %s, inode: %d\n", dirent.name, dirent.inode); |
| 48 | } |
| 49 | |
swissChili | defeb0d | 2021-02-18 15:28:36 -0800 | [diff] [blame] | 50 | asm volatile("sti"); |
| 51 | |
swissChili | 825d46b | 2021-02-21 10:14:16 -0800 | [diff] [blame] | 52 | while (true) |
| 53 | asm volatile("hlt"); |
| 54 | |
swissChili | d813792 | 2021-02-17 15:34:07 -0800 | [diff] [blame] | 55 | return 0xCAFEBABE; |
| 56 | } |