Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp913493pxb; Wed, 3 Mar 2021 20:51:17 -0800 (PST) X-Google-Smtp-Source: ABdhPJz3GbIBmO0Exv8wz8j1229pHeSwBWBp8xGKVkwT8/XNYg4w3xm5ZXFQ4jEPsVWMYNYCgqGg X-Received: by 2002:a17:906:5295:: with SMTP id c21mr2216072ejm.67.1614833477194; Wed, 03 Mar 2021 20:51:17 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1614833477; cv=none; d=google.com; s=arc-20160816; b=o8rc5nA2omUQ5sHOgdt/+4V5uBBZlUXrNnMITNGRawuwt06AwqeDANgZrlWnteQP1+ HdAVamiJIhGPE4n9gIjwyYTDSG5a4mqbof4rgHVgERacbUcHj+ITNwUGBfeRv/s87th6 YwKnsC0cDONcY3lXSagXKqp9Qu8q8Ah6Ukc1f5LRPKMwYaVbeu9auKkUAwFhpsRfDHan byBv00J+f0iWAId7px0BTsTSbCBwr/JhqVfhrWbhyj0V+pB40pz/h9LMk+YmTZ7YS/+E s7s0EG1pMoRjZzlZFAF9F4We0Fn5XL0Ou0hfrO5jRUFMaiO1/dVG8Ckoj59aLY/jeVne Uliw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=MWEbZcOCrwbicnZ1cZ1/TR5cHfm3wuLzuElz4ioS+Tk=; b=PwyZXADhyegGCWTeq8EHFlY1dqLWpV3faROY9BsTCQDT4Ad5tU26Kv8/3eK47K0g3+ SCSamD3NSyJsWTZLVV6ZAPjaH6f8sLsKL5C5vv4ugabT9Ld2AaDcd3hD/7D6aVA8Aekp dxkaAE2kFUZwuk85Odn60tfcTVZkfs8WuUbrg3SPi1hXC55cNCvJzxfoDfZjl8HJq0nL 6y1g8vEbkTh2rKXOPsOaDw2PeBjeWHZetALlDelioE7kvsUjJ16sAZYPMi/htm/8nic5 /yuIcuTd9i4yIBJtpZdqZFm+hvMZPCq48+WIrfT0AEHDzzfQrI+SGXDRV4NepFwk2Pki s8kA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=sWICAuKc; 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=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g10si17674926edf.314.2021.03.03.20.50.55; Wed, 03 Mar 2021 20:51:17 -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=@linuxfoundation.org header.s=korg header.b=sWICAuKc; 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=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1380956AbhCBB4x (ORCPT + 99 others); Mon, 1 Mar 2021 20:56:53 -0500 Received: from mail.kernel.org ([198.145.29.99]:50942 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S241719AbhCATdQ (ORCPT ); Mon, 1 Mar 2021 14:33:16 -0500 Received: by mail.kernel.org (Postfix) with ESMTPSA id D8B6D651F0; Mon, 1 Mar 2021 17:19:42 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1614619183; bh=SmWF1GTFjtoXWvYcuXgW5oDTOC+jBNtHG89hVlaooMk=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=sWICAuKcFS7ZED8YmPKwpzet7i59rigN4EVySIUKOs07PXpbXzdVmaRVShCC6K3/h y9tmVgEErNulf2yyV+xzX7mamwhGVOrFIjwsL1tEhdfKGkry5psQEyd7O1LhCkh5lD nwHj+eGHDfG7kDlenFvJKMz66tpYoP4n+ZmDWRAQ= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Vladimir Murzin , Russell King , Sasha Levin Subject: [PATCH 5.10 333/663] ARM: 9046/1: decompressor: Do not clear SCTLR.nTLSMD for ARMv7+ cores Date: Mon, 1 Mar 2021 17:09:41 +0100 Message-Id: <20210301161158.327754858@linuxfoundation.org> X-Mailer: git-send-email 2.30.1 In-Reply-To: <20210301161141.760350206@linuxfoundation.org> References: <20210301161141.760350206@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Vladimir Murzin [ Upstream commit 2acb909750431030b65a0a2a17fd8afcbd813a84 ] It was observed that decompressor running on hardware implementing ARM v8.2 Load/Store Multiple Atomicity and Ordering Control (LSMAOC), say, as guest, would stuck just after: Uncompressing Linux... done, booting the kernel. The reason is that it clears nTLSMD bit when disabling caches: nTLSMD, bit [3] When ARMv8.2-LSMAOC is implemented: No Trap Load Multiple and Store Multiple to Device-nGRE/Device-nGnRE/Device-nGnRnE memory. 0b0 All memory accesses by A32 and T32 Load Multiple and Store Multiple at EL1 or EL0 that are marked at stage 1 as Device-nGRE/Device-nGnRE/Device-nGnRnE memory are trapped and generate a stage 1 Alignment fault. 0b1 All memory accesses by A32 and T32 Load Multiple and Store Multiple at EL1 or EL0 that are marked at stage 1 as Device-nGRE/Device-nGnRE/Device-nGnRnE memory are not trapped. This bit is permitted to be cached in a TLB. This field resets to 1. Otherwise: Reserved, RES1 So as effect we start getting traps we are not quite ready for. Looking into history it seems that mask used for SCTLR clear came from the similar code for ARMv4, where bit[3] is the enable/disable bit for the write buffer. That not applicable to ARMv7 and onwards, so retire that bit from the masks. Fixes: 7d09e85448dfa78e3e58186c934449aaf6d49b50 ("[ARM] 4393/2: ARMv7: Add uncompressing code for the new CPU Id format") Signed-off-by: Vladimir Murzin Signed-off-by: Russell King Signed-off-by: Sasha Levin --- arch/arm/boot/compressed/head.S | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/arch/arm/boot/compressed/head.S b/arch/arm/boot/compressed/head.S index 3a392983ac079..a0de09f994d88 100644 --- a/arch/arm/boot/compressed/head.S +++ b/arch/arm/boot/compressed/head.S @@ -1175,9 +1175,9 @@ __armv4_mmu_cache_off: __armv7_mmu_cache_off: mrc p15, 0, r0, c1, c0 #ifdef CONFIG_MMU - bic r0, r0, #0x000d + bic r0, r0, #0x0005 #else - bic r0, r0, #0x000c + bic r0, r0, #0x0004 #endif mcr p15, 0, r0, c1, c0 @ turn MMU and cache off mov r0, #0 -- 2.27.0