-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathloader.s
31 lines (26 loc) · 1.53 KB
/
loader.s
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
global loader ; the entry symbol for ELF
KERNEL_STACK_SIZE equ 4096 ; size of stack in bytes
extern kmain ; the function kmain is defined elsewhere
section .bss
align 4 ; align at 4 bytes
kernel_stack: ; label points to beginning of memory
resb KERNEL_STACK_SIZE ; reserve stack for the kernel
MAGIC_NUMBER equ 0x1BADB002 ; define the magic number constant
FLAGS equ 0x0 ; multiboot flags
CHECKSUM equ -MAGIC_NUMBER ; calculate the checksum
; (magic number + checksum + flags should equal 0)
section .text: ; start of the text (code) section
align 4 ; the code must be 4 byte aligned
dd MAGIC_NUMBER ; write the magic number to the machine code,
dd FLAGS ; the flags,
dd CHECKSUM ; and the checksum
loader: ; the loader label (defined as entry point
; in linker script)
mov esp, kernel_stack + KERNEL_STACK_SIZE ; point esp to the start of the
; stack (end of memory area)
push dword 3 ; arg3
push dword 2 ; arg2
push dword 1 ; arg1
call kmain ; call the function
.loop:
jmp .loop ; loop forever