Received: by 2002:ac0:de83:0:0:0:0:0 with SMTP id b3csp1447827imk; Mon, 4 Jul 2022 03:20:11 -0700 (PDT) X-Google-Smtp-Source: AGRyM1sODURNMpkMbNhWLC0JNHfdZP/OmMdpIEM1QjcVfiMiO4Qt674HilmtBlDgM2HvDdqozlhe X-Received: by 2002:a05:6402:5408:b0:435:60fa:5017 with SMTP id ev8-20020a056402540800b0043560fa5017mr38355210edb.223.1656930010885; Mon, 04 Jul 2022 03:20:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1656930010; cv=none; d=google.com; s=arc-20160816; b=BCoRf5DO/IRV0xowUqXj6woojj5vXOvibU4AEUnMkZldlD5Ms/7mZHBG9L5h13Vsww ACEa2gTjZubM+WY+zWrx8r9yUJibmQ04SaxPGrXq6jMB5waBrykdQTPyOWJXrAMjQcxB /DQ8NyRcDdvnXEmj6m01YpLPPvDYMlkHnbR8ncaXonxnOmCrphOVkwfwNsZ7rAD1Q1VE hnrW7RIeLxhkZODa3Cmns6CvIsDs0vLYGWOBxUnvUKWmBDraXpjuTpCrr+JOGzBqpkA8 ODbqMJofYqbDyn8nVZ2lv5kSCrPK6G8SxjubuoSrT58b2jotgeC+Q8q373wUYMEuu92Z wiXQ== 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 :references:in-reply-to:message-id:date:subject:cc:to:from; bh=fx3Tsk0y5ALvk8LslULNwBG2MrtYPWcUxTb1yPDWiSk=; b=nsTipCRBGsmK4iU954vBZSO/LDEq+Poe7Piv+cNJWWJ+/V6CdVcWB3nQrVj8dasGcQ pkjhKGzoQSuC07HGGAtBMzOE8gCKTi5V+TJOQIx50hc4QpcwmFeIFyMv+c2GJbGrB7dV 51XhSIuQknRSUDFXY98GwF8zkWavH9z6ZSKuQpEoIRh2H5V9DwPJtV/T0uEvG5iHUKDg 36XYpq47TN0nR1E+7zkzDzeqLhhUokagJQ95KkNKcNZLPT790U7VL+STpKH3gYMFuS5F 9VGfggM4B7gZZ6RcjEqxVfobop9XI4M88mXkt4jK4iZ9bzS/Hrji6/WsVbkZBK/2V1qv JCxA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id w26-20020a17090652da00b00722dbb75ae7si13010959ejn.450.2022.07.04.03.19.46; Mon, 04 Jul 2022 03:20:10 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234247AbiGDKRx (ORCPT + 99 others); Mon, 4 Jul 2022 06:17:53 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36210 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233613AbiGDKQo (ORCPT ); Mon, 4 Jul 2022 06:16:44 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 91B2ADF1F for ; Mon, 4 Jul 2022 03:16:42 -0700 (PDT) Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id AB9D214BF; Mon, 4 Jul 2022 03:16:42 -0700 (PDT) Received: from usa.arm.com (e103737-lin.cambridge.arm.com [10.1.197.49]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id 7B65B3F792; Mon, 4 Jul 2022 03:16:40 -0700 (PDT) From: Sudeep Holla To: linux-kernel@vger.kernel.org, Greg Kroah-Hartman Cc: Sudeep Holla , conor.dooley@microchip.com, valentina.fernandezalanis@microchip.com, Vincent Guittot , Dietmar Eggemann , Qing Wang , Rob Herring , "Rafael J . Wysocki" , Ionela Voinescu , Pierre Gondois , linux-arm-kernel@lists.infradead.org, linux-riscv@lists.infradead.org, Gavin Shan Subject: [PATCH v6 13/21] arch_topology: Set thread sibling cpumask only within the cluster Date: Mon, 4 Jul 2022 11:15:57 +0100 Message-Id: <20220704101605.1318280-14-sudeep.holla@arm.com> X-Mailer: git-send-email 2.37.0 In-Reply-To: <20220704101605.1318280-1-sudeep.holla@arm.com> References: <20220704101605.1318280-1-sudeep.holla@arm.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-6.9 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Currently the cluster identifier is not set on the DT based platforms. The reset or default value is -1 for all the CPUs. Once we assign the cluster identifier values correctly that may result in getting the thread siblings wrong as the core identifiers can be same for 2 different CPUs belonging to 2 different cluster. So, in order to get the thread sibling cpumasks correct, we need to update them only if the cores they belong are in the same cluster within the socket. Let us skip updation of the thread sibling cpumaks if the cluster identifier doesn't match. This change won't affect even if the cluster identifiers are not set currently but will avoid any breakage once we set the same correctly. Tested-by: Gavin Shan Tested-by: Ionela Voinescu Reviewed-by: Gavin Shan Signed-off-by: Sudeep Holla --- drivers/base/arch_topology.c | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/drivers/base/arch_topology.c b/drivers/base/arch_topology.c index 8206990c679f..6ab173caf1dc 100644 --- a/drivers/base/arch_topology.c +++ b/drivers/base/arch_topology.c @@ -708,15 +708,17 @@ void update_siblings_masks(unsigned int cpuid) if (cpuid_topo->package_id != cpu_topo->package_id) continue; - if (cpuid_topo->cluster_id == cpu_topo->cluster_id && - cpuid_topo->cluster_id != -1) { + cpumask_set_cpu(cpuid, &cpu_topo->core_sibling); + cpumask_set_cpu(cpu, &cpuid_topo->core_sibling); + + if (cpuid_topo->cluster_id != cpu_topo->cluster_id) + continue; + + if (cpuid_topo->cluster_id != -1) { cpumask_set_cpu(cpu, &cpuid_topo->cluster_sibling); cpumask_set_cpu(cpuid, &cpu_topo->cluster_sibling); } - cpumask_set_cpu(cpuid, &cpu_topo->core_sibling); - cpumask_set_cpu(cpu, &cpuid_topo->core_sibling); - if (cpuid_topo->core_id != cpu_topo->core_id) continue; -- 2.37.0