]> git.baikalelectronics.ru Git - kernel.git/commit
x86/entry/64/compat: Fix stack switching for XEN PV
authorJan Beulich <JBeulich@suse.com>
Tue, 15 Jan 2019 16:58:16 +0000 (09:58 -0700)
committerThomas Gleixner <tglx@linutronix.de>
Thu, 17 Jan 2019 23:39:33 +0000 (00:39 +0100)
commitc5e8567c6fedf669af0ff3cdba8491559e7a6de0
tree08fb4bf98efdcb7a47927dc8728ad46eead86fbd
parent88f9ccd2f73ea188e4de243b9c76c48ef3f6cc81
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: a70e6a0fb8d2 ("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
arch/x86/entry/entry_64_compat.S