2022-09-07 13:02:23 +00:00
|
|
|
#define MODULE "main"
|
|
|
|
|
2022-09-05 14:13:51 +00:00
|
|
|
#include "acpi/RSDT.h"
|
2022-09-11 06:23:32 +00:00
|
|
|
#include "assert.h"
|
2022-09-07 13:02:54 +00:00
|
|
|
#include "config.h"
|
2022-09-05 14:13:51 +00:00
|
|
|
#include "cpu/CPU.h"
|
|
|
|
#include "gdt/GDT.h"
|
|
|
|
#include "init/Init.h"
|
2022-09-14 15:55:24 +00:00
|
|
|
#include "init/InitRD.h"
|
2022-09-05 14:13:51 +00:00
|
|
|
#include "interrupts/IDT.h"
|
|
|
|
#include "interrupts/Install.h"
|
|
|
|
#include "interrupts/Interrupts.h"
|
2022-09-21 15:57:02 +00:00
|
|
|
#include "io/PCI.h"
|
2022-09-05 14:13:51 +00:00
|
|
|
#include "io/PIC.h"
|
2022-09-20 17:58:04 +00:00
|
|
|
#include "io/Serial.h"
|
2022-09-05 14:13:51 +00:00
|
|
|
#include "log/Log.h"
|
2022-09-05 15:13:12 +00:00
|
|
|
#include "memory/Memory.h"
|
2022-09-24 19:45:13 +00:00
|
|
|
#include "memory/MemoryManager.h"
|
2022-09-07 17:41:08 +00:00
|
|
|
#include "memory/MemoryMap.h"
|
2022-09-24 19:27:45 +00:00
|
|
|
#include "memory/PMM.h"
|
2022-09-23 14:41:43 +00:00
|
|
|
#include "memory/VMM.h"
|
2022-09-23 16:01:07 +00:00
|
|
|
#include "misc/PCITypes.h"
|
2022-09-21 15:56:53 +00:00
|
|
|
#include "misc/reboot.h"
|
2022-09-25 14:56:00 +00:00
|
|
|
#include "panic/Panic.h"
|
2022-09-14 16:54:40 +00:00
|
|
|
#include "rand/Mersenne.h"
|
2022-09-10 16:42:40 +00:00
|
|
|
#include "render/Framebuffer.h"
|
2022-09-11 06:23:32 +00:00
|
|
|
#include "render/TextRenderer.h"
|
2022-09-05 14:13:51 +00:00
|
|
|
#include "std/stdio.h"
|
|
|
|
#include "std/stdlib.h"
|
|
|
|
#include "std/string.h"
|
2022-10-01 10:17:16 +00:00
|
|
|
#include "sys/elf/ELFLoader.h"
|
2022-09-21 15:56:53 +00:00
|
|
|
#include "thread/PIT.h"
|
2022-09-20 17:58:04 +00:00
|
|
|
#include "thread/Scheduler.h"
|
2022-09-05 14:13:51 +00:00
|
|
|
|
2022-09-25 18:35:05 +00:00
|
|
|
extern "C" void _userspace();
|
|
|
|
|
2022-09-05 14:13:51 +00:00
|
|
|
extern "C" void _start()
|
|
|
|
{
|
|
|
|
Init::check_magic();
|
|
|
|
Init::disable_smp(); // Put all other cores except the bootstrap one in an infinite loop
|
|
|
|
Init::early_init();
|
|
|
|
|
2022-09-20 14:34:24 +00:00
|
|
|
kinfoln("Starting Moon %s", moon_version());
|
2022-09-07 17:41:08 +00:00
|
|
|
|
|
|
|
CPU::log_cpu_information();
|
|
|
|
|
|
|
|
Memory::walk_memory_map();
|
2022-09-05 14:13:51 +00:00
|
|
|
|
|
|
|
GDT::load();
|
|
|
|
|
|
|
|
kinfoln("Loaded GDT");
|
|
|
|
|
|
|
|
Interrupts::install();
|
|
|
|
|
|
|
|
IDT::load();
|
|
|
|
|
|
|
|
kinfoln("Loaded IDT");
|
|
|
|
|
|
|
|
PIC::remap();
|
|
|
|
PIC::enable_master(0b11111100); // enable keyboard and PIT
|
|
|
|
PIC::enable_slave(0b11111111);
|
|
|
|
|
|
|
|
kinfoln("Prepared PIC");
|
|
|
|
|
2022-09-25 20:00:36 +00:00
|
|
|
PIT::initialize(1000); // 1000 times per second
|
2022-09-05 14:13:51 +00:00
|
|
|
|
|
|
|
kinfoln("Prepared PIT");
|
|
|
|
|
2022-09-20 17:58:04 +00:00
|
|
|
Scheduler::init();
|
2022-09-05 14:13:51 +00:00
|
|
|
|
2022-09-20 17:58:04 +00:00
|
|
|
kinfoln("Prepared scheduler");
|
|
|
|
|
2022-10-01 12:27:45 +00:00
|
|
|
/*Scheduler::add_kernel_task([]() {
|
2022-09-20 18:49:31 +00:00
|
|
|
int64_t x = 0;
|
|
|
|
int64_t y = 0;
|
|
|
|
int64_t xvel = 10;
|
|
|
|
int64_t yvel = 10;
|
2022-09-20 17:58:04 +00:00
|
|
|
while (1)
|
|
|
|
{
|
2022-09-25 20:00:36 +00:00
|
|
|
sleep(2);
|
2022-09-20 18:49:31 +00:00
|
|
|
uint32_t color = (uint32_t)Mersenne::get();
|
|
|
|
x += xvel;
|
|
|
|
y += yvel;
|
|
|
|
if ((x + 10) >= framebuffer0.width())
|
|
|
|
{
|
|
|
|
xvel = -xvel;
|
|
|
|
x = (framebuffer0.width() - 10);
|
|
|
|
}
|
|
|
|
if ((y + 10) >= framebuffer0.height())
|
|
|
|
{
|
|
|
|
yvel = -yvel;
|
|
|
|
y = (framebuffer0.height() - 10);
|
|
|
|
}
|
|
|
|
if (xvel < 0 && (x - 10) < 0)
|
|
|
|
{
|
|
|
|
xvel = -xvel;
|
|
|
|
x = 0;
|
|
|
|
}
|
|
|
|
if (yvel < 0 && (y - 10) < 0)
|
|
|
|
{
|
|
|
|
yvel = -yvel;
|
|
|
|
y = 0;
|
|
|
|
}
|
2022-10-01 11:08:47 +00:00
|
|
|
framebuffer0.paint_rect(x, y, 10, 10, Color::from_integer(color));
|
2022-09-20 17:58:04 +00:00
|
|
|
}
|
2022-10-01 12:27:45 +00:00
|
|
|
});*/
|
2022-09-20 17:58:04 +00:00
|
|
|
|
2022-10-01 12:27:45 +00:00
|
|
|
/*Scheduler::add_kernel_task([]() {
|
2022-09-20 17:58:04 +00:00
|
|
|
while (1)
|
|
|
|
{
|
2022-09-25 20:00:36 +00:00
|
|
|
sleep(100);
|
2022-09-20 18:49:31 +00:00
|
|
|
uint32_t color = (uint32_t)Mersenne::get();
|
|
|
|
framebuffer0.paint_rect(Mersenne::get() % (framebuffer0.width() - 256),
|
|
|
|
Mersenne::get() % (framebuffer0.height() - 256), Mersenne::get() % 255,
|
2022-10-01 11:08:47 +00:00
|
|
|
Mersenne::get() % 255, Color::from_integer(color));
|
2022-09-20 17:58:04 +00:00
|
|
|
}
|
2022-10-01 12:27:45 +00:00
|
|
|
});*/
|
2022-09-20 17:58:04 +00:00
|
|
|
|
2022-09-21 19:06:00 +00:00
|
|
|
Scheduler::add_kernel_task([]() {
|
|
|
|
while (1)
|
|
|
|
{
|
|
|
|
sleep(400);
|
|
|
|
Scheduler::reap_tasks();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2022-10-03 19:24:38 +00:00
|
|
|
int demo = Mersenne::get() % 5;
|
|
|
|
|
|
|
|
switch (demo)
|
|
|
|
{
|
|
|
|
case 0:
|
|
|
|
kinfoln("Loading demo: example init program");
|
|
|
|
Scheduler::load_user_task("bin/init");
|
|
|
|
break;
|
|
|
|
case 1:
|
|
|
|
kinfoln("Loading demo: first 50 fibonacci numbers");
|
|
|
|
Scheduler::load_user_task("bin/fib");
|
|
|
|
break;
|
|
|
|
case 2:
|
|
|
|
kinfoln("Loading demo: leap year calculator");
|
|
|
|
Scheduler::load_user_task("bin/leap");
|
|
|
|
break;
|
|
|
|
case 3:
|
|
|
|
kinfoln("Loading demo: painting program");
|
|
|
|
Scheduler::load_user_task("bin/art");
|
|
|
|
break;
|
|
|
|
case 4:
|
|
|
|
kinfoln("Loading demo: memory eating program");
|
|
|
|
Scheduler::load_user_task("bin/memeater");
|
|
|
|
break;
|
|
|
|
}
|
2022-09-25 18:35:05 +00:00
|
|
|
|
2022-09-20 17:58:04 +00:00
|
|
|
kinfoln("Prepared scheduler tasks");
|
2022-09-05 14:13:51 +00:00
|
|
|
|
2022-10-01 13:35:11 +00:00
|
|
|
Init::finish_kernel_boot();
|
|
|
|
|
2022-09-20 17:58:04 +00:00
|
|
|
Interrupts::enable();
|
2022-09-06 09:48:06 +00:00
|
|
|
|
2022-09-20 17:58:04 +00:00
|
|
|
kinfoln("Interrupts enabled");
|
|
|
|
|
2022-09-23 15:24:45 +00:00
|
|
|
PCI::scan([](PCI::Device& dev) {
|
2022-09-23 16:01:07 +00:00
|
|
|
kinfoln("Found PCI device %x:%x, %s", dev.id().vendor, dev.id().device, pci_type_name(dev.type()));
|
2022-09-21 15:57:02 +00:00
|
|
|
});
|
|
|
|
|
2022-09-21 19:06:00 +00:00
|
|
|
Scheduler::exit();
|
2022-09-05 14:13:51 +00:00
|
|
|
}
|