summaryrefslogtreecommitdiff
path: root/asm/asm_mp.asm
blob: f0eb9c044c0f3f4fc5bdd9818956adbd4c20fa54 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
global smp_start
extern smp_main
; master boot record for application processors
;[org 0x7000]
smp_start:
[bits 16]

    cli				;switch off interrupts!
    lgdt [gdt_descriptor]	;load descriptor table!

    ;switch on 32-bit protected mode
    mov eax, cr0
    or eax,0x1 
    mov cr0, eax

    jmp 0x8:init_pm

[bits 32]


LLOCK:	    dd 0

init_pm:

    mov ax, 0x10
    mov ds, ax
    mov ss, ax
    mov es, ax
    mov fs, ax
    mov gs, ax

    mov ebp, 0x8000
    mov esp, ebp

    call boot_32_pm	    ;continue booting in 32-bit protected mode

boot_32_pm:
    hlt
    jmp boot_32_pm

    ;mov eax, 1		 ; semaphore	
    ;xchg eax, [LLOCK]
    ;cmp eax,1
    ;hlt
    ;je $
    ;jmp $ ; loop forever here

    ;call [0x8010] ;kernel_ap			        ;jump into our Kernel!
    call smp_main

    jmp $ ; should never be reached


gdt_start:

gdt_null:   ;null descriptor (2 x 4 bytes)
    dd 0x0
    dd 0x0

gdt_code:
    ; flags:
    ; present: 1 / privilege: 00 / type: 1
    ; code: 1 / conforming: 0 / readable: 1 / accessed: 0
    ; granularity: 1 / 16-bit default: 1 / 64-bit seg: 0 / AVL: 0
    dw 0xffff	    ;limit
    dw 0x0	    ;base
    db 0x0	    ;base
    db 10011010b    ;flags
    db 11001111b    ;flags & seg.limit
    db 0x0	    ;base

gdt_data:
    ; flags:
    ; code: 0 / expand down: 0 / writable: 1 / accessed: 0
    dw 0xffff
    dw 0x0
    db 0x0
    db 10010010b
    db 11001111b
    db 0x0

gdt_end:

gdt_descriptor:
    dw gdt_end-gdt_start-1
    dd gdt_start

CODE_SEG equ gdt_code - gdt_start
DATA_SEG equ gdt_data - gdt_start