Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp4129202ybv; Sun, 16 Feb 2020 14:40:57 -0800 (PST) X-Google-Smtp-Source: APXvYqysukhqrCN6YlslSfgxuWMNpIM2niSmogojm/pfBppxnPDTLkk18HAvKABEYFRCYS3fFVlT X-Received: by 2002:aca:190b:: with SMTP id l11mr8679433oii.65.1581892857631; Sun, 16 Feb 2020 14:40:57 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581892857; cv=none; d=google.com; s=arc-20160816; b=czVwJSiMV5FqDOCJOqQVnRrysigjGYkKsjiJpxTV/1nP91SoRjQQbt/84ZvSvNn6dg 9PoBPZhr7FKWEIpOhfsGD4dtxBslCceR7QgSTLP8PSVWJ20Qyp1HV5Zoea87IFD/7348 X7CAvni9i3P5+syiy2heBvG4uxBLEaGfFvNjVWsgJMC+sXTtOcsv2aavVfghQNXMW9/8 ZxTaalwtEEL2MdBxWHJ9KhZsQd0gOsktsoqBxwvlrQHsIhURD+MASryhLWT3Ycff/gmy CR7UyBBOrr9rxBaV6H1G52RGah8nZ4cF9Spt+wxLd07Np32XpplE5gnJ7HlvWmc6q57n 1vEA== 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 :content-transfer-encoding:references:in-reply-to:date:cc:to:from :subject:message-id:dkim-signature; bh=DfHpcdG8v40i5aP+04JuR04nhCwzRega0nsgsSKcsrI=; b=BHNBpCAGpbDA7lHDZ8m0yINAt+PDxfJuf5lrsnyD3fJ060jw0OG8sEnoJa/FASEF8x /vxQf7+4uB52frh5fA18SOpLZdF5UD19S2fhhGzwFRLkJJIpbQGO0BSHKskAFC+RtYOK KxdHofljDCM7lHCgCFXKi778bGkajDyepiZZ4nM31F+66mPPefIVCXxH8/5p8XPVZPsf Iew0LQMB84TnWbeiLsHpMXOl+HepQ7NX4HZU67KTVeOzo5dLr6CCxS8jazAhW6VDjNnW JiaOAOxXjubxnw9hhHdTCUSgpSIdOrvWBElLWKio7+Wpz7qtT7KOmGJsx3ryHxEBsII2 J0Xw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@neuling.org header.s=201811 header.b="LaTcm1/x"; 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 o20si6137705otl.60.2020.02.16.14.40.45; Sun, 16 Feb 2020 14:40:57 -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=@neuling.org header.s=201811 header.b="LaTcm1/x"; 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 S1726962AbgBPWkK (ORCPT + 99 others); Sun, 16 Feb 2020 17:40:10 -0500 Received: from ozlabs.org ([203.11.71.1]:57897 "EHLO ozlabs.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726020AbgBPWkK (ORCPT ); Sun, 16 Feb 2020 17:40:10 -0500 Received: from neuling.org (localhost [127.0.0.1]) by ozlabs.org (Postfix) with ESMTP id 48LMWX1sdzz9sPK; Mon, 17 Feb 2020 09:40:08 +1100 (AEDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=neuling.org; s=201811; t=1581892808; bh=G/Tu9BGtdDP3vr8nlEE7cchRJpvilg7OMHuREeSG49A=; h=Subject:From:To:Cc:Date:In-Reply-To:References:From; b=LaTcm1/xqXNn/I3GiEqi19nv2R+deV0sgw0w/DwW5Z1P1Mg9q6oyvf/vFRaAUePST Xb/cgUHa2U+bpbqe7VYwqrzH24BXhm8BC/82SW/pzzfPdoOj/b6EShlTvWLyG4YVWj pXD60nii1eSz+cz7YmnRj1aEioWFeR6DPxDyNwzAIPiVVuZMHHgNs+adlQmMUOpK5a IhZBe4hbtIoao9/JWovRGRtWOn30FVV5px+y6PELMpuViBqsptFI+F3GuN/Y72ljl/ M3TyUmjFpYmKnNa2QKVmZ3xSjmai4PpIV+5+eXUHkQdV16NzQ/jGaeT/2ngSAhszUZ Jzo8x4tZoo9wA== Received: by neuling.org (Postfix, from userid 1000) id 27C302C01ED; Mon, 17 Feb 2020 09:40:08 +1100 (AEDT) Message-ID: <04cdd26307a1eaebeacc039b207db92e0b6820bb.camel@neuling.org> Subject: Re: [PATCH] powerpc/chrp: Fix enter_rtas() with CONFIG_VMAP_STACK From: Michael Neuling To: Christophe Leroy , Benjamin Herrenschmidt , Paul Mackerras , Michael Ellerman Cc: linuxppc-dev@lists.ozlabs.org, linux-kernel@vger.kernel.org Date: Mon, 17 Feb 2020 09:40:08 +1100 In-Reply-To: <159ecb0ab021c07fd2f383d4a083a43d16d67b92.1581669187.git.christophe.leroy@c-s.fr> References: <159ecb0ab021c07fd2f383d4a083a43d16d67b92.1581669187.git.christophe.leroy@c-s.fr> Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable User-Agent: Evolution 3.34.3 (3.34.3-1.fc31) MIME-Version: 1.0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, 2020-02-14 at 08:33 +0000, Christophe Leroy wrote: > With CONFIG_VMAP_STACK, data MMU has to be enabled > to read data on the stack. Can you describe what goes wrong without this? Some oops message? rtas blow= s up? Get corrupt data? Also can you say what you're actually doing (ie turning on MSR[DR]) > Signed-off-by: Christophe Leroy > --- > arch/powerpc/kernel/entry_32.S | 9 +++++++-- > 1 file changed, 7 insertions(+), 2 deletions(-) >=20 > diff --git a/arch/powerpc/kernel/entry_32.S b/arch/powerpc/kernel/entry_3= 2.S > index 0713daa651d9..bc056d906b51 100644 > --- a/arch/powerpc/kernel/entry_32.S > +++ b/arch/powerpc/kernel/entry_32.S > @@ -1354,12 +1354,17 @@ _GLOBAL(enter_rtas) > mtspr SPRN_SRR0,r8 > mtspr SPRN_SRR1,r9 > RFI > -1: tophys(r9,r1) > +1: tophys_novmstack r9, r1 > +#ifdef CONFIG_VMAP_STACK > + li r0, MSR_KERNEL & ~MSR_IR /* can take DTLB miss */ You're potentially turning on more than MSR DR here. This should be clear i= n the commit message. > + mtmsr r0 > + isync > +#endif > lwz r8,INT_FRAME_SIZE+4(r9) /* get return address */ > lwz r9,8(r9) /* original msr value */ > addi r1,r1,INT_FRAME_SIZE > li r0,0 > - tophys(r7, r2) > + tophys_novmstack r7, r2 > stw r0, THREAD + RTAS_SP(r7) > mtspr SPRN_SRR0,r8 > mtspr SPRN_SRR1,r9