2022-10-04 16:36:09 +00:00
|
|
|
#define MODULE "init"
|
|
|
|
|
2022-09-05 14:13:51 +00:00
|
|
|
#include "init/Init.h"
|
|
|
|
#include "bootboot.h"
|
|
|
|
#include "cpu/CPU.h"
|
2022-09-19 15:06:08 +00:00
|
|
|
#include "init/InitRD.h"
|
2022-09-05 14:13:51 +00:00
|
|
|
#include "interrupts/Interrupts.h"
|
|
|
|
#include "io/Serial.h"
|
2022-09-15 16:42:59 +00:00
|
|
|
#include "log/Log.h"
|
2022-09-24 19:45:13 +00:00
|
|
|
#include "memory/MemoryManager.h"
|
2022-09-24 19:27:45 +00:00
|
|
|
#include "memory/PMM.h"
|
2022-09-06 11:49:17 +00:00
|
|
|
#include "memory/VMM.h"
|
2022-09-21 15:56:53 +00:00
|
|
|
#include "misc/hang.h"
|
2022-09-14 16:54:40 +00:00
|
|
|
#include "rand/Init.h"
|
|
|
|
#include "rand/Mersenne.h"
|
2022-09-10 16:42:40 +00:00
|
|
|
#include "render/Framebuffer.h"
|
2022-09-05 14:13:51 +00:00
|
|
|
#include "render/TextRenderer.h"
|
2022-10-19 15:41:23 +00:00
|
|
|
#include "std/assert.h"
|
2022-09-15 16:42:59 +00:00
|
|
|
#include "std/string.h"
|
2022-09-05 14:13:51 +00:00
|
|
|
|
|
|
|
extern BOOTBOOT bootboot;
|
2022-09-15 16:42:59 +00:00
|
|
|
extern "C" char environment[4096];
|
2022-09-05 14:13:51 +00:00
|
|
|
|
2022-09-14 16:54:40 +00:00
|
|
|
uintptr_t __stack_chk_guard = 0xfeff34;
|
|
|
|
|
2022-09-05 14:13:51 +00:00
|
|
|
void Init::check_magic()
|
|
|
|
{
|
|
|
|
ASSERT(strncmp((char*)bootboot.magic, BOOTBOOT_MAGIC, 4) == 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
void Init::disable_smp()
|
|
|
|
{
|
|
|
|
if (CPU::get_initial_apic_id() != bootboot.bspid) { hang(); }
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2022-10-02 16:53:54 +00:00
|
|
|
extern "C" void asm_enable_sse();
|
|
|
|
|
2022-09-05 14:13:51 +00:00
|
|
|
void Init::early_init()
|
|
|
|
{
|
|
|
|
Interrupts::disable();
|
|
|
|
asm volatile("cld");
|
|
|
|
|
2022-10-02 16:53:54 +00:00
|
|
|
asm_enable_sse();
|
|
|
|
|
2022-09-10 16:42:40 +00:00
|
|
|
framebuffer0.init((void*)bootboot.fb_ptr, bootboot.fb_type, bootboot.fb_scanline, bootboot.fb_width,
|
|
|
|
bootboot.fb_height);
|
2022-09-06 11:21:54 +00:00
|
|
|
|
2022-09-25 15:38:17 +00:00
|
|
|
MemoryManager::init();
|
2022-09-14 16:54:40 +00:00
|
|
|
|
2022-09-15 16:42:59 +00:00
|
|
|
if (strstr(environment, "quiet=1"))
|
|
|
|
{
|
|
|
|
KernelLog::toggle_log_level(LogLevel::DEBUG);
|
|
|
|
KernelLog::toggle_log_level(LogLevel::INFO);
|
|
|
|
}
|
|
|
|
else if (!strstr(environment, "verbose=1")) { KernelLog::toggle_log_level(LogLevel::DEBUG); }
|
|
|
|
|
2022-10-01 13:35:11 +00:00
|
|
|
InitRD::init();
|
|
|
|
|
2022-09-14 16:54:40 +00:00
|
|
|
Mersenne::init();
|
|
|
|
|
2022-10-04 16:36:09 +00:00
|
|
|
kdbgln("Page bitmap uses %ld bytes of memory", PMM::get_bitmap_size());
|
|
|
|
|
2022-09-14 16:54:40 +00:00
|
|
|
__stack_chk_guard = Mersenne::get();
|
2022-10-01 13:35:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void Init::finish_kernel_boot()
|
|
|
|
{
|
|
|
|
KernelLog::toggle_log_backend(Backend::Console);
|
|
|
|
framebuffer0.clear(Color::Black);
|
|
|
|
TextRenderer::reset();
|
2022-09-05 14:13:51 +00:00
|
|
|
}
|