Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp762510ybl; Wed, 4 Dec 2019 10:25:46 -0800 (PST) X-Google-Smtp-Source: APXvYqx54nyzclA4vFWUNByChmVQ1L06+/uX/6/ozMbP85NoVVALCjorrrzEJXeBFTF1kr1uKBaW X-Received: by 2002:aca:52c3:: with SMTP id g186mr3638243oib.118.1575483946097; Wed, 04 Dec 2019 10:25:46 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1575483946; cv=none; d=google.com; s=arc-20160816; b=mk65wn8yfGNnWtoBWXXMjDXX/JmC8kYHuuzeZUv8Z0zfDOyzq7odCkegRZBpnUnOJN WF/jwaPxEieecTkF34/e2HUMJo2GwUqTZ84r1QL4gX4jd72EF0mfq45L4JtrJBcNGQ5K 9LOs4vJVLxZtkrZzYYJcAAiFiVeNw/zl2+qwkkBk/3ZmK08ZC8lLHC8AWQqd2f0JzYHJ MzFngYETND2dU06Y2+nXimLl3IowLH9JKuM4gHptMfeKq9caUlN7C4m+wdhnptD+pXo0 EZZe8Tw9ZGQjI5Q3XIg8BbpzRF9M84NvAx0xbIMI5qq5kPJ+UPTwisHddxBvmsunO7UG LLWA== 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=uZlLUooebcFFaPlC1mD2Wz6TOxFSwjLNhu6d+lazRSc=; b=p4qP57QXV8UjwjHxRtNjJGYzyjg1chWmQOrEFDT2shEWSxNuTuj0BJv9iSdm9ED9oV qZl7ko7dKLm77HaKHjEQjkvdJCujTinYrOWP5xbDsai2Op8G7AgvM014AeTwpjXw1/K+ woDHg5Q1b4MI6LT76syF7t9js8C/H40N4PQL8/61RBH5FDIXsKN+p3OZ15KQlojZYewD 5SZ3tq/rsfasVN4uI+6P1oYEmn90+OA/IyBVRjSMszFClESVqLRPhCzU6Y+6pq8mlZ3u kfSXdWc2akFqJBYSxwZCIkRA9B6EhjA1P9wJRmietoPOv1iQ5X77SFP0O9eW48F65Mg/ Gy0g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="U+/OZnRp"; 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 b18si3366544otl.202.2019.12.04.10.25.33; Wed, 04 Dec 2019 10:25:46 -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="U+/OZnRp"; 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 S1729836AbfLDSC0 (ORCPT + 99 others); Wed, 4 Dec 2019 13:02:26 -0500 Received: from mail.kernel.org ([198.145.29.99]:44318 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729356AbfLDSCY (ORCPT ); Wed, 4 Dec 2019 13:02:24 -0500 Received: from localhost (unknown [217.68.49.72]) (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 2318620659; Wed, 4 Dec 2019 18:02:22 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1575482543; bh=/FPIsBSNgYNCB0baNnp3NAbjXgfFsAp3hpp42LK7BVk=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=U+/OZnRpD6u1bYP4zmly8nF3/lwFsXrs6LOGcscrLoIS6Dz/O1Z2skPKUi2z9gTxD ia16p7gPwImZUWv2PU5Fe9hcLIUV7rCSyrt37VyF/HGqZUdwSSuBNC0naQCZJ4NHUo km89EgvKnE/qa82ymAGfTgApndzc3t+/d5rRVjNc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Steve Capper , Will Deacon , Sasha Levin Subject: [PATCH 4.14 037/209] arm64: mm: Prevent mismatched 52-bit VA support Date: Wed, 4 Dec 2019 18:54:09 +0100 Message-Id: <20191204175323.988332965@linuxfoundation.org> X-Mailer: git-send-email 2.24.0 In-Reply-To: <20191204175321.609072813@linuxfoundation.org> References: <20191204175321.609072813@linuxfoundation.org> User-Agent: quilt/0.66 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 From: Steve Capper [ Upstream commit a96a33b1ca57dbea4285893dedf290aeb8eb090b ] For cases where there is a mismatch in ARMv8.2-LVA support between CPUs we have to be careful in allowing secondary CPUs to boot if 52-bit virtual addresses have already been enabled on the boot CPU. This patch adds code to the secondary startup path. If the boot CPU has enabled 52-bit VAs then ID_AA64MMFR2_EL1 is checked to see if the secondary can also enable 52-bit support. If not, the secondary is prevented from booting and an error message is displayed indicating why. Technically this patch could be implemented using the cpufeature code when considering 52-bit userspace support. However, we employ low level checks here as the cpufeature code won't be able to run if we have mismatched 52-bit kernel va support. Signed-off-by: Steve Capper Signed-off-by: Will Deacon Signed-off-by: Sasha Levin --- arch/arm64/kernel/head.S | 26 ++++++++++++++++++++++++++ arch/arm64/kernel/smp.c | 5 +++++ 2 files changed, 31 insertions(+) diff --git a/arch/arm64/kernel/head.S b/arch/arm64/kernel/head.S index 92cc7b51f1002..9c00fd2acc2a4 100644 --- a/arch/arm64/kernel/head.S +++ b/arch/arm64/kernel/head.S @@ -594,6 +594,7 @@ secondary_startup: /* * Common entry point for secondary CPUs. */ + bl __cpu_secondary_check52bitva bl __cpu_setup // initialise processor bl __enable_mmu ldr x8, =__secondary_switched @@ -668,6 +669,31 @@ ENTRY(__enable_mmu) ret ENDPROC(__enable_mmu) +ENTRY(__cpu_secondary_check52bitva) +#ifdef CONFIG_ARM64_52BIT_VA + ldr_l x0, vabits_user + cmp x0, #52 + b.ne 2f + + mrs_s x0, SYS_ID_AA64MMFR2_EL1 + and x0, x0, #(0xf << ID_AA64MMFR2_LVA_SHIFT) + cbnz x0, 2f + + adr_l x0, va52mismatch + mov w1, #1 + strb w1, [x0] + dmb sy + dc ivac, x0 // Invalidate potentially stale cache line + + update_early_cpu_boot_status CPU_STUCK_IN_KERNEL, x0, x1 +1: wfe + wfi + b 1b + +#endif +2: ret +ENDPROC(__cpu_secondary_check52bitva) + __no_granule_support: /* Indicate that this CPU can't boot and is stuck in the kernel */ update_early_cpu_boot_status CPU_STUCK_IN_KERNEL, x1, x2 diff --git a/arch/arm64/kernel/smp.c b/arch/arm64/kernel/smp.c index a683cd4995157..0881dfab10f8f 100644 --- a/arch/arm64/kernel/smp.c +++ b/arch/arm64/kernel/smp.c @@ -106,6 +106,7 @@ static int boot_secondary(unsigned int cpu, struct task_struct *idle) } static DECLARE_COMPLETION(cpu_running); +bool va52mismatch __ro_after_init; int __cpu_up(unsigned int cpu, struct task_struct *idle) { @@ -135,6 +136,10 @@ int __cpu_up(unsigned int cpu, struct task_struct *idle) if (!cpu_online(cpu)) { pr_crit("CPU%u: failed to come online\n", cpu); + + if (IS_ENABLED(CONFIG_ARM64_52BIT_VA) && va52mismatch) + pr_crit("CPU%u: does not support 52-bit VAs\n", cpu); + ret = -EIO; } } else { -- 2.20.1