From patchwork Wed Apr 25 23:31:08 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Jeremy Linton X-Patchwork-Id: 134384 Delivered-To: patch@linaro.org Received: by 10.46.151.6 with SMTP id r6csp1532444lji; Wed, 25 Apr 2018 17:26:09 -0700 (PDT) X-Google-Smtp-Source: AIpwx49rdyHNQq1uGgTFLYJYVTwmWZtWoVHFwBaCIn4KH/Y6Uxs+2nTbs8ekhoL04qQc2dIcQA9U X-Received: by 2002:a17:902:4301:: with SMTP id i1-v6mr23468294pld.280.1524702369686; Wed, 25 Apr 2018 17:26:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1524702369; cv=none; d=google.com; s=arc-20160816; b=NMzD4e4yNNnxSjEEQcjZjgx482Pf3T5qjtknClYAeqJygU1Kn+kkqug38qTXzpFg54 DCfSnD/vJPeZvBZ8VL6j/q3cmvsFDvE2mAQ7btdWIAPnGZXqyCjjxhI0ns4oMxkhUf/A NDyIdeeGTs/0IjDZIVRmE1qENNdYoygMgRIDrBTEyFZOmN0TFHdNzGYlv12xAli0v1US vaEQCO9CORxnW6NETl55CjSF5LVQINISd70hdctdfG55QcLLa/XLgWRVPShm6NjHXoG8 usyyYrD5aS8h+9vlsQfkm2Cn8JrS5TmetIApxAN5y9BZJjLVzX2CGJm2568Wg7Prw1dL VvDQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :arc-authentication-results; bh=0UcuD8e61Z+dv8ORxEktHGuKvSLCDddSFpXwbt8kC0g=; b=s/k//Zwf5/rd7wLZcxP2B/mJFjbTG8NxCEn7d/Q2GKg8+g3l68zXGT8Sa9ybsfdSLp m47jg/IgTA6TgLtGnvz4/6y1rnxBM2MNOp7Fz+kjQEHKkFVIMa/I39kaL0iRwyrPRAaT XVk1eQ/lmS/QVdMx/MYfuFPxuxmWeq09FlKMHWwxxFisJq14fV88B2P3hA9teybg+AKo k7zrd/GB/+Q8mRlAh72/t5YbEBqLl+sTnCz3MohD4VkhNBDzgS3nGmIVhUMCd7kCNwwF 7+k5rwCM3EYg1Yt4D2tle/Z+sMrz4PiHa4Z6+qFVIIKnlVKXyYUOps/1hu3JlUotnJ1w yVpA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-acpi-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-acpi-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 c7si1537380pgu.439.2018.04.25.17.26.09; Wed, 25 Apr 2018 17:26:09 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-acpi-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-acpi-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-acpi-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751271AbeDZA0I (ORCPT + 8 others); Wed, 25 Apr 2018 20:26:08 -0400 Received: from usa-sjc-mx-foss1.foss.arm.com ([217.140.101.70]:45548 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750949AbeDZA0H (ORCPT ); Wed, 25 Apr 2018 20:26:07 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 692E580D; Wed, 25 Apr 2018 17:26:06 -0700 (PDT) Received: from beelzebub.austin.arm.com (beelzebub.austin.arm.com [10.118.12.119]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id 4F9753F590; Wed, 25 Apr 2018 17:26:05 -0700 (PDT) From: Jeremy Linton To: linux-acpi@vger.kernel.org Cc: Sudeep.Holla@arm.com, linux-arm-kernel@lists.infradead.org, Lorenzo.Pieralisi@arm.com, hanjun.guo@linaro.org, rjw@rjwysocki.net, Will.Deacon@arm.com, Catalin.Marinas@arm.com, gregkh@linuxfoundation.org, Mark.Rutland@arm.com, linux-kernel@vger.kernel.org, linux-riscv@lists.infradead.org, wangxiongfeng2@huawei.com, vkilari@codeaurora.org, ahs3@redhat.com, Dietmar.Eggemann@arm.com, Morten.Rasmussen@arm.com, palmer@sifive.com, lenb@kernel.org, john.garry@huawei.com, austinwc@codeaurora.org, tnowicki@caviumnetworks.com, jhugo@qti.qualcomm.com, timur@qti.qualcomm.com, ard.biesheuvel@linaro.org, Jeremy Linton Subject: [PATCH v8 00/13] Support PPTT for ARM64 Date: Wed, 25 Apr 2018 18:31:08 -0500 Message-Id: <20180425233121.13270-1-jeremy.linton@arm.com> X-Mailer: git-send-email 2.13.6 Sender: linux-acpi-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-acpi@vger.kernel.org ACPI 6.2 adds the Processor Properties Topology Table (PPTT), which is used to describe the processor and cache topology. Ideally it is used to extend/override information provided by the hardware, but right now ARM64 is entirely dependent on firmware provided tables. This patch parses the table for the cache topology and CPU topology. When we enable ACPI/PPTT for arm64 we map the package_id to the PPTT node flagged as the physical package by the firmware. This results in topologies that match what the remainder of the system expects. Finally, we update the scheduler MC domain so that it generally reflects the LLC unless the LLC is too large for the NUMA domain (or package). For example on juno: [root@mammon-juno-rh topology]# lstopo-no-graphics Package L#0 L2 L#0 (1024KB) L1d L#0 (32KB) + L1i L#0 (32KB) + Core L#0 + PU L#0 (P#0) L1d L#1 (32KB) + L1i L#1 (32KB) + Core L#1 + PU L#1 (P#1) L1d L#2 (32KB) + L1i L#2 (32KB) + Core L#2 + PU L#2 (P#2) L1d L#3 (32KB) + L1i L#3 (32KB) + Core L#3 + PU L#3 (P#3) L2 L#1 (2048KB) L1d L#4 (32KB) + L1i L#4 (48KB) + Core L#4 + PU L#4 (P#4) L1d L#5 (32KB) + L1i L#5 (48KB) + Core L#5 + PU L#5 (P#5) HostBridge L#0 PCIBridge PCIBridge PCIBridge PCI 1095:3132 Block(Disk) L#0 "sda" PCIBridge PCI 1002:68f9 GPU L#1 "renderD128" GPU L#2 "card0" GPU L#3 "controlD64" PCIBridge PCI 11ab:4380 Net L#4 "enp8s0" Git tree at: http://linux-arm.org/git?p=linux-jlinton.git branch: pptt_v8 v7->v8: Modify the logic used to select the MC domain (the change shouldn't modify the sched domains on any existing machines compared to v7, only how they are built) Reduce the severity of some parsing messages. Fix s390 link problem. Further checks to deal with broken PPTT tables. Various style tweaks, SPDX license addition, etc. v6->v7: Add additional patch to use the last cache level within the NUMA or socket as the MC domain. This assures the MC domain is equal or smaller than the DIE. Various formatting/etc review comments. Rebase to 4.16rc2 v5->v6: Add additional patches which re-factor how the initial DT code sets up the cacheinfo structure so that its not as dependent on the of_node stored in that tree. Once that is done we rename it for use with the ACPI code. Additionally there were a fair number of minor name/location/etc tweaks scattered about made in response to review comments. v4->v5: Update the cache type from NOCACHE to UNIFIED when all the cache attributes we update are valid. This fixes a problem where caches which are entirely created by the PPTT don't show up in lstopo. Give the PPTT its own firmware_node in the cache structure instead of sharing it with the of_node. Move some pieces around between patches. (see previous cover letters for futher changes) Jeremy Linton (13): drivers: base: cacheinfo: move cache_setup_of_node() drivers: base: cacheinfo: setup DT cache properties early cacheinfo: rename of_node to fw_token arm64/acpi: Create arch specific cpu to acpi id helper ACPI/PPTT: Add Processor Properties Topology Table parsing ACPI: Enable PPTT support on ARM64 drivers: base cacheinfo: Add support for ACPI based firmware tables arm64: Add support for ACPI based firmware tables ACPI/PPTT: Add topology parsing code arm64: topology: rename cluster_id arm64: topology: enable ACPI/PPTT based CPU topology ACPI: Add PPTT to injectable table list arm64: topology: divorce MC scheduling domain from core_siblings arch/arm64/Kconfig | 1 + arch/arm64/include/asm/acpi.h | 4 + arch/arm64/include/asm/topology.h | 6 +- arch/arm64/kernel/cacheinfo.c | 15 +- arch/arm64/kernel/topology.c | 103 +++++- arch/riscv/kernel/cacheinfo.c | 1 - drivers/acpi/Kconfig | 3 + drivers/acpi/Makefile | 1 + drivers/acpi/pptt.c | 678 ++++++++++++++++++++++++++++++++++++++ drivers/acpi/tables.c | 2 +- drivers/base/cacheinfo.c | 157 ++++----- include/linux/acpi.h | 4 + include/linux/cacheinfo.h | 18 +- 13 files changed, 886 insertions(+), 107 deletions(-) create mode 100644 drivers/acpi/pptt.c -- 2.13.6 -- To unsubscribe from this list: send the line "unsubscribe linux-acpi" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Acked-by: Ard Biesheuvel Tested-by: Ard Biesheuvel # SynQuacer Acked-by: Sudeep Holla Acked-by: Sudeep Holla Acked-by: Sudeep Holla Acked-by: Morten Rasmussen Tested-by: Vijaya Kumar K Tested-by: Xiongfeng Wang