Received: by 2002:a05:6602:18e:0:0:0:0 with SMTP id m14csp5856115ioo; Wed, 1 Jun 2022 14:13:25 -0700 (PDT) X-Google-Smtp-Source: ABdhPJydKZ38e0/N+IQvUPPnpRQtqkkhPeX9p9y+BaUIY/tuY5fsk9Wd47EHSAP/WxStGRqjIxzO X-Received: by 2002:a17:902:cf06:b0:163:62cb:250e with SMTP id i6-20020a170902cf0600b0016362cb250emr1317660plg.171.1654118005225; Wed, 01 Jun 2022 14:13:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1654118005; cv=none; d=google.com; s=arc-20160816; b=tY5e3YtU0u2hZc8OzI+vhdDu+hlFyFpDE0DjhHpVkrBI7LbVeJMkTfRsAoA/fQI3uC oGhMyJITFwl/W6+ES+MWN7EV5oUjXMJxnfSQnp5TO8y4ga+pxk4mJIMH1cXrS2SYpyx6 WbfOUsQ49F39CXNaON1woZBpf7eImWgW+zzrS8bTRVT3+2ltGx8Q2Nyn2pP+cgKMkDL3 3QNp3xkME1ShUPllwlcCwiNuZc2x6vqyzP1XgU/cnsuNNHMYPnIS1QJJn9PqI7sG2z3b gvewnh/9Npu3zTRVQ/usbPVbX57rN1umgOU1eybAg1C5AoG6jLvRJUxu6ESZbeHymZIb 8o4w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date; bh=yAEXKdeoifq0LrYPx5wvfNEod6O7xky1nCHigqIAfgY=; b=UfbnzxeksgfWST6bhdTDVsXxTwvp5bVyqICqS0/ZSH8tWvuQlghiZfofGRPliy1dZg VEZnSGxwJOd6aBNHcfUDfwZ4yb0vyww+KSjpB8TFHTCt0XVvLLu/Cwajk/4310nOEAvZ lPzZrgFuz6T54QRcPjv10LPNbW+J/fMZsu4hlXbBZhRL/zrKcehArd3AJBp1Kr8H0hG6 LPStz35Fc2Cqj6yeAF79BpJ/+FVZVo2+wOct4cBIQLc4hlPAsKvsTg8OjhKATSwyqIxS El9/kHliphYQJas2t/zLj2zgkvEbTNajJqOqvh9+zXeLJP5XPigpnVFya9D/VUHyBMCH opXw== 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:18 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 lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id s17-20020a632c11000000b003fcda70f168si53338pgs.785.2022.06.01.14.13.24 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 01 Jun 2022 14:13:25 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 27CD42D56D4; Wed, 1 Jun 2022 13:04:57 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1351797AbiFAMEs (ORCPT + 99 others); Wed, 1 Jun 2022 08:04:48 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53882 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230377AbiFAMEq (ORCPT ); Wed, 1 Jun 2022 08:04:46 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 859894C781 for ; Wed, 1 Jun 2022 05:04:44 -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 261B7ED1; Wed, 1 Jun 2022 05:04:44 -0700 (PDT) Received: from bogus (unknown [10.57.9.14]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 9707D3F73D; Wed, 1 Jun 2022 05:04:41 -0700 (PDT) Date: Wed, 1 Jun 2022 13:03:53 +0100 From: Sudeep Holla To: Gavin Shan Cc: linux-kernel@vger.kernel.org, Atish Patra , Atish Patra , Vincent Guittot , Sudeep Holla , Morten Rasmussen , Dietmar Eggemann , Qing Wang , linux-arm-kernel@lists.infradead.org, linux-riscv@lists.infradead.org, Rob Herring Subject: Re: [PATCH v3 00/16] arch_topology: Updates to add socket support and fix cluster ids Message-ID: <20220601120353.mz3t3sse2ja6engx@bogus> References: <20220525081416.3306043-1-sudeep.holla@arm.com> <5258e7c2-7829-af20-6416-1a40a09d1917@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <5258e7c2-7829-af20-6416-1a40a09d1917@redhat.com> X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,RDNS_NONE, SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no 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 On Wed, Jun 01, 2022 at 11:49:07AM +0800, Gavin Shan wrote: > Hi Sudeep, > > On 5/25/22 4:14 PM, Sudeep Holla wrote: > > This version updates cacheinfo to populate and use the information from > > there for all the cache topology. Sorry for posting in the middle of > > merge window but better to get this tested earlier so that it is ready > > for next merge window. > > > > This series intends to fix some discrepancies we have in the CPU topology > > parsing from the device tree /cpu-map node. Also this diverges from the > > behaviour on a ACPI enabled platform. The expectation is that both DT > > and ACPI enabled systems must present consistent view of the CPU topology. > > > > Currently we assign generated cluster count as the physical package identifier > > for each CPU which is wrong. The device tree bindings for CPU topology supports > > sockets to infer the socket or physical package identifier for a given CPU. > > Also we don't check if all the cores/threads belong to the same cluster before > > updating their sibling masks which is fine as we don't set the cluster id yet. > > > > These changes also assigns the cluster identifier as parsed from the device tree > > cluster nodes within /cpu-map without support for nesting of the clusters. > > Finally, it also add support for socket nodes in /cpu-map. With this the > > parsing of exact same information from ACPI PPTT and /cpu-map DT node > > aligns well. > > > > The only exception is that the last level cache id information can be > > inferred from the same ACPI PPTT while we need to parse CPU cache nodes > > in the device tree. > > > > P.S: I have not cc-ed Greg and Rafael so that all the users of arch_topology > > agree with the changes first before we include them. > > > > v2[2]->v3: > > - Dropped support to get the device node for the CPU's LLC > > - Updated cacheinfo to support calling of detect_cache_attributes > > early in smp_prepare_cpus stage > > - Added support to check if LLC is valid and shared in the cacheinfo > > - Used the same in arch_topology > > > > v1[1]->v2[2]: > > - Updated ID validity check include all non-negative value > > - Added support to get the device node for the CPU's last level cache > > - Added support to build llc_sibling on DT platforms > > > > [1] https://lore.kernel.org/lkml/20220513095559.1034633-1-sudeep.holla@arm.com > > [2] https://lore.kernel.org/lkml/20220518093325.2070336-1-sudeep.holla@arm.com > > > > Sudeep Holla (16): > > cacheinfo: Use of_cpu_device_node_get instead cpu_dev->of_node > > cacheinfo: Add helper to access any cache index for a given CPU > > cacheinfo: Move cache_leaves_are_shared out of CONFIG_OF > > cacheinfo: Add support to check if last level cache(LLC) is valid or shared > > cacheinfo: Allow early detection and population of cache attributes > > arch_topology: Add support to parse and detect cache attributes > > arch_topology: Use the last level cache information from the cacheinfo > > arm64: topology: Remove redundant setting of llc_id in CPU topology > > arch_topology: Drop LLC identifier stash from the CPU topology > > arch_topology: Set thread sibling cpumask only within the cluster > > arch_topology: Check for non-negative value rather than -1 for IDs validity > > arch_topology: Avoid parsing through all the CPUs once a outlier CPU is found > > arch_topology: Don't set cluster identifier as physical package identifier > > arch_topology: Drop unnecessary check for uninitialised package_id > > arch_topology: Set cluster identifier in each core/thread from /cpu-map > > arch_topology: Add support for parsing sockets in /cpu-map > > > > arch/arm64/kernel/topology.c | 14 ----- > > drivers/base/arch_topology.c | 92 +++++++++++++++++---------- > > drivers/base/cacheinfo.c | 114 +++++++++++++++++++++------------- > > include/linux/arch_topology.h | 1 - > > include/linux/cacheinfo.h | 3 + > > 5 files changed, 135 insertions(+), 89 deletions(-) > > > > I tried this series on virtual machine where ACPI is enabled and looks good. > Especially for PATCH[10], resolving the issue I have. So I provided my tested-by > tag for it. Besides, I checked the changes related to ACPI part and looks to > me either after the mentioned nits fixed. I leave the changes related to device-tree > to be reviewed by the experts :) > Thanks for the review and testing, much appreciated! Yes the changes for ACPI is very minimal in this series, except the bug fix you are interested, nothing changes in the system behaviour. The main aim is to get the same behaviour on a similar DT based system. -- Regards, Sudeep