quark/src/kernel/main.c

77 líneas
2,3 KiB
C

#include <stdint.h>
#include "lib/stdio.h"
#include "hal/hal.h"
#include "drivers/keyboard.h"
#include "drivers/uart.h"
#include "drivers/initrd.h"
#include "fs/vfs.h"
#include "arch/i686/mm/pmm.h"
#include "arch/i686/mm/vmm.h"
#include "multiboot.h"
#include "lib/debug.h"
#include "arch/i686/fdc.h"
#include "shell.h"
extern uint8_t end; // Kernel end
void __attribute__((cdecl)) kmain(multiboot_info_t *multiboot_info){
// Clear screen
clear_screen();
// Initialize chip-specific hardware
hal_initialize();
// Initialize serial
uart_initialize(COM1, 2);
// Initialize drivers
keyboard_initialize();
// Initialize physical memory manager
uint32_t mem_size = 1024 + multiboot_info->mem_lower + multiboot_info->mem_upper*64;
i686_pmm_initialize(mem_size, (int)(&end));
// Memory map
debug_printf("= Memory map =\n");
for(int i = 0; i < multiboot_info->mmap_length; i += sizeof(multiboot_memory_map_t)){
multiboot_memory_map_t *memory_map = (multiboot_memory_map_t *)(multiboot_info->mmap_addr + i);
debug_printf("Start Addr: 0x%x%x | Length: 0x%x%x | Size: 0x%x | Type: %i\n", memory_map->addr_h, memory_map->addr_l, memory_map->len_h, memory_map->len_l, memory_map->size, memory_map->type);
if(memory_map->type == 1){
i686_pmm_init_region(memory_map->addr_l, memory_map->len_l);
}
}
i686_pmm_deinit_region(0x100000, (int)(&end) - 0x100000); // Deinit the section the kernel is in
// Initialize virtual memory
i686_vmm_initialize();
// Floppy disk controller
i686_fdc_set_working_drive(0);
i686_fdc_initialize();
debug_printf("Multiboot modules: (%d)\n", multiboot_info->mods_count);
if(multiboot_info->mods_count == 1){
debug_printf("Loading initrd...\n");
multiboot_module_t *module;
module = (multiboot_module_t *)multiboot_info->mods_addr;
debug_printf("Initrd module structure: start=0x%x end=0x%x cmdline=%s\n", module->start, module->end, module->cmdline);
debug_printf("%d\n", module->start);
}
else{
debug_printf("WARNING: mods_count is not 1, not loading the initrd");
}
// Initialize FS
vfs_initialize();
// Run shell
shell();
// Halt at end
debug_printf("Kernel execution ended\n");
for(;;);
}