#define FOOLOS_MODULE_NAME "kernel" #ifdef __linux__ #error "Watchout! this is not Linux but FoolOS. Use a cross-compiler" #endif #include "kernel.h" #include #include "config.h" #include "types.h" #include "lib/logger/log.h" #include "timer.h" #include "mem.h" #include "vmem.h" #include "interrupts.h" #include "multiboot.h" #include "console.h" #include // for built-in shell #include "lib/buffer/ringbuffer.h" #include "task.h" #include "video/vesa.h" #include "multiboot.h" void kernel_main(uint32_t eax,uint32_t ebx) { // // Init Console // uint32_t physbase=console_init(0,0); // // PR // log(FOOLOS_MODULE_NAME,FOOLOS_LOG_INFO,"%s - compiled on %s at %s",KERNEL_VERSION,__DATE__,__TIME__); // // Configuring the PIT timer. // timer_init(); // // Process Multiboot Header // multiboot_information *info=get_multiboot(eax, ebx); // // Memory Init // // after this is set up we will be able to allocate and deallocate // blocks of physical memory :) // // we know that here, the bootloader placed the memory map and // its length // mem_init(info); //info->mmap_addr,info->mmap_length); // // Video TODO // /* log(FOOLOS_MODULE_NAME,FOOLOS_LOG_INFO,"VBE Info: 0x%04X (0x%08X 0x%08X)",info->vbe_mode,info->vbe_control_info, info->vbe_mode_info); vbeinfo *vbe=info->vbe_mode_info; //log(FOOLOS_MODULE_NAME,FOOLOS_LOG_INFO,"%c%c",'X',vbe->VbeSignature[0]); uint16_t VbeVersion; // == 0x0300 for VBE 3.0 uint16_t OemStringPtr[2]; // isa vbeFarPtr uint8_t Capabilities[4]; uint16_t VideoModePtr[2]; // isa vbeFarPtr uint16_t TotalMemory; // as # of 64KB blocks */ // // Activate Virtual Memory (paging) // pdirectory *dir=vmem_init(physbase); // // Setup Interrupts (code segment: 0x08) // int_init(0x08); while(1); // // Scan the PCI Bus // // We are interested in the E1000 Network Adapter in particular // Its driver will be hopefully implemented one day ;) TODO // //pci_init(); // // Gather Info about other processors. (APs) // ACPI or MP // // /* smp_processors procdata; if(!acpi_find(&procdata)) if(!mp_find(&procdata)) panic(FOOLOS_MODULE_NAME,"ACPI and MP search failed! I do not want to continue!"); */ // // Start the other Processors (also before paging for some reason!) // //smp_log_procdata(&procdata); //smp_start_aps(&procdata,0x80000); // starts at 0x80000 // but it will be copied over mbr // // Initialize Multitasking // task_init(dir); //; this will never return! // }