|  | /* @r{boot.S - bootstrap the kernel} */ | 
|  | /* @r{Copyright (C) 1999, 2001  Free Software Foundation, Inc. | 
|  |  | 
|  | This program is free software; you can redistribute it and/or modify | 
|  | it under the terms of the GNU General Public License as published by | 
|  | the Free Software Foundation; either version 2 of the License, or | 
|  | (at your option) any later version. | 
|  |  | 
|  | This program is distributed in the hope that it will be useful, | 
|  | but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|  | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
|  | GNU General Public License for more details. | 
|  |  | 
|  | You should have received a copy of the GNU General Public License | 
|  | along with this program; if not, write to the Free Software | 
|  | Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.} */ | 
|  |  | 
|  | #define ASM     1 | 
|  | #include <multiboot.h> | 
|  |  | 
|  | .text | 
|  |  | 
|  | .globl  start, _start | 
|  | start: | 
|  | _start: | 
|  | jmp     multiboot_entry | 
|  |  | 
|  | /* @r{Align 32 bits boundary.} */ | 
|  | .align  4 | 
|  |  | 
|  | /* @r{Multiboot header.} */ | 
|  | multiboot_header: | 
|  | /* @r{magic} */ | 
|  | .long   MULTIBOOT_HEADER_MAGIC | 
|  | /* @r{flags} */ | 
|  | .long   MULTIBOOT_HEADER_FLAGS | 
|  | /* @r{checksum} */ | 
|  | .long   -(MULTIBOOT_HEADER_MAGIC + MULTIBOOT_HEADER_FLAGS) | 
|  | #ifndef __ELF__ | 
|  | /* @r{header_addr} */ | 
|  | .long   multiboot_header | 
|  | /* @r{load_addr} */ | 
|  | .long   _start | 
|  | /* @r{load_end_addr} */ | 
|  | .long   _edata | 
|  | /* @r{bss_end_addr} */ | 
|  | .long   _end | 
|  | /* @r{entry_addr} */ | 
|  | .long   multiboot_entry | 
|  | #endif /* @r{! __ELF__} */ | 
|  |  | 
|  | multiboot_entry: | 
|  | /* @r{Initialize the stack pointer.} */ | 
|  | movl    $(stack + STACK_SIZE), %esp | 
|  |  | 
|  | /* @r{Reset EFLAGS.} */ | 
|  | pushl   $0 | 
|  | popf | 
|  |  | 
|  | /* @r{Push the pointer to the Multiboot information structure.} */ | 
|  | pushl   %ebx | 
|  | /* @r{Push the magic value.} */ | 
|  | pushl   %eax | 
|  |  | 
|  | /* @r{Now enter the C main function...} */ | 
|  | call    EXT_C(cmain) | 
|  |  | 
|  | /* @r{Halt.} */ | 
|  | pushl   $halt_message | 
|  | call    EXT_C(printf) | 
|  |  | 
|  | loop:   hlt | 
|  | jmp     loop | 
|  |  | 
|  | halt_message: | 
|  | .asciz  "Halted." | 
|  |  | 
|  | /* @r{Our stack area.} */ | 
|  | .comm   stack, STACK_SIZE | 
|  |  |