summaryrefslogtreecommitdiff
path: root/kernel/src/main.c
diff options
context:
space:
mode:
authorAleksa Vuckovic <aleksav013@gmail.com>2022-11-26 00:22:10 +0100
committerAleksa Vuckovic <aleksav013@gmail.com>2022-11-27 01:04:18 +0100
commitd43a3388a976a74ae109c5b8b5a31f82a16b45db (patch)
tree51880414ee600ddfb3c7e3486c3d74beced36bfe /kernel/src/main.c
parent5d56d1a5b4d52702eb4e4ea6f05e4b6eebf41ca8 (diff)
fixing issues
1) main.c: order of init (multiboot.c must be after heap & paging because it uses heap to allocate pages for framebuffer) 2) paging.c: zeroing new pages allocated via heap 3) multiboot2.c: invalid pointer arithmetic 4) libk/string.c: check for null pointers in memcpy 5) paging: only page_lvl2 should have FLAG_HUGE 6) keyboard.c: kfree(print_buff)
Diffstat (limited to 'kernel/src/main.c')
-rw-r--r--kernel/src/main.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/kernel/src/main.c b/kernel/src/main.c
index 7424f56..ae2e0ee 100644
--- a/kernel/src/main.c
+++ b/kernel/src/main.c
@@ -5,6 +5,7 @@
#include <paging.h>
#include <heap.h>
#include <keyboard.h>
+#include <libk/serial_stdio.h>
#include <libk/stdio.h>
#include <libk/string.h>
#include <libk/math.h>
@@ -20,16 +21,18 @@ int kernel_main(mb2_tag_header* multiboot_bootinfo, uint32_t multiboot_magic);
int kernel_main(mb2_tag_header* multiboot_bootinfo, uint32_t multiboot_magic)
{
init_serial();
+// serial is enabled from this point
init_gdt();
init_paging();
- init_timer(TICKS_PER_SECOND);
- init_idt();
init_heap();
- init_tss();
read_mb2(multiboot_bootinfo, multiboot_magic);
+// framebuffer is enabled from this point
+ init_timer(TICKS_PER_SECOND);
+ init_idt();
disc_init();
ext2_init();
ls(path_to_inode("/"));
+ init_tss();
jump_userspace();
for(;;) {