]> www.infradead.org Git - linux.git/commit
x86/resctrl: Prepare for new Sub-NUMA Cluster (SNC) monitor files
authorTony Luck <tony.luck@intel.com>
Fri, 28 Jun 2024 21:56:08 +0000 (14:56 -0700)
committerBorislav Petkov (AMD) <bp@alien8.de>
Tue, 2 Jul 2024 17:49:54 +0000 (19:49 +0200)
commit328ea688746420e12ced6cfbc5064413180244cc
tree73eb4027c1bac117843f70177b879966d971cf0d
parentac20aa423052553c005089b00f1e3caf79d3c1d3
x86/resctrl: Prepare for new Sub-NUMA Cluster (SNC) monitor files

When SNC is enabled, monitoring data is collected at the SNC node granularity,
but must be reported at L3-cache granularity for backwards compatibility in
addition to reporting at the node level.

Add a "ci" field to the rdt_mon_domain structure to save the cache information
about the enclosing L3 cache for the domain.  This provides:

1) The cache id which is needed to compose the name of the legacy monitoring
   directory, and to determine which domains should be summed to provide
   L3-scoped data.

2) The shared_cpu_map which is needed to determine which CPUs can be used to
   read the RMID counters with the MSR interface.

This is the first step to an eventual goal of monitor reporting files like this
(for a system with two SNC nodes per L3):

  $ cd /sys/fs/resctrl/mon_data
  $ tree mon_L3_00
  mon_L3_00 <- 00 here is L3 cache id
  ├── llc_occupancy \  These files provide legacy support
  ├── mbm_local_bytes  > for non-SNC aware monitor apps
  ├── mbm_total_bytes /  that expect data at L3 cache level
  ├── mon_sub_L3_00 <- 00 here is SNC node id
  │   ├── llc_occupancy \  These files are finer grained
  │   ├── mbm_local_bytes  > data from each SNC node
  │   └── mbm_total_bytes /
  └── mon_sub_L3_01
      ├── llc_occupancy \
      ├── mbm_local_bytes  > As above, but for node 1.
      └── mbm_total_bytes /

  [ bp: Massage commit message. ]

Signed-off-by: Tony Luck <tony.luck@intel.com>
Signed-off-by: Borislav Petkov (AMD) <bp@alien8.de>
Reviewed-by: Reinette Chatre <reinette.chatre@intel.com>
Tested-by: Babu Moger <babu.moger@amd.com>
Link: https://lore.kernel.org/r/20240628215619.76401-9-tony.luck@intel.com
arch/x86/kernel/cpu/resctrl/core.c
arch/x86/kernel/cpu/resctrl/pseudo_lock.c
arch/x86/kernel/cpu/resctrl/rdtgroup.c
include/linux/resctrl.h