kernel/arch/start.s

49 lines
815 B
ArmAsm
Raw Normal View History

.set MULTIBOOT_MAGIC, 0xE85250D6
.set MULTIBOOT_ARCH, 0
.set MULTIBOOT_LENGTH, 16 + 8
.set MULTIBOOT_CHECKSUM, -(MULTIBOOT_MAGIC + MULTIBOOT_ARCH + MULTIBOOT_LENGTH)
2017-11-01 04:43:42 +00:00
.section .multiboot
2017-11-01 08:53:27 +00:00
.align 4
.long MULTIBOOT_MAGIC
.long MULTIBOOT_ARCH
.long MULTIBOOT_LENGTH
.long MULTIBOOT_CHECKSUM
2017-11-01 09:45:56 +00:00
.long 0
.long 8
2017-11-01 08:53:27 +00:00
2017-11-01 04:43:42 +00:00
.section .bss
.align 16
stack_bottom:
.skip 16384 # 16 KiB
stack_top:
.section .text
.global _start
2017-11-04 02:35:17 +00:00
.global halt
2017-11-01 04:43:42 +00:00
.type _start, @function
2017-11-04 02:35:17 +00:00
.type halt, @function
2017-11-01 04:43:42 +00:00
_start:
2017-11-04 02:25:57 +00:00
mov $stack_top, %esp // Initialize stack
push %ebx // Multiboot information pointer
push %eax // Multiboot magic number
2017-11-04 02:15:05 +00:00
call init
2017-11-04 02:32:23 +00:00
mov $stack_top, %esp // Initialize stack
2017-11-04 10:38:28 +00:00
push %eax // Kernel information pointer
2017-11-04 02:32:23 +00:00
call main
2017-11-04 02:35:17 +00:00
halt:
2017-11-01 04:43:42 +00:00
cli
1:
hlt
jmp 1b
.size _start, . - _start
2017-11-04 02:35:17 +00:00
.size _halt, . - halt