1 /* @r{boot.S - bootstrap the kernel} */ 2 /* @r{Copyright (C) 1999, 2001 Free Software Foundation, Inc. 3 4 This program is free software; you can redistribute it and/or modify 5 it under the terms of the GNU General Public License as published by 6 the Free Software Foundation; either version 2 of the License, or 7 (at your option) any later version. 8 9 This program is distributed in the hope that it will be useful, 10 but WITHOUT ANY WARRANTY; without even the implied warranty of 11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 GNU General Public License for more details. 13 14 You should have received a copy of the GNU General Public License 15 along with this program; if not, write to the Free Software 16 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.} */ 17 18 #define ASM 1 19 #include <multiboot.h> 20 21 .text 22 23 .globl start, _start 24 start: 25 _start: 26 jmp multiboot_entry 27 28 /* @r{Align 32 bits boundary.} */ 29 .align 4 30 31 /* @r{Multiboot header.} */ 32 multiboot_header: 33 /* @r{magic} */ 34 .long MULTIBOOT_HEADER_MAGIC 35 /* @r{flags} */ 36 .long MULTIBOOT_HEADER_FLAGS 37 /* @r{checksum} */ 38 .long -(MULTIBOOT_HEADER_MAGIC + MULTIBOOT_HEADER_FLAGS) 39 #ifndef __ELF__ 40 /* @r{header_addr} */ 41 .long multiboot_header 42 /* @r{load_addr} */ 43 .long _start 44 /* @r{load_end_addr} */ 45 .long _edata 46 /* @r{bss_end_addr} */ 47 .long _end 48 /* @r{entry_addr} */ 49 .long multiboot_entry 50 #endif /* @r{! __ELF__} */ 51 52 multiboot_entry: 53 /* @r{Initialize the stack pointer.} */ 54 movl $(stack + STACK_SIZE), %esp 55 56 /* @r{Reset EFLAGS.} */ 57 pushl $0 58 popf 59 60 /* @r{Push the pointer to the Multiboot information structure.} */ 61 pushl %ebx 62 /* @r{Push the magic value.} */ 63 pushl %eax 64 65 /* @r{Now enter the C main function...} */ 66 call EXT_C(cmain) 67 68 /* @r{Halt.} */ 69 pushl $halt_message 70 call EXT_C(printf) 71 72 loop: hlt 73 jmp loop 74 75 halt_message: 76 .asciz "Halted." 77 78 /* @r{Our stack area.} */ 79 .comm stack, STACK_SIZE 80