Changeset 17aa6d1 in mainline
- Timestamp:
- 2018-11-12T20:45:38Z (6 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- 9a791eb9
- Parents:
- 08f1a6d
- Location:
- kernel/arch
- Files:
-
- 4 edited
Legend:
- Unmodified
- Added
- Removed
-
kernel/arch/amd64/src/boot/multiboot.S
r08f1a6d r17aa6d1 39 39 40 40 // TODO: most of this file can be rewritten in C 41 42 // TODO: FB state should be checked dynamically from provided multiboot info. 43 // Currently we only enable EGA statically, which forces us to rebuild 44 // the image to get very early debug output. 41 45 42 46 #define START_STACK (BOOT_OFFSET - BOOT_STACK_SIZE) -
kernel/arch/amd64/src/boot/multiboot2.S
r08f1a6d r17aa6d1 34 34 #include <arch/cpu.h> 35 35 #include <genarch/multiboot/multiboot2.h> 36 37 #define START_STACK (BOOT_OFFSET - BOOT_STACK_SIZE)38 36 39 37 .section K_TEXT_START, "ax" … … 80 78 .word MULTIBOOT2_FLAGS_REQUIRED 81 79 .long tag_entry_address_end - tag_entry_address_start 82 .long multiboot 2_image_start80 .long multiboot_image_start 83 81 tag_entry_address_end: 84 82 … … 122 120 tag_terminator_end: 123 121 multiboot2_header_end: 124 125 SYMBOL(multiboot2_image_start)126 cli127 cld128 129 /* Initialize stack pointer */130 movl $START_STACK, %esp131 132 /*133 * Initialize Global Descriptor Table and134 * Interrupt Descriptor Table registers135 */136 lgdtl bootstrap_gdtr137 lidtl bootstrap_idtr138 139 /* Kernel data + stack */140 movw $GDT_SELECTOR(KDATA_DES), %cx141 movw %cx, %es142 movw %cx, %ds143 movw %cx, %ss144 145 /*146 * Simics seems to remove hidden part of GS on entering user mode147 * when _visible_ part of GS does not point to user-mode segment.148 */149 movw $GDT_SELECTOR(UDATA_DES), %cx150 movw %cx, %fs151 movw %cx, %gs152 153 jmpl $GDT_SELECTOR(KTEXT32_DES), $multiboot2_meeting_point154 multiboot2_meeting_point:155 156 /*157 * Protected 32-bit. We want to reuse the code-seg descriptor,158 * the Default operand size must not be 1 when entering long mode.159 */160 161 /* Save multiboot arguments */162 movl %eax, multiboot_eax163 movl %ebx, multiboot_ebx164 165 movl $(INTEL_CPUID_EXTENDED), %eax166 cpuid167 cmp $(INTEL_CPUID_EXTENDED), %eax168 ja extended_cpuid_supported169 170 jmp pm_error_halt171 172 extended_cpuid_supported:173 174 movl $(AMD_CPUID_EXTENDED), %eax175 cpuid176 bt $(AMD_EXT_LONG_MODE), %edx177 jc long_mode_supported178 179 jmp pm_error_halt180 181 long_mode_supported:182 183 bt $(AMD_EXT_NOEXECUTE), %edx184 jc noexecute_supported185 186 jmp pm_error_halt187 188 noexecute_supported:189 190 movl $(INTEL_CPUID_STANDARD), %eax191 cpuid192 bt $(INTEL_FXSAVE), %edx193 jc fx_supported194 195 jmp pm_error_halt196 197 fx_supported:198 199 bt $(INTEL_SSE2), %edx200 jc sse2_supported201 202 jmp pm_error_halt203 204 sse2_supported:205 206 /*207 * Enable 64-bit page translation entries - CR4.PAE = 1.208 * Paging is not enabled until after long mode is enabled.209 */210 211 movl %cr4, %eax212 orl $CR4_PAE, %eax213 movl %eax, %cr4214 215 /* Set up paging tables */216 leal ptl_0, %eax217 movl %eax, %cr3218 219 /* Enable long mode */220 movl $AMD_MSR_EFER, %ecx221 rdmsr /* read EFER */222 orl $AMD_LME, %eax /* set LME = 1 */223 wrmsr224 225 /* Enable paging to activate long mode (set CR0.PG = 1) */226 movl %cr0, %eax227 orl $CR0_PG, %eax228 movl %eax, %cr0229 230 /* At this point we are in compatibility mode */231 jmpl $GDT_SELECTOR(KTEXT_DES), $start64232 233 pm_error_halt:234 cli235 hlt1:236 hlt237 jmp hlt1238 239 .code64240 241 start64:242 243 /*244 * Long mode.245 */246 247 movq $(PA2KA(START_STACK)), %rsp248 249 /* Create the first stack frame */250 pushq $0251 movq %rsp, %rbp252 253 /* Call amd64_pre_main(multiboot_eax, multiboot_ebx) */254 movl multiboot_eax, %edi255 movl multiboot_ebx, %esi256 257 #ifdef MEMORY_MODEL_large258 movabsq $amd64_pre_main, %rax259 callq *%rax260 #else261 callq amd64_pre_main262 #endif263 264 /* Call main_bsp() */265 #ifdef MEMORY_MODEL_large266 movabsq $main_bsp, %rax267 callq *%rax268 #else269 callq main_bsp270 #endif271 272 /* Not reached */273 cli274 hlt0:275 hlt276 jmp hlt0 -
kernel/arch/ia32/src/boot/multiboot.S
r08f1a6d r17aa6d1 39 39 40 40 // TODO: most of this file can be rewritten in C 41 42 // TODO: FB state should be checked dynamically from provided multiboot info. 43 // Currently we only enable EGA statically, which forces us to rebuild 44 // the image to get very early debug output. 41 45 42 46 #define START_STACK (BOOT_OFFSET - BOOT_STACK_SIZE) -
kernel/arch/ia32/src/boot/multiboot2.S
r08f1a6d r17aa6d1 32 32 #include <arch/cpuid.h> 33 33 #include <genarch/multiboot/multiboot2.h> 34 35 #define START_STACK (BOOT_OFFSET - BOOT_STACK_SIZE)36 34 37 35 .section K_TEXT_START, "ax" … … 78 76 .word MULTIBOOT2_FLAGS_REQUIRED 79 77 .long tag_entry_address_end - tag_entry_address_start 80 .long multiboot 2_image_start78 .long multiboot_image_start 81 79 tag_entry_address_end: 82 80 … … 120 118 tag_terminator_end: 121 119 multiboot2_header_end: 122 123 SYMBOL(multiboot2_image_start)124 cli125 cld126 127 /* Initialize stack pointer */128 movl $START_STACK, %esp129 130 /*131 * Initialize Global Descriptor Table and132 * Interrupt Descriptor Table registers133 */134 lgdtl bootstrap_gdtr135 lidtl bootstrap_idtr136 137 /* Kernel data + stack */138 movw $GDT_SELECTOR(KDATA_DES), %cx139 movw %cx, %es140 movw %cx, %fs141 movw %cx, %gs142 movw %cx, %ds143 movw %cx, %ss144 145 jmpl $GDT_SELECTOR(KTEXT_DES), $multiboot2_meeting_point146 multiboot2_meeting_point:147 148 /* Save multiboot arguments */149 movl %eax, multiboot_eax150 movl %ebx, multiboot_ebx151 152 #ifndef PROCESSOR_i486153 154 movl $(INTEL_CPUID_LEVEL), %eax155 cpuid156 cmp $0x0, %eax /* any function > 0? */157 jbe pse_unsupported158 159 movl $(INTEL_CPUID_STANDARD), %eax160 cpuid161 bt $(INTEL_PSE), %edx162 jnc pse_unsupported163 164 /* Map kernel and turn paging on */165 call map_kernel_pse166 jmp stack_init167 168 #endif /* PROCESSOR_i486 */169 170 pse_unsupported:171 172 /* Map kernel and turn paging on */173 call map_kernel_non_pse174 175 stack_init:176 177 /* Create the first stack frame */178 pushl $0179 movl %esp, %ebp180 181 /* Call ia32_pre_main(multiboot_eax, multiboot_ebx) */182 pushl multiboot_ebx183 pushl multiboot_eax184 call ia32_pre_main185 186 /* Call main_bsp() */187 call main_bsp188 189 /* Not reached */190 cli191 hlt0:192 hlt193 jmp hlt0
Note:
See TracChangeset
for help on using the changeset viewer.