Received: by 2002:a25:e7d8:0:0:0:0:0 with SMTP id e207csp633037ybh; Thu, 12 Mar 2020 08:18:22 -0700 (PDT) X-Google-Smtp-Source: ADFU+vubNRxnyeen0a/SkxH1gH8MRexsmSTGzRRhgUfQizmckntW0fxxB3IXJh24TrPgMMwnECkI X-Received: by 2002:a9d:4c15:: with SMTP id l21mr6986233otf.185.1584026302389; Thu, 12 Mar 2020 08:18:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1584026302; cv=none; d=google.com; s=arc-20160816; b=MYpRLxKeWBB+c07Qf/xaeknpaG640fyOzo5u81FRQRdDaYI1J1NQhh12e3Z7QRc8RQ CEVHSFhoY5uV4lEAYzB252dueA5Q7xL7IDAhNyC9S1arp+1UK1z8d0+tLNMqNwln8VS4 1taP0NaIgexXNCnwPHdg+G90pM3bVZM5G+5lv7xgd2KV1kVkp+nchJgnwaUArzUS0rk/ vEzp1JEUEObs8SSv4TaZmeaTkWzMt57lV6PPCq26bDnyievikTjbqAUGS2qpDCjZ7XPi XHfidpm7NEFa1951Yl9O74k9ahi+Eieg/pt+uedFQWjb3dLYzJY2gSOhDPp+goFJtwJq UGng== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :message-id:in-reply-to:subject:cc:to:from:date; bh=rGpFKQeNv1CDndkeua+vi0ityN3M50GGaHNHDfg1++k=; b=U6eSIyk3Vi1zgLYCz0h+pKxwP97L0uOEz3SW+FZvQ/ZMjFtk827XE5IUsvhICsicxP 7shnTrQeICf2Z3GIMxFJbyaKP//q6hXxyQar1DoGjyfSeV8h1IPnF79K58qKBfhEGQ0D NgUeNrI4zqe3u68zM2TMDcMnXxM1tya7/uoA3YNgJ6p4MqRyA0arBZ3G+bz54t8/+pfR IrnBAdek84yP610Vue2GaOVjbp/4sOw2VnTsJwc3ImCex6Ty6ZcLdaQvw2HItWmzoZN3 Rp/LjAv41wpk9pMEudf+Gzo3goWxQEPeJUbQo9+m5tRqXhSuNm0rdYUIm2AwTPX/TRBs cPbg== ARC-Authentication-Results: i=1; mx.google.com; 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 p203si2683838oic.214.2020.03.12.08.18.08; Thu, 12 Mar 2020 08:18:22 -0700 (PDT) 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; 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 S1727833AbgCLPRH (ORCPT + 99 others); Thu, 12 Mar 2020 11:17:07 -0400 Received: from mx2.suse.de ([195.135.220.15]:40160 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727455AbgCLPRH (ORCPT ); Thu, 12 Mar 2020 11:17:07 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.220.254]) by mx2.suse.de (Postfix) with ESMTP id A62CCABF4; Thu, 12 Mar 2020 15:17:05 +0000 (UTC) Date: Thu, 12 Mar 2020 16:17:04 +0100 (CET) From: Miroslav Benes To: Andrew Cooper cc: boris.ostrovsky@oracle.com, jgross@suse.com, sstabellini@kernel.org, tglx@linutronix.de, mingo@redhat.com, bp@alien8.de, hpa@zytor.com, jpoimboe@redhat.com, x86@kernel.org, linux-kernel@vger.kernel.org, live-patching@vger.kernel.org, xen-devel@lists.xenproject.org, jslaby@suse.cz Subject: Re: [Xen-devel] [PATCH 1/2] x86/xen: Make the boot CPU idle task reliable In-Reply-To: Message-ID: References: <20200312142007.11488-1-mbenes@suse.cz> <20200312142007.11488-2-mbenes@suse.cz> User-Agent: Alpine 2.21 (LSU 202 2017-01-01) MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="1678380546-1273645187-1584026225=:28317" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This message is in MIME format. The first part should be readable text, while the remaining parts are likely unreadable without MIME-aware tools. --1678380546-1273645187-1584026225=:28317 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8BIT On Thu, 12 Mar 2020, Andrew Cooper wrote: > On 12/03/2020 14:20, Miroslav Benes wrote: > > The unwinder reports the boot CPU idle task's stack on XEN PV as > > unreliable, which affects at least live patching. There are two reasons > > for this. First, the task does not follow the x86 convention that its > > stack starts at the offset right below saved pt_regs. It allows the > > unwinder to easily detect the end of the stack and verify it. Second, > > startup_xen() function does not store the return address before jumping > > to xen_start_kernel() which confuses the unwinder. > > > > Amend both issues by moving the starting point of initial stack in > > startup_xen() and storing the return address before the jump. > > > > Signed-off-by: Miroslav Benes > > --- > > arch/x86/xen/xen-head.S | 4 +++- > > 1 file changed, 3 insertions(+), 1 deletion(-) > > > > diff --git a/arch/x86/xen/xen-head.S b/arch/x86/xen/xen-head.S > > index 1d0cee3163e4..642f346bfe02 100644 > > --- a/arch/x86/xen/xen-head.S > > +++ b/arch/x86/xen/xen-head.S > > @@ -35,7 +35,7 @@ SYM_CODE_START(startup_xen) > > rep __ASM_SIZE(stos) > > > > mov %_ASM_SI, xen_start_info > > - mov $init_thread_union+THREAD_SIZE, %_ASM_SP > > + mov $init_thread_union+THREAD_SIZE-SIZEOF_PTREGS, %_ASM_SP > > > > #ifdef CONFIG_X86_64 > > /* Set up %gs. > > @@ -51,7 +51,9 @@ SYM_CODE_START(startup_xen) > > wrmsr > > #endif > > > > + push $1f > > jmp xen_start_kernel > > +1: > > Hang on.  Isn't this just a `call` instruction written in longhand? It is (as far as I know). I wanted to keep it opencoded for a reason I don't remember now. I'll change it. Thanks. Miroslav --1678380546-1273645187-1584026225=:28317--