Skip to content

Commit fc24d75

Browse files
jbeulichKAGA-KOKO
authored andcommitted
x86/entry/64/compat: Fix stack switching for XEN PV
While in the native case entry into the kernel happens on the trampoline stack, PV Xen kernels get entered with the current thread stack right away. Hence source and destination stacks are identical in that case, and special care is needed. Other than in sync_regs() the copying done on the INT80 path isn't NMI / #MC safe, as either of these events occurring in the middle of the stack copying would clobber data on the (source) stack. There is similar code in interrupt_entry() and nmi(), but there is no fixup required because those code paths are unreachable in XEN PV guests. [ tglx: Sanitized subject, changelog, Fixes tag and stable mail address. Sigh ] Fixes: 7f2590a ("x86/entry/64: Use a per-CPU trampoline stack for IDT entries") Signed-off-by: Jan Beulich <jbeulich@suse.com> Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Juergen Gross <jgross@suse.com> Acked-by: Andy Lutomirski <luto@kernel.org> Cc: Peter Anvin <hpa@zytor.com> Cc: xen-devel@lists.xenproject.org> Cc: Boris Ostrovsky <boris.ostrovsky@oracle.com> Cc: stable@vger.kernel.org Link: https://lkml.kernel.org/r/5C3E1128020000780020DFAD@prv1-mh.provo.novell.com
1 parent 993a110 commit fc24d75

File tree

1 file changed

+4
-2
lines changed

1 file changed

+4
-2
lines changed

arch/x86/entry/entry_64_compat.S

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -361,7 +361,8 @@ ENTRY(entry_INT80_compat)
361361

362362
/* Need to switch before accessing the thread stack. */
363363
SWITCH_TO_KERNEL_CR3 scratch_reg=%rdi
364-
movq %rsp, %rdi
364+
/* In the Xen PV case we already run on the thread stack. */
365+
ALTERNATIVE "movq %rsp, %rdi", "jmp .Lint80_keep_stack", X86_FEATURE_XENPV
365366
movq PER_CPU_VAR(cpu_current_top_of_stack), %rsp
366367

367368
pushq 6*8(%rdi) /* regs->ss */
@@ -370,8 +371,9 @@ ENTRY(entry_INT80_compat)
370371
pushq 3*8(%rdi) /* regs->cs */
371372
pushq 2*8(%rdi) /* regs->ip */
372373
pushq 1*8(%rdi) /* regs->orig_ax */
373-
374374
pushq (%rdi) /* pt_regs->di */
375+
.Lint80_keep_stack:
376+
375377
pushq %rsi /* pt_regs->si */
376378
xorl %esi, %esi /* nospec si */
377379
pushq %rdx /* pt_regs->dx */

0 commit comments

Comments
 (0)