blob: e1963e8d787b787a48081a63a35f448c9bcee0b3 [file] [log] [blame]
swissChilie4f01992021-02-25 15:38:12 -08001#include "alloc.h"
swissChilid8137922021-02-17 15:34:07 -08002#include "descriptor_tables.h"
swissChili825d46b2021-02-21 10:14:16 -08003#include "io.h"
4#include "log.h"
swissChilicfd3c3c2021-04-03 15:04:24 -07005#include "multiboot.h"
swissChilie4f01992021-02-25 15:38:12 -08006#include "paging.h"
swissChili4749d022021-07-19 12:33:06 -07007#include "sync.h"
swissChilicfd3c3c2021-04-03 15:04:24 -07008#include "syscall.h"
9#include "task.h"
swissChilidefeb0d2021-02-18 15:28:36 -080010#include "timer.h"
swissChilif5448622021-03-08 20:17:36 -080011#include "vfs.h"
swissChilic2e62ed2021-03-10 17:04:18 -080012#include "vfs_initrd.h"
swissChilicfd3c3c2021-04-03 15:04:24 -070013#include "vga.h"
swissChili1a3f07f2021-04-05 20:01:55 -070014#include <dri/ata_pio/ata_pio.h>
swissChili4418ca52021-06-14 17:36:00 -070015#include <dri/fs/ext2/ext2.h>
swissChili4749d022021-07-19 12:33:06 -070016#include <dri/ide/ide.h>
17#include <dri/pci/pci.h>
swissChilicfd3c3c2021-04-03 15:04:24 -070018
19void greet()
20{
swissChili9bd74de2021-06-15 20:30:48 -070021 kprintf(DEBUG "Hello from get_task_id() = %d, get_process_id() = %d\n",
swissChilicfd3c3c2021-04-03 15:04:24 -070022 get_task_id(), get_process_id());
23}
24
swissChilif01ddcc2021-04-04 11:31:34 -070025void other_thread(size_t data)
swissChilicfd3c3c2021-04-03 15:04:24 -070026{
swissChili9bd74de2021-06-15 20:30:48 -070027 kprintf(DEBUG "data is 0x%x\n", data);
swissChilif01ddcc2021-04-04 11:31:34 -070028 greet();
swissChili9bd74de2021-06-15 20:30:48 -070029 kprintf(DEBUG "Returning from other_thread\n");
swissChilif01ddcc2021-04-04 11:31:34 -070030
31 return;
swissChilicfd3c3c2021-04-03 15:04:24 -070032}
swissChilid8137922021-02-17 15:34:07 -080033
swissChilida23a912021-03-12 16:07:50 -080034int kmain(struct multiboot_info *mboot)
swissChilid8137922021-02-17 15:34:07 -080035{
swissChilie0a79bb2021-02-22 19:54:48 -080036 init_paging();
swissChilidc25b2b2021-02-23 17:07:13 -080037 init_vga();
swissChili0b35bf22021-02-18 12:49:40 -080038 init_descriptor_tables();
swissChili64228692021-03-16 08:19:23 -070039 init_syscall();
swissChili6c0519e2021-03-07 19:40:23 -080040 vga_clear();
swissChilid8137922021-02-17 15:34:07 -080041
swissChili825d46b2021-02-21 10:14:16 -080042 init_timer(20);
swissChilie4f01992021-02-25 15:38:12 -080043 init_allocator();
swissChili19ef4182021-02-21 17:45:51 -080044 init_kbd();
swissChilie4f01992021-02-25 15:38:12 -080045
swissChili6c0519e2021-03-07 19:40:23 -080046#ifdef TEST_ALLOC
47 test_allocator();
48#endif
swissChilie4f01992021-02-25 15:38:12 -080049
swissChili2b5acc82021-03-13 17:06:42 -080050 init_vfs();
swissChili9752ab32021-03-05 11:20:13 -080051
swissChili2b5acc82021-03-13 17:06:42 -080052#ifdef INITRD
swissChilid00ec612022-01-16 21:21:29 -080053 // Load initrd
54 struct multiboot_info mb = make_multiboot_physical(mboot);
55
swissChili9752ab32021-03-05 11:20:13 -080056 kassert(mb.mods_count, "No multiboot modules loaded!");
swissChili9bd74de2021-06-15 20:30:48 -070057 kprintf(DEBUG "mboot->mods_addr = %d (0x%x)\n", mb.mods_addr, mb.mods_addr);
swissChilida23a912021-03-12 16:07:50 -080058 uchar *initrd_loc = (uchar *)((uint *)mb.mods_addr)[0];
swissChili9752ab32021-03-05 11:20:13 -080059
swissChili9bd74de2021-06-15 20:30:48 -070060 kprintf(DEBUG "initrd is at 0x%x to 0x%x\n", initrd_loc);
swissChili9752ab32021-03-05 11:20:13 -080061
swissChili2b5acc82021-03-13 17:06:42 -080062 init_initrd_vfs(initrd_loc);
swissChili9bd74de2021-06-15 20:30:48 -070063 kprintf(OKAY "VFS initialized\n");
swissChili2b5acc82021-03-13 17:06:42 -080064#endif
swissChilib7fe8992021-03-10 16:25:47 -080065
swissChili402a3832021-05-29 21:41:31 -070066 asm("sti");
swissChiliaed6ff32021-05-29 17:51:04 -070067
swissChilib58ab672022-01-17 21:18:01 -080068 init_tasks();
swissChili14d0b842023-01-01 02:22:44 -050069 kprintf(OKAY "Tasks initialized\n");
swissChili4749d022021-07-19 12:33:06 -070070 init_sync();
71
swissChili14d0b842023-01-01 02:22:44 -050072#ifdef TEST_PAGING
73 test_paging();
74#endif
75
76#ifdef TEST_THREADS
77 kprintf(DEBUG "Spawning test thread\n");
swissChilie4229a22023-01-01 15:59:53 -050078 spawn_thread((task_function_t)other_thread, NULL);
swissChili14d0b842023-01-01 02:22:44 -050079
80 greet();
81#endif
82
swissChili5fe85a12021-05-31 08:10:27 -070083 pci_init();
swissChili14d0b842023-01-01 02:22:44 -050084 kprintf(OKAY "PCI initialized\n");
swissChili5fe85a12021-05-31 08:10:27 -070085
86 // Register PCI drivers
87 ide_register();
88
89 pci_load();
90
swissChilie5adca52021-06-16 21:00:31 -070091 kprintf(OKAY "Loaded PCI device drivers\n");
swissChili9bd74de2021-06-15 20:30:48 -070092
swissChiliaed6ff32021-05-29 17:51:04 -070093#ifdef TEST_PCI
swissChili402a3832021-05-29 21:41:31 -070094 pci_print_devices();
swissChili5fe85a12021-05-31 08:10:27 -070095 pci_print_drivers();
swissChiliaed6ff32021-05-29 17:51:04 -070096#endif
97
swissChili4418ca52021-06-14 17:36:00 -070098#ifdef TEST_ATA_PIO
99 test_ata_pio();
100#endif
101
swissChili9bd74de2021-06-15 20:30:48 -0700102 if (ext2_valid_filesystem())
103 {
swissChilib7ef65d2021-07-17 12:51:52 -0700104 kprintf(OKAY "EXT2 filesystem is valid\n");
105 ext2_mount(&root);
swissChili9bd74de2021-06-15 20:30:48 -0700106 }
swissChilib7ef65d2021-07-17 12:51:52 -0700107 else
108 {
swissChili4749d022021-07-19 12:33:06 -0700109 kprintf(
110 WARN
111 "Filesystem is not a valid EXT2 format, only EXT2 is supported\n");
swissChilib7ef65d2021-07-17 12:51:52 -0700112 }
swissChili276b8cf2021-07-16 13:24:42 -0700113
swissChilia664e722021-07-27 17:47:55 -0700114 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
swissChilief97c262021-04-04 10:20:21 -0700122 while (true)
swissChili402a3832021-05-29 21:41:31 -0700123 asm("hlt");
swissChilif01ddcc2021-04-04 11:31:34 -0700124
swissChilid8137922021-02-17 15:34:07 -0800125 return 0xCAFEBABE;
126}