Kernel/arm7 - Fiddling, still having issues with VMM
[tpg/acess2.git] / Kernel / arch / x86_64 / start32.asm
index 4769ee4..6ee9262 100644 (file)
@@ -1,7 +1,8 @@
 
 [BITS 32]
 
-KERNEL_BASE    equ     0xFFFF800000000000
+;KERNEL_BASE   equ     0xFFFF800000000000
+KERNEL_BASE    equ     0xFFFFFFFF80000000
 
 [section .multiboot]
 mboot:
@@ -41,13 +42,15 @@ start:
        cmp eax, 0x80000001     ; Compare the A-register with 0x80000001.
        mov eax, 0x80000001
        cpuid
-    jb .not64bitCapable
+       jb .not64bitCapable
        test edx, 1<<29
        jz .not64bitCapable
 
-       ; Enable PAE
+       ; Enable PGE (Page Global Enable)
+       ; + PAE (Physical Address Extension)
+       ; + PSE (Page Size Extensions)
        mov eax, cr4
-       or eax, 0x80|0x20
+       or eax, 0x80|0x20|0x10
        mov cr4, eax
 
        ; Load PDP4
@@ -86,6 +89,7 @@ start:
 
 [section .data]
 [global gGDT]
+[global gGDTPtr]
 gGDT:
        dd      0,0
        dd      0x00000000, 0x00209A00  ; 0x08: 64-bit Code
@@ -94,7 +98,7 @@ gGDT:
        dd      0x00000000, 0x0000F200  ; 0x20: 64-bit User Data
        dd      0x00000000, 0x0040FA00  ; 0x38: 32-bit User Code
        dd      0x00000000, 0x0040F200  ; 0x30: 32-bit User Data
-       times MAX_CPUS  dd      0, 0, 0, 0      ; 0x38+16*n: TSS 0
+       times MAX_CPUS  dd      0, 0x00008900, 0, 0     ; 0x38+16*n: TSS 0
 gGDTPtr:
        dw      $-gGDT-1
        dd      gGDT-KERNEL_BASE
@@ -110,18 +114,22 @@ gMultibootPtr:
 [global gInitialPML4]
 gInitialPML4:  ; Covers 256 TiB (Full 48-bit Virtual Address Space)
        dd      gInitialPDP - KERNEL_BASE + 3, 0        ; Identity Map Low 4Mb
-       times 256-1 dq  0
-       dd      gInitialPDP - KERNEL_BASE + 3, 0        ; Map Low 4Mb to kernel base
-       times 256-1-4 dq 0
+       times 512-4-1 dq        0
        dd      gInitialPML4 - KERNEL_BASE + 3, 0       ; Fractal Mapping
        dq      0
        dq      0
-       dq      0
+       dd      gHighPDP - KERNEL_BASE + 3, 0   ; Map Low 4Mb to kernel base
 
 gInitialPDP:   ; Covers 512 GiB
        dd      gInitialPD - KERNEL_BASE + 3, 0
        times 511       dq      0
 
+gHighPDP:      ; Covers 512 GiB
+       times 510       dq      0
+       ;dq     0 + 0x143       ; 1 GiB Page from zero
+       dd      gInitialPD - KERNEL_BASE + 3, 0
+       dq      0
+
 gInitialPD:    ; Covers 1 GiB
        dd      gInitialPT1 - KERNEL_BASE + 3, 0
        dd      gInitialPT2 - KERNEL_BASE + 3, 0
@@ -130,13 +138,13 @@ gInitialPD:       ; Covers 1 GiB
 gInitialPT1:   ; Covers 2 MiB
        %assign i 0
        %rep 512
-       dq      i*4096+3
+       dq      i*4096+0x103
        %assign i i+1
        %endrep
 gInitialPT2:   ; 2 MiB
        %assign i 512
        %rep 512
-       dq      i*4096+3
+       dq      i*4096+0x103
        %assign i i+1
        %endrep
 

UCC git Repository :: git.ucc.asn.au