Mercurial > hg > Members > taiki > original_os
diff bootstrap.S @ 10:50e4b9ca4867
add bootstrap source. Go to 64bit mode.
author | Taiki TAIRA <e095767@ie.u-ryukyu.ac.jp> |
---|---|
date | Mon, 27 Aug 2012 23:45:31 +0900 |
parents | bd2f9ba6f5f8 |
children | 26b76ada8c13 |
line wrap: on
line diff
--- a/bootstrap.S Wed Aug 22 18:30:45 2012 +0900 +++ b/bootstrap.S Mon Aug 27 23:45:31 2012 +0900 @@ -4,6 +4,7 @@ */ #include "multiboot2.h" +#include "boot_header.h" .file "bootstrap.S" @@ -55,6 +56,7 @@ * 6144 = 512*8*6/4 */ + movl $0x01fe9000, %ebx leal pgtable(%ebx), %edi xorl %eax, %eax movl $6144, %ecx @@ -65,9 +67,43 @@ leal 0x1007(%edi), %eax movl %eax, 0(%edi) + /* Build Level 3 */ + leal pgtable + 0x1000(%ebx), %edi + leal 0x1007(%edi), %eax + movl $4, %ecx +1: movl %eax, 0x00(%edi) + addl $0x00001000, %eax + addl $8, %edi + decl %ecx + jnz 1b + /* Build level 2 */ + leal pgtable + 0x2000(%ebx), %edi + movl $0x00000183, %eax + movl $2048, %ecx +1: movl %eax, 0(%edi) + addl $0x00200000, %eax + addl $8, %edi + decl %ecx + jnz 1b + + /* Enable the boot page talbes */ + leal pgtable(%ebx), %eax + movl %eax, %cr3 + + /* Enable Long mode */ + movl $MSR_EFER, %ecx + rdmsr + btsl $EFER_LME, %eax + wrmsr + + jmp start_kernel + +/* jump to kernel. + * push ebx and eax send argument to kernel. + */ start_kernel: pushl %ebx pushl %eax