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 | cfd3c3c | 2021-04-03 15:04:24 -0700 | [diff] [blame] | 5 | #include "multiboot.h" |
swissChili | e4f0199 | 2021-02-25 15:38:12 -0800 | [diff] [blame] | 6 | #include "paging.h" |
swissChili | 4749d02 | 2021-07-19 12:33:06 -0700 | [diff] [blame] | 7 | #include "sync.h" |
swissChili | cfd3c3c | 2021-04-03 15:04:24 -0700 | [diff] [blame] | 8 | #include "syscall.h" |
| 9 | #include "task.h" |
swissChili | defeb0d | 2021-02-18 15:28:36 -0800 | [diff] [blame] | 10 | #include "timer.h" |
swissChili | f544862 | 2021-03-08 20:17:36 -0800 | [diff] [blame] | 11 | #include "vfs.h" |
swissChili | c2e62ed | 2021-03-10 17:04:18 -0800 | [diff] [blame] | 12 | #include "vfs_initrd.h" |
swissChili | cfd3c3c | 2021-04-03 15:04:24 -0700 | [diff] [blame] | 13 | #include "vga.h" |
swissChili | 1a3f07f | 2021-04-05 20:01:55 -0700 | [diff] [blame] | 14 | #include <dri/ata_pio/ata_pio.h> |
swissChili | 4418ca5 | 2021-06-14 17:36:00 -0700 | [diff] [blame] | 15 | #include <dri/fs/ext2/ext2.h> |
swissChili | 4749d02 | 2021-07-19 12:33:06 -0700 | [diff] [blame] | 16 | #include <dri/ide/ide.h> |
| 17 | #include <dri/pci/pci.h> |
swissChili | cfd3c3c | 2021-04-03 15:04:24 -0700 | [diff] [blame] | 18 | |
| 19 | void greet() |
| 20 | { |
swissChili | 9bd74de | 2021-06-15 20:30:48 -0700 | [diff] [blame] | 21 | kprintf(DEBUG "Hello from get_task_id() = %d, get_process_id() = %d\n", |
swissChili | cfd3c3c | 2021-04-03 15:04:24 -0700 | [diff] [blame] | 22 | get_task_id(), get_process_id()); |
| 23 | } |
| 24 | |
swissChili | f01ddcc | 2021-04-04 11:31:34 -0700 | [diff] [blame] | 25 | void other_thread(size_t data) |
swissChili | cfd3c3c | 2021-04-03 15:04:24 -0700 | [diff] [blame] | 26 | { |
swissChili | 9bd74de | 2021-06-15 20:30:48 -0700 | [diff] [blame] | 27 | kprintf(DEBUG "data is 0x%x\n", data); |
swissChili | f01ddcc | 2021-04-04 11:31:34 -0700 | [diff] [blame] | 28 | greet(); |
swissChili | 9bd74de | 2021-06-15 20:30:48 -0700 | [diff] [blame] | 29 | kprintf(DEBUG "Returning from other_thread\n"); |
swissChili | f01ddcc | 2021-04-04 11:31:34 -0700 | [diff] [blame] | 30 | |
| 31 | return; |
swissChili | cfd3c3c | 2021-04-03 15:04:24 -0700 | [diff] [blame] | 32 | } |
swissChili | d813792 | 2021-02-17 15:34:07 -0800 | [diff] [blame] | 33 | |
swissChili | da23a91 | 2021-03-12 16:07:50 -0800 | [diff] [blame] | 34 | int kmain(struct multiboot_info *mboot) |
swissChili | d813792 | 2021-02-17 15:34:07 -0800 | [diff] [blame] | 35 | { |
swissChili | e0a79bb | 2021-02-22 19:54:48 -0800 | [diff] [blame] | 36 | init_paging(); |
swissChili | dc25b2b | 2021-02-23 17:07:13 -0800 | [diff] [blame] | 37 | init_vga(); |
swissChili | 0b35bf2 | 2021-02-18 12:49:40 -0800 | [diff] [blame] | 38 | init_descriptor_tables(); |
swissChili | 6422869 | 2021-03-16 08:19:23 -0700 | [diff] [blame] | 39 | init_syscall(); |
swissChili | 6c0519e | 2021-03-07 19:40:23 -0800 | [diff] [blame] | 40 | vga_clear(); |
swissChili | d813792 | 2021-02-17 15:34:07 -0800 | [diff] [blame] | 41 | |
swissChili | 825d46b | 2021-02-21 10:14:16 -0800 | [diff] [blame] | 42 | init_timer(20); |
swissChili | e4f0199 | 2021-02-25 15:38:12 -0800 | [diff] [blame] | 43 | init_allocator(); |
swissChili | 19ef418 | 2021-02-21 17:45:51 -0800 | [diff] [blame] | 44 | init_kbd(); |
swissChili | e4f0199 | 2021-02-25 15:38:12 -0800 | [diff] [blame] | 45 | |
swissChili | 6c0519e | 2021-03-07 19:40:23 -0800 | [diff] [blame] | 46 | #ifdef TEST_ALLOC |
| 47 | test_allocator(); |
| 48 | #endif |
swissChili | e4f0199 | 2021-02-25 15:38:12 -0800 | [diff] [blame] | 49 | |
swissChili | 2b5acc8 | 2021-03-13 17:06:42 -0800 | [diff] [blame] | 50 | init_vfs(); |
swissChili | 9752ab3 | 2021-03-05 11:20:13 -0800 | [diff] [blame] | 51 | |
swissChili | 2b5acc8 | 2021-03-13 17:06:42 -0800 | [diff] [blame] | 52 | #ifdef INITRD |
swissChili | d00ec61 | 2022-01-16 21:21:29 -0800 | [diff] [blame] | 53 | // Load initrd |
| 54 | struct multiboot_info mb = make_multiboot_physical(mboot); |
| 55 | |
swissChili | 9752ab3 | 2021-03-05 11:20:13 -0800 | [diff] [blame] | 56 | kassert(mb.mods_count, "No multiboot modules loaded!"); |
swissChili | 9bd74de | 2021-06-15 20:30:48 -0700 | [diff] [blame] | 57 | kprintf(DEBUG "mboot->mods_addr = %d (0x%x)\n", mb.mods_addr, mb.mods_addr); |
swissChili | da23a91 | 2021-03-12 16:07:50 -0800 | [diff] [blame] | 58 | uchar *initrd_loc = (uchar *)((uint *)mb.mods_addr)[0]; |
swissChili | 9752ab3 | 2021-03-05 11:20:13 -0800 | [diff] [blame] | 59 | |
swissChili | 9bd74de | 2021-06-15 20:30:48 -0700 | [diff] [blame] | 60 | kprintf(DEBUG "initrd is at 0x%x to 0x%x\n", initrd_loc); |
swissChili | 9752ab3 | 2021-03-05 11:20:13 -0800 | [diff] [blame] | 61 | |
swissChili | 2b5acc8 | 2021-03-13 17:06:42 -0800 | [diff] [blame] | 62 | init_initrd_vfs(initrd_loc); |
swissChili | 9bd74de | 2021-06-15 20:30:48 -0700 | [diff] [blame] | 63 | kprintf(OKAY "VFS initialized\n"); |
swissChili | 2b5acc8 | 2021-03-13 17:06:42 -0800 | [diff] [blame] | 64 | #endif |
swissChili | b7fe899 | 2021-03-10 16:25:47 -0800 | [diff] [blame] | 65 | |
swissChili | 402a383 | 2021-05-29 21:41:31 -0700 | [diff] [blame] | 66 | asm("sti"); |
swissChili | aed6ff3 | 2021-05-29 17:51:04 -0700 | [diff] [blame] | 67 | |
swissChili | b58ab67 | 2022-01-17 21:18:01 -0800 | [diff] [blame] | 68 | init_tasks(); |
swissChili | 14d0b84 | 2023-01-01 02:22:44 -0500 | [diff] [blame] | 69 | kprintf(OKAY "Tasks initialized\n"); |
swissChili | 4749d02 | 2021-07-19 12:33:06 -0700 | [diff] [blame] | 70 | init_sync(); |
| 71 | |
swissChili | 14d0b84 | 2023-01-01 02:22:44 -0500 | [diff] [blame] | 72 | #ifdef TEST_PAGING |
| 73 | test_paging(); |
| 74 | #endif |
| 75 | |
| 76 | #ifdef TEST_THREADS |
| 77 | kprintf(DEBUG "Spawning test thread\n"); |
swissChili | e4229a2 | 2023-01-01 15:59:53 -0500 | [diff] [blame^] | 78 | spawn_thread((task_function_t)other_thread, NULL); |
swissChili | 14d0b84 | 2023-01-01 02:22:44 -0500 | [diff] [blame] | 79 | |
| 80 | greet(); |
| 81 | #endif |
| 82 | |
swissChili | 5fe85a1 | 2021-05-31 08:10:27 -0700 | [diff] [blame] | 83 | pci_init(); |
swissChili | 14d0b84 | 2023-01-01 02:22:44 -0500 | [diff] [blame] | 84 | kprintf(OKAY "PCI initialized\n"); |
swissChili | 5fe85a1 | 2021-05-31 08:10:27 -0700 | [diff] [blame] | 85 | |
| 86 | // Register PCI drivers |
| 87 | ide_register(); |
| 88 | |
| 89 | pci_load(); |
| 90 | |
swissChili | e5adca5 | 2021-06-16 21:00:31 -0700 | [diff] [blame] | 91 | kprintf(OKAY "Loaded PCI device drivers\n"); |
swissChili | 9bd74de | 2021-06-15 20:30:48 -0700 | [diff] [blame] | 92 | |
swissChili | aed6ff3 | 2021-05-29 17:51:04 -0700 | [diff] [blame] | 93 | #ifdef TEST_PCI |
swissChili | 402a383 | 2021-05-29 21:41:31 -0700 | [diff] [blame] | 94 | pci_print_devices(); |
swissChili | 5fe85a1 | 2021-05-31 08:10:27 -0700 | [diff] [blame] | 95 | pci_print_drivers(); |
swissChili | aed6ff3 | 2021-05-29 17:51:04 -0700 | [diff] [blame] | 96 | #endif |
| 97 | |
swissChili | 4418ca5 | 2021-06-14 17:36:00 -0700 | [diff] [blame] | 98 | #ifdef TEST_ATA_PIO |
| 99 | test_ata_pio(); |
| 100 | #endif |
| 101 | |
swissChili | 9bd74de | 2021-06-15 20:30:48 -0700 | [diff] [blame] | 102 | if (ext2_valid_filesystem()) |
| 103 | { |
swissChili | b7ef65d | 2021-07-17 12:51:52 -0700 | [diff] [blame] | 104 | kprintf(OKAY "EXT2 filesystem is valid\n"); |
| 105 | ext2_mount(&root); |
swissChili | 9bd74de | 2021-06-15 20:30:48 -0700 | [diff] [blame] | 106 | } |
swissChili | b7ef65d | 2021-07-17 12:51:52 -0700 | [diff] [blame] | 107 | else |
| 108 | { |
swissChili | 4749d02 | 2021-07-19 12:33:06 -0700 | [diff] [blame] | 109 | kprintf( |
| 110 | WARN |
| 111 | "Filesystem is not a valid EXT2 format, only EXT2 is supported\n"); |
swissChili | b7ef65d | 2021-07-17 12:51:52 -0700 | [diff] [blame] | 112 | } |
swissChili | 276b8cf | 2021-07-16 13:24:42 -0700 | [diff] [blame] | 113 | |
swissChili | a664e72 | 2021-07-27 17:47:55 -0700 | [diff] [blame] | 114 | kprintf(INFO "fs_readdir(\"/\") mnt=%p\n", root.mount); |
| 115 | |
| 116 | struct fs_dirent dirent; |
| 117 | for (int i = 0; fs_readdir(&root, i, &dirent); i++) |
| 118 | { |
| 119 | kprintf(INFO "name: %s, inode: %d\n", dirent.name, dirent.inode); |
| 120 | } |
| 121 | |
swissChili | ef97c26 | 2021-04-04 10:20:21 -0700 | [diff] [blame] | 122 | while (true) |
swissChili | 402a383 | 2021-05-29 21:41:31 -0700 | [diff] [blame] | 123 | asm("hlt"); |
swissChili | f01ddcc | 2021-04-04 11:31:34 -0700 | [diff] [blame] | 124 | |
swissChili | d813792 | 2021-02-17 15:34:07 -0800 | [diff] [blame] | 125 | return 0xCAFEBABE; |
| 126 | } |