Changes in kernel/arch/amd64/src/boot/multiboot.S [4bf0926e:f66c203d] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
kernel/arch/amd64/src/boot/multiboot.S
r4bf0926e rf66c203d 29 29 */ 30 30 31 #include <abi/asmtool.h>32 31 #include <arch/boot/boot.h> 33 32 #include <arch/mm/page.h> … … 65 64 66 65 .align 4 66 .global multiboot_image_start 67 67 multiboot_header: 68 68 .long MULTIBOOT_HEADER_MAGIC … … 75 75 .long multiboot_image_start 76 76 77 SYMBOL(multiboot_image_start) 77 multiboot_image_start: 78 78 cli 79 79 cld … … 168 168 169 169 movl %cr4, %eax 170 orl $CR4_PAE, %eax170 btsl $5, %eax 171 171 movl %eax, %cr4 172 172 … … 176 176 177 177 /* Enable long mode */ 178 movl $ AMD_MSR_EFER, %ecx178 movl $EFER_MSR_NUM, %ecx 179 179 rdmsr /* read EFER */ 180 orl $AMD_LME, %eax/* set LME = 1 */180 btsl $AMD_LME_FLAG, %eax /* set LME = 1 */ 181 181 wrmsr 182 182 183 183 /* Enable paging to activate long mode (set CR0.PG = 1) */ 184 184 movl %cr0, %eax 185 orl $CR0_PG, %eax185 btsl $31, %eax 186 186 movl %eax, %cr0 187 187 … … 427 427 long_status $status_long 428 428 429 /* Call amd64_pre_main(multiboot_eax, multiboot_ebx) */ 429 /* Call arch_pre_main(multiboot_eax, multiboot_ebx) */ 430 xorq %rdi, %rdi 430 431 movl multiboot_eax, %edi 432 xorq %rsi, %rsi 431 433 movl multiboot_ebx, %esi 432 434 433 #ifdef MEMORY_MODEL_large 434 movabsq $amd64_pre_main, %rax 435 movabsq $arch_pre_main, %rax 435 436 callq *%rax 436 #else437 callq amd64_pre_main438 #endif439 437 440 438 long_status $status_main 441 439 442 440 /* Call main_bsp() */ 443 #ifdef MEMORY_MODEL_large444 441 movabsq $main_bsp, %rax 445 callq *%rax 446 #else 447 callq main_bsp 448 #endif 442 call *%rax 449 443 450 444 /* Not reached */ … … 633 627 ptl2gen 512 7 634 628 635 #ifdef MEMORY_MODEL_kernel636 .align 4096637 ptl_1:638 /* Identity mapping for [0; 8G) */639 .quad ptl_2_0g + (PTL_WRITABLE | PTL_PRESENT)640 .quad ptl_2_1g + (PTL_WRITABLE | PTL_PRESENT)641 .quad ptl_2_2g + (PTL_WRITABLE | PTL_PRESENT)642 .quad ptl_2_3g + (PTL_WRITABLE | PTL_PRESENT)643 .quad ptl_2_4g + (PTL_WRITABLE | PTL_PRESENT)644 .quad ptl_2_5g + (PTL_WRITABLE | PTL_PRESENT)645 .quad ptl_2_6g + (PTL_WRITABLE | PTL_PRESENT)646 .quad ptl_2_7g + (PTL_WRITABLE | PTL_PRESENT)647 .fill 502, 8, 0648 /* Mapping of [0; 2G) at -2G */649 .quad ptl_2_0g + (PTL_WRITABLE | PTL_PRESENT)650 .quad ptl_2_1g + (PTL_WRITABLE | PTL_PRESENT)651 652 .align 4096653 SYMBOL(ptl_0)654 .quad ptl_1 + (PTL_WRITABLE | PTL_PRESENT)655 .fill 510, 8, 0656 .quad ptl_1 + (PTL_WRITABLE | PTL_PRESENT)657 #endif658 659 #ifdef MEMORY_MODEL_large660 629 .align 4096 661 630 ptl_1: … … 672 641 673 642 .align 4096 674 SYMBOL(ptl_0) 643 .global ptl_0 644 ptl_0: 675 645 .quad ptl_1 + (PTL_WRITABLE | PTL_PRESENT) 676 646 .fill 255, 8, 0 677 647 .quad ptl_1 + (PTL_WRITABLE | PTL_PRESENT) 678 648 .fill 255, 8, 0 679 #endif680 649 681 650 .section K_DATA_START, "aw", @progbits 682 651 683 SYMBOL(bootstrap_idtr) 652 .global bootstrap_idtr 653 bootstrap_idtr: 684 654 .word 0 685 655 .long 0 686 656 687 SYMBOL(bootstrap_gdtr) 657 .global bootstrap_gdtr 658 bootstrap_gdtr: 688 659 .word GDT_SELECTOR(GDT_ITEMS) 689 660 .long KA2PA(gdt) 690 661 691 SYMBOL(multiboot_eax) 662 .global multiboot_eax 663 multiboot_eax: 692 664 .long 0 693 665 694 SYMBOL(multiboot_ebx) 666 .global multiboot_ebx 667 multiboot_ebx: 695 668 .long 0 696 669
Note:
See TracChangeset
for help on using the changeset viewer.