Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp4119313iog; Tue, 21 Jun 2022 12:25:41 -0700 (PDT) X-Google-Smtp-Source: AGRyM1sR6PnpgnqWNp7fDdrlrFfAO2skcf01z+rJ+UcQz1O2IUD8uF802jupwx/CKAuEfm//+L6Q X-Received: by 2002:a17:907:3f11:b0:711:d56d:ab57 with SMTP id hq17-20020a1709073f1100b00711d56dab57mr27324407ejc.160.1655839541411; Tue, 21 Jun 2022 12:25:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655839541; cv=none; d=google.com; s=arc-20160816; b=O8xvkevmfEUgaAG3DPNT8DhunVzonSrfPxp4PFQVGd3ClAzZvCG17bfLnEKa8DAHMt jKVawh7Sz/wXvZu1yQ3TtASK/B1vTp1b1uQ0gMdUblrMkd+nrALyvakaYk7ZqAbcNo9a Cg7p22ISH7Z+dJtmVV3lQUUoH8PabYMr5Rj817GhS5kajv5W2FQ29BsctDI64TUTPtCW 5/Fhva/SAUbf6FGb4CgBJwSOh1qwciNQhboDgaujgUQVqW7YPBaltRdoNYtNj4UGU1HB UzsPPuLsWchF8wVjcqe1mZHUQ3zrrDr87fCfGXT/vgKVKon/z9B+pWiSgHY5G8cDSBag fOvQ== 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=zTG/hyaONP/+xjCSbwEq8efpKAXZAM4rOKz7jrYUHIg=; b=MXJG49/aY9mNF1Ef7GZ5IQLuVAeCUHRyed3qmJGIq7P1oATtlEqU+8P2DrrEDBQr1b Lrj2GplmTyFdsdBKxm73zF5hCBoVIWZ7kkSSVj3vqRWIQbhRDjKvFR2UL26AOe8tsyZM 0MjMO3JcNg1Tw34zEKuzewOhAnkByUE32wneG7LNXt0GpF8IaJGZCNmJHOWne4kPbfjn RgY7VpypqgbVDTujSRLsbMKw+KLZqRZvzD3akClBNmTBAwk8mR0On+PyJUhiYKV8tnhO O6Hy0WoubaBh7eisE10BuNcdtIfU8iLcoF5ZdRGSHSaHA5f7X5VbIv/63Y/toESvQ7Pi qoNQ== 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 q15-20020a056402518f00b004351fb72288si20161694edd.594.2022.06.21.12.25.14; Tue, 21 Jun 2022 12:25:41 -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 S1353450AbiFUTXe (ORCPT + 99 others); Tue, 21 Jun 2022 15:23:34 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40568 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1353493AbiFUTV3 (ORCPT ); Tue, 21 Jun 2022 15:21:29 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id DFC5F2A95B for ; Tue, 21 Jun 2022 12:21:25 -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 CDB4D165C; Tue, 21 Jun 2022 12:21:25 -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 E022D3F792; Tue, 21 Jun 2022 12:21:23 -0700 (PDT) From: Sudeep Holla To: linux-kernel@vger.kernel.org, Greg KH Cc: Sudeep Holla , Atish Patra , Atish Patra , 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 Subject: [PATCH v4 19/20] arch_topology: Add support for parsing sockets in /cpu-map Date: Tue, 21 Jun 2022 20:20:33 +0100 Message-Id: <20220621192034.3332546-20-sudeep.holla@arm.com> X-Mailer: git-send-email 2.36.1 In-Reply-To: <20220621192034.3332546-1-sudeep.holla@arm.com> References: <20220621192034.3332546-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 Finally let us add support for socket nodes in /cpu-map in the device tree. Since this may not be present in all the old platforms and even most of the existing platforms, we need to assume absence of the socket node indicates that it is a single socket system and handle appropriately. Also it is likely that most single socket systems skip to as the node since it is optional. Signed-off-by: Sudeep Holla --- drivers/base/arch_topology.c | 37 +++++++++++++++++++++++++++++++----- 1 file changed, 32 insertions(+), 5 deletions(-) diff --git a/drivers/base/arch_topology.c b/drivers/base/arch_topology.c index 75604f783bfc..ed1cb64a95aa 100644 --- a/drivers/base/arch_topology.c +++ b/drivers/base/arch_topology.c @@ -545,8 +545,8 @@ static int __init parse_core(struct device_node *core, int package_id, return 0; } -static int __init -parse_cluster(struct device_node *cluster, int cluster_id, int depth) +static int __init parse_cluster(struct device_node *cluster, int package_id, + int cluster_id, int depth) { char name[20]; bool leaf = true; @@ -566,7 +566,7 @@ parse_cluster(struct device_node *cluster, int cluster_id, int depth) c = of_get_child_by_name(cluster, name); if (c) { leaf = false; - ret = parse_cluster(c, i, depth + 1); + ret = parse_cluster(c, package_id, i, depth + 1); of_node_put(c); if (ret != 0) return ret; @@ -590,7 +590,8 @@ parse_cluster(struct device_node *cluster, int cluster_id, int depth) } if (leaf) { - ret = parse_core(c, 0, cluster_id, core_id++); + ret = parse_core(c, package_id, cluster_id, + core_id++); } else { pr_err("%pOF: Non-leaf cluster with core %s\n", cluster, name); @@ -610,6 +611,32 @@ parse_cluster(struct device_node *cluster, int cluster_id, int depth) return 0; } +static int __init parse_socket(struct device_node *socket) +{ + char name[20]; + struct device_node *c; + bool has_socket = false; + int package_id = 0, ret; + + do { + snprintf(name, sizeof(name), "socket%d", package_id); + c = of_get_child_by_name(socket, name); + if (c) { + has_socket = true; + ret = parse_cluster(c, package_id, -1, 0); + of_node_put(c); + if (ret != 0) + return ret; + } + package_id++; + } while (c); + + if (!has_socket) + ret = parse_cluster(socket, 0, -1, 0); + + return ret; +} + static int __init parse_dt_topology(void) { struct device_node *cn, *map; @@ -629,7 +656,7 @@ static int __init parse_dt_topology(void) if (!map) goto out; - ret = parse_cluster(map, -1, 0); + ret = parse_socket(map); if (ret != 0) goto out_map; -- 2.36.1