X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/cd09c4b222e4ddf45a42522563ae2471a829d1c8..fa57b4a05aa12d594f40e0894e0ac6f810a7095c:/lunaix-os/arch/x86/boot.S diff --git a/lunaix-os/arch/x86/boot.S b/lunaix-os/arch/x86/boot.S index bc1eec2..938db87 100644 --- a/lunaix-os/arch/x86/boot.S +++ b/lunaix-os/arch/x86/boot.S @@ -2,7 +2,7 @@ #include #define MB_FLAGS MULTIBOOT_MEMORY_INFO | MULTIBOOT_PAGE_ALIGN -#define KPG_SIZE 24*1024 +#define KPG_SIZE 10*4096 .section .multiboot .long MULTIBOOT_MAGIC @@ -18,15 +18,15 @@ /* 根据System V ABI,栈地址必须16字节对齐 */ /* 这里只是一个临时栈,在_hhk_init里面我们会初始化内核专用栈 */ stack_bottom: - .skip 16318, 0 + .skip 16318 * 2, 0 stack_top: /* 1 page directory, - 5 page tables: + 9 page tables: 1. Mapping reserved area and hhk_init - 2-5. Remapping the kernels + 2-9. Remapping the kernels */ .section .kpg @@ -41,6 +41,9 @@ * linker more knowledge about the label */ start_: + cld + # 确保屏蔽所有外中断,直到我们准备好PIC为止 + cli movl $stack_top, %esp subl $16, %esp @@ -57,9 +60,7 @@ /* _hhk_init用来初始化我们高半核: - 1. 设置GDT表 - 2. 设置IDT表(暂时,以后会拿到 kernel_init 里面) - 3. 初始化最简单的PTD与PT(重新映射我们的内核至3GiB处,以及对相应的地方进行Identity Map) + 1. 初始化最简单的PD与PT(重新映射我们的内核至3GiB处,以及对相应的地方进行Identity Map) */ movl $(KPG_SIZE), 4(%esp) @@ -76,11 +77,17 @@ andl $0xfffff000, %eax # 有点多余,但写上还算明白一点 movl %eax, %cr3 - /* 开启分页与地址转换 (CR0.PG=1) */ movl %cr0, %eax - orl $0x80000000, %eax + orl $0x80010000, %eax /* 开启分页与地址转换 (CR0.PG=1, CR0.WP=1) */ + andl $0xfffffffb, %eax + orl $0x2, %eax /* 启用x87 FPU (CR0.MP=1, CR0.EM=0) */ movl %eax, %cr0 + movl %cr4, %eax + orl $0x600, %eax + movl %eax, %cr4 /* CR4.OSFXSR=1, CR4.OSXMMEXCPT=1 */ + /* x87 FPU 已配置 */ + addl $16, %esp /* 进入高半核! */