All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH v7 00/13] Support PPTT for ARM64
@ 2018-02-28 22:06 ` Jeremy Linton
  0 siblings, 0 replies; 136+ messages in thread
From: Jeremy Linton @ 2018-02-28 22:06 UTC (permalink / raw)
  To: linux-acpi
  Cc: linux-arm-kernel, sudeep.holla, lorenzo.pieralisi, hanjun.guo,
	rjw, will.deacon, catalin.marinas, gregkh, mark.rutland,
	linux-kernel, linux-riscv, wangxiongfeng2, vkilari, ahs3,
	dietmar.eggemann, morten.rasmussen, palmer, lenb, john.garry,
	austinwc, tnowicki, Jeremy Linton

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 physical_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. To avoid inverted scheduler domains we then
set the MC domain equal to the largest cache within the socket
below the NUMA domain.

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_v7

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 |   9 +-
 arch/arm64/kernel/cacheinfo.c     |  15 +-
 arch/arm64/kernel/topology.c      | 132 +++++++-
 arch/riscv/kernel/cacheinfo.c     |   1 -
 drivers/acpi/Kconfig              |   3 +
 drivers/acpi/Makefile             |   1 +
 drivers/acpi/pptt.c               | 642 ++++++++++++++++++++++++++++++++++++++
 drivers/acpi/tables.c             |   2 +-
 drivers/base/cacheinfo.c          | 157 +++++-----
 include/linux/acpi.h              |   4 +
 include/linux/cacheinfo.h         |  17 +-
 13 files changed, 882 insertions(+), 106 deletions(-)
 create mode 100644 drivers/acpi/pptt.c

-- 
2.13.6

^ permalink raw reply	[flat|nested] 136+ messages in thread

end of thread, other threads:[~2018-03-20 13:25 UTC | newest]

Thread overview: 136+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2018-02-28 22:06 [PATCH v7 00/13] Support PPTT for ARM64 Jeremy Linton
2018-02-28 22:06 ` Jeremy Linton
2018-02-28 22:06 ` Jeremy Linton
2018-02-28 22:06 ` [PATCH v7 01/13] drivers: base: cacheinfo: move cache_setup_of_node() Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-03-06 16:16   ` Sudeep Holla
2018-03-06 16:16     ` Sudeep Holla
2018-03-06 16:16     ` Sudeep Holla
2018-02-28 22:06 ` [PATCH v7 02/13] drivers: base: cacheinfo: setup DT cache properties early Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-02-28 22:34   ` Palmer Dabbelt
2018-02-28 22:34     ` Palmer Dabbelt
2018-02-28 22:34     ` Palmer Dabbelt
2018-02-28 22:34     ` Palmer Dabbelt
2018-03-06 16:43   ` Sudeep Holla
2018-03-06 16:43     ` Sudeep Holla
2018-03-06 16:43     ` Sudeep Holla
2018-02-28 22:06 ` [PATCH v7 03/13] cacheinfo: rename of_node to fw_token Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-03-06 16:45   ` Sudeep Holla
2018-03-06 16:45     ` Sudeep Holla
2018-03-06 16:45     ` Sudeep Holla
2018-02-28 22:06 ` [PATCH v7 04/13] arm64/acpi: Create arch specific cpu to acpi id helper Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-03-06 17:13   ` Sudeep Holla
2018-03-06 17:13     ` Sudeep Holla
2018-03-06 17:13     ` Sudeep Holla
2018-02-28 22:06 ` [PATCH v7 05/13] ACPI/PPTT: Add Processor Properties Topology Table parsing Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-03-06 17:39   ` Sudeep Holla
2018-03-06 17:39     ` Sudeep Holla
2018-03-06 17:39     ` Sudeep Holla
2018-03-08 16:39   ` Ard Biesheuvel
2018-03-08 16:39     ` Ard Biesheuvel
2018-03-08 16:39     ` Ard Biesheuvel
2018-03-08 19:52     ` Jeremy Linton
2018-03-08 19:52       ` Jeremy Linton
2018-03-08 19:52       ` Jeremy Linton
2018-03-08 19:52       ` Jeremy Linton
2018-03-19 10:46   ` Rafael J. Wysocki
2018-03-19 10:46     ` Rafael J. Wysocki
2018-03-19 10:46     ` Rafael J. Wysocki
2018-03-20 13:25     ` Jeremy Linton
2018-03-20 13:25       ` Jeremy Linton
2018-03-20 13:25       ` Jeremy Linton
2018-02-28 22:06 ` [PATCH v7 06/13] ACPI: Enable PPTT support on ARM64 Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-03-06 16:55   ` Sudeep Holla
2018-03-06 16:55     ` Sudeep Holla
2018-03-06 16:55     ` Sudeep Holla
2018-02-28 22:06 ` [PATCH v7 07/13] drivers: base cacheinfo: Add support for ACPI based firmware tables Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-03-06 17:50   ` Sudeep Holla
2018-03-06 17:50     ` Sudeep Holla
2018-03-06 17:50     ` Sudeep Holla
2018-03-08 17:20   ` Lorenzo Pieralisi
2018-03-08 17:20     ` Lorenzo Pieralisi
2018-03-08 17:20     ` Lorenzo Pieralisi
2018-02-28 22:06 ` [PATCH v7 08/13] arm64: " Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-03-03 21:58   ` kbuild test robot
2018-03-03 21:58     ` kbuild test robot
2018-03-03 21:58     ` kbuild test robot
2018-03-03 21:58     ` kbuild test robot
2018-03-06 17:23   ` Sudeep Holla
2018-03-06 17:23     ` Sudeep Holla
2018-03-06 17:23     ` Sudeep Holla
2018-02-28 22:06 ` [PATCH v7 09/13] ACPI/PPTT: Add topology parsing code Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-02-28 22:06 ` [PATCH v7 10/13] arm64: topology: rename cluster_id Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-03-05 12:24   ` Mark Brown
2018-03-05 12:24     ` Mark Brown
2018-03-05 12:24     ` Mark Brown
2018-02-28 22:06 ` [PATCH v7 11/13] arm64: topology: enable ACPI/PPTT based CPU topology Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-02-28 22:06 ` [PATCH v7 12/13] ACPI: Add PPTT to injectable table list Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-02-28 22:06 ` [PATCH v7 13/13] arm64: topology: divorce MC scheduling domain from core_siblings Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-02-28 22:06   ` Jeremy Linton
2018-03-01 15:52   ` Morten Rasmussen
2018-03-01 15:52     ` Morten Rasmussen
2018-03-01 15:52     ` Morten Rasmussen
2018-02-27 20:18     ` Jeremy Linton
2018-02-27 20:18       ` Jeremy Linton
2018-02-27 20:18       ` Jeremy Linton
2018-03-06 16:07       ` Morten Rasmussen
2018-03-06 16:07         ` Morten Rasmussen
2018-03-06 16:07         ` Morten Rasmussen
2018-03-06 22:22         ` Jeremy Linton
2018-03-06 22:22           ` Jeremy Linton
2018-03-06 22:22           ` Jeremy Linton
2018-03-07 13:06           ` Morten Rasmussen
2018-03-07 13:06             ` Morten Rasmussen
2018-03-07 13:06             ` Morten Rasmussen
2018-03-07 16:19             ` Jeremy Linton
2018-03-07 16:19               ` Jeremy Linton
2018-03-07 16:19               ` Jeremy Linton
2018-03-14 13:05               ` Morten Rasmussen
2018-03-14 13:05                 ` Morten Rasmussen
2018-03-14 13:05                 ` Morten Rasmussen
2018-03-08 20:41             ` Brice Goglin
2018-03-08 20:41               ` Brice Goglin
2018-03-08 20:41               ` Brice Goglin
2018-03-14 12:43               ` Morten Rasmussen
2018-03-14 12:43                 ` Morten Rasmussen
2018-03-14 12:43                 ` Morten Rasmussen
2018-03-01 12:06 ` [PATCH v7 00/13] Support PPTT for ARM64 Sudeep Holla
2018-03-01 12:06   ` Sudeep Holla
2018-03-01 12:06   ` Sudeep Holla
2018-02-27 18:49   ` Jeremy Linton
2018-02-27 18:49     ` Jeremy Linton
2018-02-27 18:49     ` Jeremy Linton
2018-03-08 15:59     ` Ard Biesheuvel
2018-03-08 15:59       ` Ard Biesheuvel
2018-03-08 15:59       ` Ard Biesheuvel
2018-03-08 17:41       ` Jeremy Linton
2018-03-08 17:41         ` Jeremy Linton
2018-03-08 17:41         ` Jeremy Linton
2018-03-14  9:57 ` vkilari
2018-03-14  9:57   ` vkilari at codeaurora.org
2018-03-14  9:57   ` vkilari at codeaurora.org
2018-03-14  9:57   ` vkilari

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.