Lines Matching +full:ecx +full:- +full:2000
1 /* SPDX-License-Identifier: GPL-2.0 */
3 * linux/arch/x86/kernel/head_64.S -- start in 32bit and switch to 64bit
5 * Copyright (C) 2000 Andrea Arcangeli <[email protected]> SuSE
6 * Copyright (C) 2000 Pavel Machek <[email protected]>
7 * Copyright (C) 2000 Karsten Keil <[email protected]>
21 #include <asm/processor-flags.h>
25 #include <asm/nospec-branch.h>
33 * because we need identity-mapped pages.
65 movl $MSR_GS_BASE, %ecx
86 * be done now, since this also includes setup of the SEV-SNP CPUID table,
98 * Derive the kernel's physical-to-virtual offset from the physical and
121 * For SEV guests: Verify that the C-bit is correct. A malicious
122 * hypervisor could lie about the C-bit position to perform a ROP
164 * SEV-ES guests. In those guests the call to verify_cpu() would cause
168 * All non SEV-ES systems, especially Intel systems, need to execute
180 addq $(init_top_pgt - __START_KERNEL_map), %rax
220 andl %edx, %ecx
223 btsl $X86_CR4_PSE_BIT, %ecx
227 * Set CR4.PGE to re-enable global translations.
229 btsl $X86_CR4_PGE_BIT, %ecx
239 * Bit 0-23 CPU# if STARTUP_xx flags are not set
241 movl smpboot_control(%rip), %ecx
242 testl $STARTUP_READ_APICID, %ecx
246 * in bit 0-23. This is also the boot CPU case (CPU number 0).
248 andl $(~STARTUP_PARALLEL_MASK), %ecx
253 mov $MSR_IA32_APICBASE, %ecx
274 /* Read the APIC ID from the fix-mapped MMIO space. */
282 mov $APIC_X2APIC_ID_MSR, %ecx
287 xorl %ecx, %ecx
293 inc %ecx
295 cmpl $NR_CPUS, %ecx
297 cmpl nr_cpu_ids(%rip), %ecx
310 /* Get the per cpu offset for the given CPU# which is in ECX */
313 xorl %edx, %edx /* zero-extended to clear all of RDX */
317 * Setup a boot time stack - Any secondary CPU will have lost its stack
318 * by now because the cr3-switch above unmaps the real-mode stack.
320 * RDX contains the per-cpu offset
342 movw $(GDT_SIZE-1), (%rsp)
369 movl $MSR_GS_BASE,%ecx
386 movl $MSR_EFER, %ecx
505 .fill early_idt_handler_array + i*EARLY_IDT_HANDLER_SIZE - ., 1, 0xcc
520 /* The vector number is currently in the pt_regs->di slot. */
521 pushq %rsi /* pt_regs->si */
523 movq %rdi, 8(%rsp) /* pt_regs->di = RDI */
524 pushq %rdx /* pt_regs->dx */
525 pushq %rcx /* pt_regs->cx */
526 pushq %rax /* pt_regs->ax */
527 pushq %r8 /* pt_regs->r8 */
528 pushq %r9 /* pt_regs->r9 */
529 pushq %r10 /* pt_regs->r10 */
530 pushq %r11 /* pt_regs->r11 */
531 pushq %rbx /* pt_regs->bx */
532 pushq %rbp /* pt_regs->bp */
533 pushq %r12 /* pt_regs->r12 */
534 pushq %r13 /* pt_regs->r13 */
535 pushq %r14 /* pt_regs->r14 */
536 pushq %r15 /* pt_regs->r15 */
550 * paravirtualized INTERRUPT_RETURN and pv-ops don't work that early.
575 /* Pure iret required here - don't use INTERRUPT_RETURN */
592 /* This ensures they are 8k-aligned: */
606 .quad level3_kernel_pgt - __START_KERNEL_map + _PAGE_TABLE_NOENC
620 .quad level3_ident_pgt - __START_KERNEL_map + _KERNPG_TABLE_NOENC
622 .quad level3_ident_pgt - __START_KERNEL_map + _KERNPG_TABLE_NOENC
624 /* (2^48-(2*1024*1024*1024))/(2^39) = 511 */
625 .quad level3_kernel_pgt - __START_KERNEL_map + _PAGE_TABLE_NOENC
630 .quad level2_ident_pgt - __START_KERNEL_map + _KERNPG_TABLE_NOENC
654 .quad level3_kernel_pgt - __START_KERNEL_map + _PAGE_TABLE_NOENC
660 /* (2^48-(2*1024*1024*1024)-((2^39)*511))/(2^30) = 510 */
661 .quad level2_kernel_pgt - __START_KERNEL_map + _KERNPG_TABLE_NOENC
662 .quad level2_fixmap_pgt - __START_KERNEL_map + _PAGE_TABLE_NOENC
683 .fill (512 - 4 - FIXMAP_PMD_NUM),8,0
686 .quad level1_fixmap_pgt + (pgtno << PAGE_SHIFT) - __START_KERNEL_map \
710 #include "../xen/xen-head.S"