Files
Sylva/kernel/main.cpp
T
2026-05-29 19:25:56 +08:00

101 lines
2.9 KiB
C++

#include <efi.h>
#include <graphics/context.h>
#include <graphics/draw.h>
#include <fonts/pixel_font.h>
#include <serial.h>
#include <common.h>
#include <memory/pmm.h>
#include <memory/heap.h>
extern EFI_SYSTEM_TABLE *ST;
inline void init_gop() {
// 初始化 GOP
EFI_GUID gop_guid = EFI_GRAPHICS_OUTPUT_PROTOCOL_GUID;
EFI_GRAPHICS_OUTPUT_PROTOCOL *GOP;
uefi_call_wrapper(ST->BootServices->SetWatchdogTimer, 4, 0, 0, 0, NULL);
uefi_call_wrapper(ST->BootServices->LocateProtocol, 3, &gop_guid, NULL, (void **)&GOP);
gfx_init(GOP);
}
inline void init_serial() {
// 初始化串行驱动
EFI_SERIAL_IO_PROTOCOL *SerialIo = NULL;
EFI_GUID gEfiSerialIoProtocolGuid = EFI_SERIAL_IO_PROTOCOL_GUID;
EFI_HANDLE *SerialHandles = NULL;
UINTN NumSerials = 0;
EFI_STATUS status = uefi_call_wrapper(ST->BootServices->LocateHandleBuffer, 5,
ByProtocol,
&gEfiSerialIoProtocolGuid,
NULL,
&NumSerials,
&SerialHandles
);
if (status == EFI_SUCCESS && NumSerials > 0) {
status = uefi_call_wrapper(ST->BootServices->HandleProtocol, 3,
SerialHandles[0], &gEfiSerialIoProtocolGuid, (void **)&SerialIo);
if (status == EFI_SUCCESS) {
serial_init(SerialIo);
}
}
if (SerialHandles) {
ST->BootServices->FreePool(SerialHandles);
}
}
extern "C" void kernel_main() {
init_gop();
init_serial();
uefi_call_wrapper(ST->ConOut->SetCursorPosition, 3, ST->ConOut, 0, 5);
uefi_call_wrapper(ST->ConOut->OutputString, 2, ST->ConOut, (CHAR16*)L"Kernel is running!\n");
uefi_call_wrapper(ST->ConOut->ClearScreen, 1, ST->ConOut);
serial_write("\n\n"); // 防止和前面串了serial.log看不清
// init memory managers
serial_write("Sylva: init PMM...\n");
EFI_STATUS st = pmm_init();
if (EFI_ERROR(st)) {
serial_write("Sylva: PMM init FAILED!\n");
} else {
serial_write("Sylva: PMM init OK\n");
serial_write("Sylva: free pages = ");
serial_write_hex(pmm_get_free_count());
serial_write("\n");
}
serial_write("Sylva: init heap...\n");
init_heap();
// test kmalloc/kfree
serial_write("Sylva: kmalloc test...\n");
void* p1 = kmalloc(64);
void* p2 = kmalloc(128);
void* p3 = kmalloc(256);
serial_write("Sylva: p1 = ");
serial_write_hex((UINTN)p1);
serial_write(" p2 = ");
serial_write_hex((UINTN)p2);
serial_write(" p3 = ");
serial_write_hex((UINTN)p3);
serial_write("\n");
serial_write("Sylva: kfree test...\n");
kfree(p2);
kfree(p1);
kfree(p3);
void* p4 = kmalloc(32);
serial_write("Sylva: realloc p4 = ");
serial_write_hex((UINTN)p4);
serial_write("\n");
kfree(p4);
serial_write("Sylva: memory init done.\n");
pf_print("Welcome to Sylva OS!\n");
serial_write(" Kernel prepared well, start loop.\n");
while (1) ASM ("hlt"); // 《30天》看多了 (doge
}