summaryrefslogtreecommitdiff
path: root/src/boot.s
blob: 6fe5ab85744031351c4ac1a25b2398f6c9afe6b9 (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
.set ALIGN,    1<<0
.set MEMINFO,  1<<1
.set FLAGS,    ALIGN | MEMINFO
.set MAGIC,    0x1BADB002
.set CHECKSUM, -(MAGIC + FLAGS)
 
.section .multiboot
.align 4
.long MAGIC
.long FLAGS
.long CHECKSUM

.global _start
.global load_gdt
.global load_idt
.global enable_interrupts
.global keyboard_handler
.global ioport_in
.global ioport_out

.extern init_gdt_table
.extern handle_keyboard_interrupt
.extern kernel_main

load_gdt:
    movl 4(%esp), %edx
    lgdt (%edx)
    ret

load_idt:
    movl 4(%esp), %edx
    lidt (%edx)
    sti
    ret

keyboard_handler:
    pushal
    cld
    call handle_keyboard_interrupt
    popal
    iretl

ioport_in:
    movl 4(%esp),%edx
    in %dx,%al
    ret

ioport_out:
    movl 4(%esp),%edx
    movl 8(%esp),%eax
    outb %al,%dx
    ret

.set CODE_SEGMENT, 0x08
.set DATA_SEGMENT, 0x10

.section .bss
.align 16
stack_bottom:
.skip 16384
stack_top:

.section .text
.type _start, @function
_start:
	call init_gdt_table
	ljmp $CODE_SEGMENT, $code
	
code:
	movw $DATA_SEGMENT, %ax
	movw %ax, %ds
	movw %ax, %es
	movw %ax, %fs
	movw %ax, %gs
	movw %ax, %ss
	movl $stack_top, %esp
	cli
	call _init
	call kernel_main
	hlt
 
.size _start, . - _start