summaryrefslogtreecommitdiff
path: root/arch/i386/kernel/multiboot.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/i386/kernel/multiboot.c')
-rw-r--r--arch/i386/kernel/multiboot.c46
1 files changed, 33 insertions, 13 deletions
diff --git a/arch/i386/kernel/multiboot.c b/arch/i386/kernel/multiboot.c
index d7f0a65..87876f0 100644
--- a/arch/i386/kernel/multiboot.c
+++ b/arch/i386/kernel/multiboot.c
@@ -1,23 +1,43 @@
#include <kernel/multiboot.h>
-#include <kernel/tty.h>
+#include <kernel/asm.h>
+#include <kernel/gdt.h>
+#include <kernel/idt.h>
+#include <kernel/pic.h>
+#include <kernel/paging.h>
+#include <kernel/mem.h>
+#include <kernel/keyboard.h>
+#include <kernel/framebuffer.h>
+#include <kernel/timer.h>
#include <kernel/panic.h>
#include <kernel/io.h>
+extern void kernel_main(char *cmdline);
+
void i386_entry(uint32_t mboot_magic, struct mboot_info *header) {
paging_init();
- tty_init();
+ fb_init();
+ gdt_install();
+ idt_install();
+ pic_remap();
+ timer_init();
- struct mboot_info *vheader = get_vaddr(header);
- mark_bitmap(header, 1);
- map_page(header, vheader, 0x003);
+ register_irq_handler(1, keyboard_handler);
+ enable_ints();
- if (mboot_magic != MBOOT_LOADER_MAGIC)
- panic("NOT BOOTED WITH MULTIBOOT BOOTLOADER");
- if (!(vheader->flags >> 6 & 0x1))
- panic("NO MEMORY MAP FROM BOOTLOADER");
+ if (mboot_magic != MBOOT_LOADER_MAGIC) {
+ fb_write("NOT BOOTED WITH MULTIBOOT BOOTLOADER\n", 37);
+ fb_write("RESET PC!\n", 10);
+ disable_ints();
+ while (1);
+ }
+ if (!(header->flags >> 6 & 0x1)) {
+ fb_write("NO MEMORY MAP FROM BOOTLOADER\n", 30);
+ fb_write("RESET PC!\n", 10);
+ disable_ints();
+ while (1);
+ }
- gdt_install();
- idt_install();
- alloc_init(vheader);
- kernel_main(vheader->cmdline);
+ kernel_main((char*)header->cmdline);
+
+ while (1);
}