Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp4558673imu; Tue, 29 Jan 2019 03:47:10 -0800 (PST) X-Google-Smtp-Source: ALg8bN6UNCRg6cQsquCaPRGYpLNo8402rSdBGX+NBCilwCh7ppW5L2DpIaE0B0d0gtlLf2cZRSis X-Received: by 2002:a62:2cf:: with SMTP id 198mr26008435pfc.67.1548762430500; Tue, 29 Jan 2019 03:47:10 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1548762430; cv=none; d=google.com; s=arc-20160816; b=IiuhYoC+wG02IC9yQf0yBVxUbtjC0DGHX9w618+IVVQaIsrMQEBQusBWkyeGIgPgH4 YOGyWDmH1eE7N4E/ByRe9odWpK1n4czcKNSDCiJZWcurwcmrWt9oUHyM0XWrNAP5yhaF sAb9iFk8h0Z2cogWcfx9NCT3PsjTt7WtAmLX5+1MvQXnvlUGbrdnE21W4a5wvxCcBm8d fwcgFaUuGNO48yJw5UOHeAJSzZqxzxqHkcQjoZM0GpfPzVLmgqFyOxCgwo61ka+CIE7L gyCxdD241ccgeCW7gAn02008NkDCLeZR/OOQoSHLtwGmFzzcpyvZOZOrxXl1cIqlJMH5 Z0kw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=aIWwFyQIjyfsunWn4kZn8v+SS0kMY4RYMokshpcaGY4=; b=tzMKm0RDoql5ydcjCMjGOFBbt7RWPcmH1u1r1u2Isp9JL9blgl7AByoaNe471FScEf zEi1bqiLb4DNRi6aay5UHlWOG2n2i0D2FL98xyd1a/5olu1XzdKKs/tpEOHP0hZK08Yg ppZJSiOGP7c3CkuzJzYgnh8r3QmDABEAAAinc0TZ1puQcg3pP5+CGI+qNiJPFoARCeF8 IKj/8WPjH7BJsU9FEbC2lmS7lLWOWOEmt9qD3U32UAetazowNigDKhhcf1JKowjV/PRS HXSIy17sCTF3YE/0RFKRhvsPTGuPNb0pNR7z7/Vso24zF8A1BNWPAGJ7jPVahy74Oiia rwZA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=HzZUq271; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f189si21288430pfg.123.2019.01.29.03.46.55; Tue, 29 Jan 2019 03:47:10 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=HzZUq271; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730824AbfA2Lpn (ORCPT + 99 others); Tue, 29 Jan 2019 06:45:43 -0500 Received: from mail.kernel.org ([198.145.29.99]:36202 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730814AbfA2Lpm (ORCPT ); Tue, 29 Jan 2019 06:45:42 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 5CC5C20882; Tue, 29 Jan 2019 11:45:41 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1548762341; bh=CoOyLPvBlziB3oKmes/Vo0P0Rd/a5U6nQeucAkUPW5E=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=HzZUq271l5fpOh4lt4p+uzQJWk5Bd8t52TiclVu/kCb5xSp0dsGGlvzWR1fVqPu2V Y8/LW9WSGJHIoMrtAtyxbZAcwg6jl8oXFPVG94W/ak3wUSMPxMvbC+ZITR78jQPptl 1BrRkOXwn45B0GgLZWctHUwH5nuCTsQsHqq6Afek= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jan Beulich , Thomas Gleixner , Juergen Gross , Andy Lutomirski , Peter Anvin , Boris Ostrovsky , xen-devel@lists.xenproject.org Subject: [PATCH 4.19 075/103] x86/entry/64/compat: Fix stack switching for XEN PV Date: Tue, 29 Jan 2019 12:35:52 +0100 Message-Id: <20190129113205.301971958@linuxfoundation.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190129113159.567154026@linuxfoundation.org> References: <20190129113159.567154026@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.19-stable review patch. If anyone has any objections, please let me know. ------------------ From: Jan Beulich commit fc24d75a7f91837d7918e40719575951820b2b8f upstream. 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: 7f2590a110b8 ("x86/entry/64: Use a per-CPU trampoline stack for IDT entries") Signed-off-by: Jan Beulich Signed-off-by: Thomas Gleixner Reviewed-by: Juergen Gross Acked-by: Andy Lutomirski Cc: Peter Anvin Cc: xen-devel@lists.xenproject.org> Cc: Boris Ostrovsky Cc: stable@vger.kernel.org Link: https://lkml.kernel.org/r/5C3E1128020000780020DFAD@prv1-mh.provo.novell.com Signed-off-by: Greg Kroah-Hartman --- arch/x86/entry/entry_64_compat.S | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) --- a/arch/x86/entry/entry_64_compat.S +++ b/arch/x86/entry/entry_64_compat.S @@ -356,7 +356,8 @@ ENTRY(entry_INT80_compat) /* Need to switch before accessing the thread stack. */ SWITCH_TO_KERNEL_CR3 scratch_reg=%rdi - movq %rsp, %rdi + /* In the Xen PV case we already run on the thread stack. */ + ALTERNATIVE "movq %rsp, %rdi", "jmp .Lint80_keep_stack", X86_FEATURE_XENPV movq PER_CPU_VAR(cpu_current_top_of_stack), %rsp pushq 6*8(%rdi) /* regs->ss */ @@ -365,8 +366,9 @@ ENTRY(entry_INT80_compat) pushq 3*8(%rdi) /* regs->cs */ pushq 2*8(%rdi) /* regs->ip */ pushq 1*8(%rdi) /* regs->orig_ax */ - pushq (%rdi) /* pt_regs->di */ +.Lint80_keep_stack: + pushq %rsi /* pt_regs->si */ xorl %esi, %esi /* nospec si */ pushq %rdx /* pt_regs->dx */