Received: by 10.223.185.116 with SMTP id b49csp2321297wrg; Thu, 15 Feb 2018 09:48:41 -0800 (PST) X-Google-Smtp-Source: AH8x224exWZHvU63exOLaiLufzW2DppG1Y1N9mvQ+Xb9W0znZa+dkaBbZNFPmJR7/Vwdaf+FioEg X-Received: by 2002:a17:902:6716:: with SMTP id f22-v6mr353664plk.180.1518716921121; Thu, 15 Feb 2018 09:48:41 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1518716921; cv=none; d=google.com; s=arc-20160816; b=00jzPOU+3KeeN+yhwUY8o3VjLHsh+uHzTZbo9yGXlIO1eVbqSsvlguRYGFC39ihCYN VU/FsbIndXpj58ekFIUKxLiXFsIOOdqqve6MTtuee2PGSjAF3OZPWGBcNCOo/5Ub8iXw 21W4UOJxicsTVNjBC0ku4faTw28NsdjUAS0wuwEZ+GK97TmaOeXg7+fOu0HZywoFZJrW eiE0QnVDH9pXrTKcC861pdJFgWtNOx2ysdwPutbqh8Fpryjfk0ascMkmWyynqAYVGsUv ALyS1iVizvat++vB64MIPtkYOAZCzXyDy/MRRjARP7e27zEL7ozEUiuhFqvRiZl/6h1p ltTQ== 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 :in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=0zcUhgodgae+/xqhbVM2sIZ81isZt8LVqm/Mn5SJzMA=; b=C1ocUNAiG9k8EaHa6nsZ3pygrziMWYTQalg0a/RHni7xQTUhzDtOrUCHbzCej2CxTE JXvsDQAuz8TouY4BpsNlR8aKp8KIW7uHjA2BQXQ2eZTVXD7s56L2++YY5fs0nCeAQqyu k59H0ys4lWCe+N62djDlYz1PRK8zM0Tg2qYV0jWrBW39Z9Ztdu5a8gipZvMoFW3gGf7+ FUzC9T2SQEmuOcgeHNX1NAkiXaUA5d2SR1A7RDuPrtU2P0y+ml2H1TU6gT+BW3dlkgon jka9ffD9yFlyM+VE1qgmm9oafbd3+nQszR8KjE2cufku3lGRXOh0vPm4ilr32k3VKUIX oMHA== 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 v15si1857657pfk.397.2018.02.15.09.48.26; Thu, 15 Feb 2018 09:48:41 -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; 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 S1164925AbeBORqM (ORCPT + 99 others); Thu, 15 Feb 2018 12:46:12 -0500 Received: from mail.linuxfoundation.org ([140.211.169.12]:55930 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1164439AbeBOPbe (ORCPT ); Thu, 15 Feb 2018 10:31:34 -0500 Received: from localhost (LFbn-1-12258-90.w90-92.abo.wanadoo.fr [90.92.71.90]) by mail.linuxfoundation.org (Postfix) with ESMTPSA id 7104FDD6; Thu, 15 Feb 2018 15:31:33 +0000 (UTC) From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Mark Rutland , Will Deacon , Marc Zyngier , Suzuki K Poulose , Catalin Marinas , Ard Biesheuvel Subject: [PATCH 4.14 045/195] [Variant 3/Meltdown] arm64: capabilities: Handle duplicate entries for a capability Date: Thu, 15 Feb 2018 16:15:36 +0100 Message-Id: <20180215151707.993743572@linuxfoundation.org> X-Mailer: git-send-email 2.16.1 In-Reply-To: <20180215151705.738773577@linuxfoundation.org> References: <20180215151705.738773577@linuxfoundation.org> User-Agent: quilt/0.65 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.14-stable review patch. If anyone has any objections, please let me know. ------------------ From: Suzuki K Poulose Commit 67948af41f2e upstream. Sometimes a single capability could be listed multiple times with differing matches(), e.g, CPU errata for different MIDR versions. This breaks verify_local_cpu_feature() and this_cpu_has_cap() as we stop checking for a capability on a CPU with the first entry in the given table, which is not sufficient. Make sure we run the checks for all entries of the same capability. We do this by fixing __this_cpu_has_cap() to run through all the entries in the given table for a match and reuse it for verify_local_cpu_feature(). Cc: Mark Rutland Cc: Will Deacon Acked-by: Marc Zyngier Signed-off-by: Suzuki K Poulose Signed-off-by: Catalin Marinas Signed-off-by: Will Deacon Signed-off-by: Ard Biesheuvel Signed-off-by: Greg Kroah-Hartman --- arch/arm64/kernel/cpufeature.c | 44 +++++++++++++++++++++-------------------- 1 file changed, 23 insertions(+), 21 deletions(-) --- a/arch/arm64/kernel/cpufeature.c +++ b/arch/arm64/kernel/cpufeature.c @@ -1047,6 +1047,26 @@ static void __init setup_elf_hwcaps(cons cap_set_elf_hwcap(hwcaps); } +/* + * Check if the current CPU has a given feature capability. + * Should be called from non-preemptible context. + */ +static bool __this_cpu_has_cap(const struct arm64_cpu_capabilities *cap_array, + unsigned int cap) +{ + const struct arm64_cpu_capabilities *caps; + + if (WARN_ON(preemptible())) + return false; + + for (caps = cap_array; caps->desc; caps++) + if (caps->capability == cap && + caps->matches && + caps->matches(caps, SCOPE_LOCAL_CPU)) + return true; + return false; +} + void update_cpu_capabilities(const struct arm64_cpu_capabilities *caps, const char *info) { @@ -1125,8 +1145,9 @@ verify_local_elf_hwcaps(const struct arm } static void -verify_local_cpu_features(const struct arm64_cpu_capabilities *caps) +verify_local_cpu_features(const struct arm64_cpu_capabilities *caps_list) { + const struct arm64_cpu_capabilities *caps = caps_list; for (; caps->matches; caps++) { if (!cpus_have_cap(caps->capability)) continue; @@ -1134,7 +1155,7 @@ verify_local_cpu_features(const struct a * If the new CPU misses an advertised feature, we cannot proceed * further, park the cpu. */ - if (!caps->matches(caps, SCOPE_LOCAL_CPU)) { + if (!__this_cpu_has_cap(caps_list, caps->capability)) { pr_crit("CPU%d: missing feature: %s\n", smp_processor_id(), caps->desc); cpu_die_early(); @@ -1195,25 +1216,6 @@ static void __init mark_const_caps_ready static_branch_enable(&arm64_const_caps_ready); } -/* - * Check if the current CPU has a given feature capability. - * Should be called from non-preemptible context. - */ -static bool __this_cpu_has_cap(const struct arm64_cpu_capabilities *cap_array, - unsigned int cap) -{ - const struct arm64_cpu_capabilities *caps; - - if (WARN_ON(preemptible())) - return false; - - for (caps = cap_array; caps->desc; caps++) - if (caps->capability == cap && caps->matches) - return caps->matches(caps, SCOPE_LOCAL_CPU); - - return false; -} - extern const struct arm64_cpu_capabilities arm64_errata[]; bool this_cpu_has_cap(unsigned int cap)