summaryrefslogtreecommitdiff
path: root/asm/asm_mp.asm
blob: 18b9d7ed898f4e2078c751c245d5f07cd88bc31f (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
90
91
92
93
global smp_start
extern smp_main
global asm_smp_unlock

; master boot record for application processors
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 1

asm_smp_unlock:
    mov eax, 0x0
    mov [LLOCK], eax
    ret

init_pm:

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

    mov ebp, 0x7000         ;temporary stack
    mov esp, ebp

    call boot_32_pm	    ;continue booting in 32-bit protected mode

boot_32_pm:

    mov eax,1
    xchg eax, [LLOCK]
    cmp eax,1
    je boot_32_pm

    mov ebp, 0x7000
    mov esp, ebp

    and esp,-16  ; padding to align stack on 16byte boundary before CALL
    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