Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp186981pxb; Thu, 21 Jan 2021 04:53:31 -0800 (PST) X-Google-Smtp-Source: ABdhPJyITGUcFvdFVvBDjiHFCwzzKtKBQpfoz+jCPJbcOa20Uisz58XuLPIeLVfjSyG5bG/VZuee X-Received: by 2002:a17:906:76d6:: with SMTP id q22mr8917396ejn.221.1611233611607; Thu, 21 Jan 2021 04:53:31 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611233611; cv=none; d=google.com; s=arc-20160816; b=ixHUk+LlrQSgG9xg39C8VKIOgRw2OatI0B3KB6TfVRETZQV+Dglo2bVe76xKpr/bEc rlWpS6AqADi//CXNxIADEjNsw+GLomJRb6oRMpGhJ2WJKrgFnh41gfxo4LkekdNpB/sm QHyKLyP2KFuwkAmAMCgqqyG/hcKzXFIsuvQFf6ff5tvXmko3dJoOL/qgEIxdhhY/Wczw WKQbFgki+S9yyiRf2RtcVBf1e+BSvfjb4v6UvlI3EAeB5F/u/PYnMr52gzOmq3HH4XUN LIRytoAFLyGZ+HPaAsarWgRJymUL673RXgvxY9yXYqGaISLSPeaGcE/A5+SpXY2lKCa1 JVEg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=SH5XNDTzcGE1gMmwlt67DyetMtf7rp+ZMNhEJB/EcFA=; b=N9YVjbzLsDU8wPcCiWEIjeX7Sbq5kUUA2phBalFhxW6lw8CpboLxgEgHxb0T+v++VJ ZDJRx+Gjnceu+UYHX0F5C7Ac17c2JAHs3bOw63UgURUTiUEYfPRwuCGx6+y3Bqs0gJSX IAEjv4iCp1nnD4Nr7z7w3TD2iCB04uUCbx6J0/DTQbbIAcyL2m+ZD4BizAoYsoc9fkQH lqy/WmqHh0hUdQyT0SyApIa0bdclp+rwOtwb4SYpXeVelnGnlNKrE0jmCaz6Ui0EUp/t tU7FmtgcWB+hochCbNKYdjdfE2hujJJLMrIlaRCjhDYwaGVvBdeT9M9XybNT/g1MMKu/ K9yQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=juVxlmLR; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i13si1726575ejz.170.2021.01.21.04.53.07; Thu, 21 Jan 2021 04:53:31 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=juVxlmLR; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729880AbhAUMt1 (ORCPT + 99 others); Thu, 21 Jan 2021 07:49:27 -0500 Received: from mail.kernel.org ([198.145.29.99]:32858 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731458AbhAUMs3 (ORCPT ); Thu, 21 Jan 2021 07:48:29 -0500 Received: by mail.kernel.org (Postfix) with ESMTPSA id 8E7A1239FD; Thu, 21 Jan 2021 12:47:46 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1611233268; bh=dd4yVlG9KCtejepvHpsxeT3++mxKoHWtZTeivvj2m1Y=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=juVxlmLRk3sPnqi2cpCwV8Yh5CyUDKDtHm9bgxeBYtb7PgJ/QYTC2/S7FMVsbGieX +p+G+tAXsn3Wpqle6HWrVvXAf81J/hLdQLdkBLHa7g8+MelcuuiHROOMSL10KaUuCZ XI11xwu0vo4X9jpN7GY5jfHt2Aw85hD0nFeioehNGfULUNy6qmaVJ+5gV/iBqXABCm +RGFeDKDWWXQFGlqqKpCIzpWzNRbLl4otLMlpx5lzLJ34oSuMBP/FtFf9m9TZbuclf Cvg+JJmm1O+NVO88bZeg9Fn713WyC6GoeO6bYQWf7CvatkVdCP1510apDJ8fT+KazG Kq2DckCKrXzLA== Date: Thu, 21 Jan 2021 12:47:43 +0000 From: Will Deacon To: Marc Zyngier Cc: Mohamed Mediouni , linux-arm-kernel@lists.infradead.org, Catalin Marinas , Mark Rutland , Hector Martin , linux-kernel@vger.kernel.org, Stan Skowronek Subject: Re: [RFC PATCH 3/7] arm64: mm: use nGnRnE instead of nGnRE on Apple processors Message-ID: <20210121124742.GA22123@willie-the-truck> References: <20210120132717.395873-1-mohamed.mediouni@caramail.com> <20210120132717.395873-4-mohamed.mediouni@caramail.com> <20210121112725.GA21750@willie-the-truck> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.10.1 (2018-07-13) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Jan 21, 2021 at 11:44:23AM +0000, Marc Zyngier wrote: > On 2021-01-21 11:27, Will Deacon wrote: > > On Wed, Jan 20, 2021 at 02:27:13PM +0100, Mohamed Mediouni wrote: > > > Use nGnRnE instead of nGnRE on Apple SoCs to workaround a serious > > > hardware quirk. > > > > > > On Apple processors, writes using the nGnRE device memory type get > > > dropped in flight, > > > getting to nowhere. > > > > > > Signed-off-by: Stan Skowronek > > > Signed-off-by: Mohamed Mediouni > > > --- > > > arch/arm64/mm/proc.S | 26 ++++++++++++++++++++++++++ > > > 1 file changed, 26 insertions(+) > > > > > > diff --git a/arch/arm64/mm/proc.S b/arch/arm64/mm/proc.S > > > index 1f7ee8c8b7b8..06436916f137 100644 > > > --- a/arch/arm64/mm/proc.S > > > +++ b/arch/arm64/mm/proc.S > > > @@ -51,6 +51,25 @@ > > > #define TCR_KASAN_HW_FLAGS 0 > > > #endif > > > > > > +#ifdef CONFIG_ARCH_APPLE > > > + > > > +/* > > > + * Apple cores appear to black-hole writes done with nGnRE. > > > + * We settled on a work-around that uses MAIR vs changing every > > > single user of > > > + * nGnRE across the arm64 code. > > > + */ > > > + > > > +#define MAIR_EL1_SET_APPLE \ > > > + (MAIR_ATTRIDX(MAIR_ATTR_DEVICE_nGnRnE, MT_DEVICE_nGnRnE) | \ > > > + MAIR_ATTRIDX(MAIR_ATTR_DEVICE_nGnRnE, MT_DEVICE_nGnRE) | \ > > > + MAIR_ATTRIDX(MAIR_ATTR_DEVICE_GRE, MT_DEVICE_GRE) | \ > > > + MAIR_ATTRIDX(MAIR_ATTR_NORMAL_NC, MT_NORMAL_NC) | \ > > > + MAIR_ATTRIDX(MAIR_ATTR_NORMAL, MT_NORMAL) | \ > > > + MAIR_ATTRIDX(MAIR_ATTR_NORMAL_WT, MT_NORMAL_WT) | \ > > > + MAIR_ATTRIDX(MAIR_ATTR_NORMAL, MT_NORMAL_TAGGED)) > > > + > > > +#endif > > > + > > > /* > > > * Default MAIR_EL1. MT_NORMAL_TAGGED is initially mapped as Normal > > > memory and > > > * changed during __cpu_setup to Normal Tagged if the system > > > supports MTE. > > > @@ -432,6 +451,13 @@ SYM_FUNC_START(__cpu_setup) > > > * Memory region attributes > > > */ > > > mov_q x5, MAIR_EL1_SET > > > +#ifdef CONFIG_ARCH_APPLE > > > + mrs x0, MIDR_EL1 > > > + lsr w0, w0, #24 > > > + mov_q x1, MAIR_EL1_SET_APPLE > > > + cmp x0, #0x61 // 0x61 = Implementer: Apple > > > + csel x5, x1, x5, eq > > > > Why does this need to be done so early? It would be a lot cleaner if we > > could detect this in a similar fashion to other errata and update the > > MAIR > > appropriately. If that's not possible because of early IO mappings > > (which > > ones?), then we could instead initialise to nGnRnE unconditionally, but > > relax it to nGnRE if we detect that we _don't_ have the erratum. > > Would that imply another round-trip into the idmap, much like we do > when we switch to non-global mappings? Or do you expect that we can change > the MAIR with live mappings? I think we should be able to change it live and then invalidate the TLB. At least, my reading of the BBM requirements suggests that it isn't required for changing between different types of device memory. I can seek clarification from Arm if necessary. Will