diff options
| author | Emu <89668582+EmulatedSeasons@users.noreply.github.com> | 2024-05-31 23:38:46 -0400 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-05-31 23:38:46 -0400 | 
| commit | 27a44e0d79d1c6e01cd832feb8ad958d5999b5e3 (patch) | |
| tree | 3759eb02fcad7a609a064080d81b7c6f9dbec4c8 /kernel/arch/x86/boot.asm | |
| parent | 639240bbf498195912d8ceb6cb396b89391a5b1b (diff) | |
| parent | fd5a1699592ce0afafc42ebf22401596abcdfc28 (diff) | |
Merge pull request #1 from EmulatedSeasons/limineswitch
Limineswitch
Diffstat (limited to 'kernel/arch/x86/boot.asm')
| -rw-r--r-- | kernel/arch/x86/boot.asm | 103 | 
1 files changed, 103 insertions, 0 deletions
| diff --git a/kernel/arch/x86/boot.asm b/kernel/arch/x86/boot.asm new file mode 100644 index 0000000..42c11e6 --- /dev/null +++ b/kernel/arch/x86/boot.asm @@ -0,0 +1,103 @@ +; multiboot header constants
 +MBALIGN equ 1 << 0
 +MEMINFO equ 1 << 1
 +MBFLAGS equ MBALIGN | MEMINFO
 +MAGIC    equ  0x1BADB002
 +CHECKSUM equ -(MAGIC+MBFLAGS)
 +
 +; multiboot header
 +section .multiboot
 +align 4
 +    dd MAGIC
 +    dd MBFLAGS
 +    dd CHECKSUM
 +
 +section .data
 +%include "arch/i386/gdt.asm"
 +
 +; defines the stack
 +section .bss
 +align 16
 +stack_bottom:
 +resb 16384 ; 16 KiB
 +stack_top:
 +
 +; temporary paging tables
 +align 4
 +boot_page_directory:
 +    resb 4096
 +boot_page_table:
 +    resb 4096
 +
 +
 +section .text
 +global _start:function (_start.end - _start)
 +_start:
 +    cli
 +    ; setup stack
 +    mov esp, stack_top
 +
 +    ; push the multiboot header data into the stack for later use
 +    push eax
 +    push ebx
 +
 +    ; get multiboot header data (for memory map)
 +    ;extern multiboot_main
 +    ;call multiboot_main
 +
 +    ;extern _init
 +    ;Scall _init
 +
 +    lgdt [gdt_descriptor]
 +    jmp 0x08:.gdt_jmp
 +
 +.gdt_jmp:
 +	mov ax, DATA_SEG
 +	mov ds, ax
 +	mov es, ax
 +	mov fs, ax
 +	mov gs, ax
 +	mov ss, ax
 +	jmp .gdt_jmp2
 +
 +.gdt_jmp2:
 +    ; setup paging (to map kernel to the higher half)
 +    ;mov eax, 0
 +    ;mov cr3, eax
 +    ;mov eax, cr0
 +    ;or eax, 0x80000001
 +    ;mov cr0, eax
 +
 +    ; setup idt
 +    extern idt_setup
 +    call idt_setup
 +    extern idtr
 +    lidt [idtr]
 +    
 +    ; initialize pic
 +    push ebp
 +    mov ebp, esp
 +    mov ebx, 0x28
 +    push ebx
 +    mov ebx, 0x20
 +    push ebx
 +
 +    extern pic_remap
 +    call pic_remap
 +
 +    pop ebx
 +    pop ebx
 +    mov esp, ebp
 +    pop ebp
 +
 +    sti
 +
 +    ; enter the kernel
 +    extern kernel_main
 +    call kernel_main
 +
 +    ; indefinite loop once system exits
 +    ;cli
 +.hang: hlt
 +    jmp .hang
 +.end:
\ No newline at end of file | 
