mirror of
https://github.com/Zeal-Operating-System/ZealOS.git
synced 2025-01-13 16:16:31 +00:00
ZealBooter: Misc progress
This commit is contained in:
parent
344de80dab
commit
bcb830e880
5 changed files with 62 additions and 14 deletions
|
@ -70,7 +70,7 @@ if [ ! -d "ovmf" ]; then
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "Testing..."
|
echo "Testing..."
|
||||||
qemu-system-x86_64 -machine q35,accel=kvm -drive format=raw,file=$TMPDISK -m 1G -rtc base=localtime -bios ovmf/OVMF.fd
|
qemu-system-x86_64 -machine q35,accel=kvm -drive format=raw,file=$TMPDISK -m 1G -rtc base=localtime -bios ovmf/OVMF.fd -no-reboot -no-shutdown
|
||||||
|
|
||||||
echo "Deleting temp folder..."
|
echo "Deleting temp folder..."
|
||||||
rm -rf $TMPDIR
|
rm -rf $TMPDIR
|
||||||
|
|
|
@ -54,6 +54,9 @@ SYS_FONT_PTR:: DU32 0;
|
||||||
|
|
||||||
SYS_VBE_INFO:: DU8 sizeof(CVBEInfo) DUP(0);
|
SYS_VBE_INFO:: DU8 sizeof(CVBEInfo) DUP(0);
|
||||||
SYS_VBE_MODES:: DU8 sizeof(CVBEModeShort) * VBE_MODES_NUM DUP(0);
|
SYS_VBE_MODES:: DU8 sizeof(CVBEModeShort) * VBE_MODES_NUM DUP(0);
|
||||||
|
|
||||||
|
ALIGN 16, OC_NOP
|
||||||
|
DU64 0x5439581381193aaf, 0x2a8a30e69ec9f845;
|
||||||
SYS_VBE_FINAL_MODE:: DU8 sizeof(CVBEMode) DUP(0);
|
SYS_VBE_FINAL_MODE:: DU8 sizeof(CVBEMode) DUP(0);
|
||||||
SYS_VBE_FINAL_MODE_NUM::DU16 0; //mode number of final mode set
|
SYS_VBE_FINAL_MODE_NUM::DU16 0; //mode number of final mode set
|
||||||
#assert $$ - SYS_KERNEL == sizeof(CKernel) - sizeof(CZXE)
|
#assert $$ - SYS_KERNEL == sizeof(CKernel) - sizeof(CZXE)
|
||||||
|
|
|
@ -89,9 +89,8 @@ CORE0_32BIT_INIT:: //Entry point for $LK,"BootRAM",A="MN:BootRAM"$.
|
||||||
|
|
||||||
MOV AX, CGDT.boot_ds //LOAD DS SELECTOR
|
MOV AX, CGDT.boot_ds //LOAD DS SELECTOR
|
||||||
MOV DS, AX
|
MOV DS, AX
|
||||||
BTS U32 [SYS_RUN_LEVEL], RLf_32BIT
|
//MOV ESI, U32 [SYS_BOOT_PATCH_TABLE_BASE]
|
||||||
MOV ESI, U32 [SYS_BOOT_PATCH_TABLE_BASE]
|
//MOV EDI, U32 [MEM_BOOT_BASE]
|
||||||
MOV EDI, U32 [MEM_BOOT_BASE]
|
|
||||||
|
|
||||||
MOV AX, CGDT.ds
|
MOV AX, CGDT.ds
|
||||||
MOV DS, AX
|
MOV DS, AX
|
||||||
|
@ -104,6 +103,7 @@ CORE0_32BIT_INIT:: //Entry point for $LK,"BootRAM",A="MN:BootRAM"$.
|
||||||
//Patch abs addresses
|
//Patch abs addresses
|
||||||
MOV ECX, U32 CPatchTableAbsAddr.abs_address_count[ESI]
|
MOV ECX, U32 CPatchTableAbsAddr.abs_address_count[ESI]
|
||||||
LEA ESI, U32 CPatchTableAbsAddr.abs_address[ESI]
|
LEA ESI, U32 CPatchTableAbsAddr.abs_address[ESI]
|
||||||
|
|
||||||
@@05: LODSD
|
@@05: LODSD
|
||||||
ADD EAX, EDI
|
ADD EAX, EDI
|
||||||
ADD U32 [EAX], EDI
|
ADD U32 [EAX], EDI
|
||||||
|
@ -114,6 +114,7 @@ CORE0_32BIT_INIT:: //Entry point for $LK,"BootRAM",A="MN:BootRAM"$.
|
||||||
DU16 CGDT.cs32;
|
DU16 CGDT.cs32;
|
||||||
|
|
||||||
@@10: BTS U32 [SYS_RUN_LEVEL], RLf_PATCHED
|
@@10: BTS U32 [SYS_RUN_LEVEL], RLf_PATCHED
|
||||||
|
BTS U32 [SYS_RUN_LEVEL], RLf_32BIT
|
||||||
|
|
||||||
CALL SYS_FIND_PCIBIOS_SERVICE_DIR
|
CALL SYS_FIND_PCIBIOS_SERVICE_DIR
|
||||||
CALL SYS_FIND_PCI_SERVICES
|
CALL SYS_FIND_PCI_SERVICES
|
||||||
|
|
|
@ -96,7 +96,7 @@ CTSS *TSSNew(I64 cpu_num)
|
||||||
tss->tr = offset(CGDT.tr) + cpu_num * 16;
|
tss->tr = offset(CGDT.tr) + cpu_num * 16;
|
||||||
tss->tr_ring3= offset(CGDT.tr_ring3) + cpu_num * 16;
|
tss->tr_ring3= offset(CGDT.tr_ring3) + cpu_num * 16;
|
||||||
|
|
||||||
d = (&sys_gdt)(U8 *) + tss->tr;
|
d = (0x80d8)(U8 *) + tss->tr;
|
||||||
d1 = d(U8 *) + 4;
|
d1 = d(U8 *) + 4;
|
||||||
*d = 0x0000FFFF;
|
*d = 0x0000FFFF;
|
||||||
*d1 = 0x008F8900;
|
*d1 = 0x008F8900;
|
||||||
|
@ -106,7 +106,7 @@ CTSS *TSSNew(I64 cpu_num)
|
||||||
*d1++ = tss >> 32;
|
*d1++ = tss >> 32;
|
||||||
*d1 = 0;
|
*d1 = 0;
|
||||||
|
|
||||||
d = (&sys_gdt)(U8 *) + tss->tr_ring3;
|
d = (0x80d8)(U8 *) + tss->tr_ring3;
|
||||||
d1 = d(U8 *) + 4;
|
d1 = d(U8 *) + 4;
|
||||||
*d = 0x0000FFFF;
|
*d = 0x0000FFFF;
|
||||||
*d1 = 0x008FE900;
|
*d1 = 0x008FE900;
|
||||||
|
@ -193,6 +193,7 @@ U0 MPAPICInit()
|
||||||
|
|
||||||
RAXSet(Gs->tss->tr);
|
RAXSet(Gs->tss->tr);
|
||||||
LTR AX
|
LTR AX
|
||||||
|
|
||||||
if (Gs->num)
|
if (Gs->num)
|
||||||
{
|
{
|
||||||
IntInit1;
|
IntInit1;
|
||||||
|
|
|
@ -13,11 +13,21 @@ static volatile struct limine_kernel_address_request kernel_address_request = {
|
||||||
.revision = 0
|
.revision = 0
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static volatile struct limine_hhdm_request hhdm_request = {
|
||||||
|
.id = LIMINE_HHDM_REQUEST,
|
||||||
|
.revision = 0
|
||||||
|
};
|
||||||
|
|
||||||
static volatile struct limine_memmap_request memmap_request = {
|
static volatile struct limine_memmap_request memmap_request = {
|
||||||
.id = LIMINE_MEMMAP_REQUEST,
|
.id = LIMINE_MEMMAP_REQUEST,
|
||||||
.revision = 0
|
.revision = 0
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static volatile struct limine_framebuffer_request framebuffer_request = {
|
||||||
|
.id = LIMINE_FRAMEBUFFER_REQUEST,
|
||||||
|
.revision = 0
|
||||||
|
};
|
||||||
|
|
||||||
struct CZXE {
|
struct CZXE {
|
||||||
uint16_t jmp;
|
uint16_t jmp;
|
||||||
uint8_t module_align_bits;
|
uint8_t module_align_bits;
|
||||||
|
@ -123,11 +133,41 @@ struct E801 get_E801(void) {
|
||||||
return E801;
|
return E801;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
struct CVBEMode {
|
||||||
|
uint16_t attributes, pad0[7], pitch, width, height;
|
||||||
|
uint8_t pad1[3], bpp, pad2, memory_model, pad[12];
|
||||||
|
uint32_t framebuffer;
|
||||||
|
uint16_t pad3[9];
|
||||||
|
uint32_t max_pixel_clock;
|
||||||
|
uint8_t reserved[190];
|
||||||
|
} __attribute__((packed));
|
||||||
|
|
||||||
void _start(void) {
|
void _start(void) {
|
||||||
struct limine_file *kernel = module_request.response->modules[0];
|
struct limine_file *kernel = module_request.response->modules[0];
|
||||||
struct CKernel *CKernel = (void *)0x7c00;
|
struct CKernel *CKernel = (void *)0x7c00;
|
||||||
memcpy(CKernel, kernel->address, kernel->size);
|
memcpy(CKernel, kernel->address, kernel->size);
|
||||||
|
|
||||||
|
struct CVBEMode *sys_vbe_mode;
|
||||||
|
for (uint64_t *p = (uint64_t *)CKernel; ; p++) {
|
||||||
|
if (*p != 0x5439581381193aaf) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
p++;
|
||||||
|
if (*p != 0x2a8a30e69ec9f845) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
p++;
|
||||||
|
sys_vbe_mode = (void *)p;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
struct limine_framebuffer *fb = framebuffer_request.response->framebuffers[0];
|
||||||
|
sys_vbe_mode->pitch = fb->pitch;
|
||||||
|
sys_vbe_mode->width = fb->width;
|
||||||
|
sys_vbe_mode->height = fb->height;
|
||||||
|
sys_vbe_mode->bpp = fb->bpp;
|
||||||
|
sys_vbe_mode->framebuffer = (uintptr_t)fb->address - hhdm_request.response->offset;
|
||||||
|
|
||||||
void *CORE0_32BIT_INIT;
|
void *CORE0_32BIT_INIT;
|
||||||
for (uint64_t *p = (uint64_t *)CKernel; ; p++) {
|
for (uint64_t *p = (uint64_t *)CKernel; ; p++) {
|
||||||
if (*p != 0xaa23c08ed10bd4d7) {
|
if (*p != 0xaa23c08ed10bd4d7) {
|
||||||
|
@ -145,17 +185,20 @@ void _start(void) {
|
||||||
CKernel->boot_src = BOOT_SRC_RAM;
|
CKernel->boot_src = BOOT_SRC_RAM;
|
||||||
CKernel->boot_blk = 0;
|
CKernel->boot_blk = 0;
|
||||||
CKernel->boot_patch_table_base = (uintptr_t)CKernel + CKernel->h.patch_table_offset;
|
CKernel->boot_patch_table_base = (uintptr_t)CKernel + CKernel->h.patch_table_offset;
|
||||||
|
|
||||||
|
// asm volatile ("jmp ." ::"a"(CKernel->boot_patch_table_base));
|
||||||
|
|
||||||
CKernel->sys_run_level = RLF_VESA | RLF_16BIT;
|
CKernel->sys_run_level = RLF_VESA | RLF_16BIT;
|
||||||
|
|
||||||
CKernel->boot_base = (uintptr_t)&CKernel->jmp;
|
CKernel->boot_base = (uintptr_t)&CKernel->jmp;
|
||||||
|
|
||||||
CKernel->sys_gdt.boot_ds.lo = 0x000093000000ffff;
|
CKernel->sys_gdt.boot_ds.lo = 0x00CF92000000FFFF;
|
||||||
CKernel->sys_gdt.boot_cs.lo = 0x00009a000000ffff;
|
CKernel->sys_gdt.boot_cs.lo = 0x00CF9A000000FFFF;
|
||||||
CKernel->sys_gdt.cs32.lo = 0x00cf9a000000ffff;
|
CKernel->sys_gdt.cs32.lo = 0x00CF9A000000FFFF;
|
||||||
CKernel->sys_gdt.cs64.lo = 0x00af9b000000ffff;
|
CKernel->sys_gdt.cs64.lo = 0x00209A0000000000;
|
||||||
CKernel->sys_gdt.cs64_ring3.lo = 0x00affb000000ffff;
|
CKernel->sys_gdt.cs64_ring3.lo = 0x0020FA0000000000;
|
||||||
CKernel->sys_gdt.ds.lo = 0x00af93000000ffff;
|
CKernel->sys_gdt.ds.lo = 0x00CF92000000FFFF;
|
||||||
CKernel->sys_gdt.ds_ring3.lo = 0x00aff3000000ffff;
|
CKernel->sys_gdt.ds_ring3.lo = 0x00CFF2000000FFFF;
|
||||||
|
|
||||||
CKernel->sys_gdt_ptr.limit = sizeof(CKernel->sys_gdt) - 1;
|
CKernel->sys_gdt_ptr.limit = sizeof(CKernel->sys_gdt) - 1;
|
||||||
CKernel->sys_gdt_ptr.base = (void *)&CKernel->sys_gdt;
|
CKernel->sys_gdt_ptr.base = (void *)&CKernel->sys_gdt;
|
||||||
|
@ -192,7 +235,7 @@ void _start(void) {
|
||||||
void *target_addr = (void *)lower - kernel_address_request.response->virtual_base;
|
void *target_addr = (void *)lower - kernel_address_request.response->virtual_base;
|
||||||
target_addr += kernel_address_request.response->physical_base;
|
target_addr += kernel_address_request.response->physical_base;
|
||||||
|
|
||||||
asm volatile ("jmp *%0" :: "a"(target_addr), "b"(CORE0_32BIT_INIT), "c"(&CKernel->sys_gdt_ptr) : "memory");
|
asm volatile ("jmp *%0" :: "a"(target_addr), "b"(CORE0_32BIT_INIT), "c"(&CKernel->sys_gdt_ptr), "S"(CKernel->boot_patch_table_base), "D"(CKernel->boot_base) : "memory");
|
||||||
|
|
||||||
__builtin_unreachable();
|
__builtin_unreachable();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue