]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
perf/x86/intel/uncore: Skip discovery table for offline dies
authorZide Chen <zide.chen@intel.com>
Fri, 13 Mar 2026 17:40:48 +0000 (10:40 -0700)
committerPeter Zijlstra <peterz@infradead.org>
Tue, 7 Apr 2026 07:05:29 +0000 (09:05 +0200)
This warning can be triggered if NUMA is disabled and the system
boots with fewer CPUs than the number of CPUs in die 0.

WARNING: CPU: 9 PID: 7257 at uncore.c:1157 uncore_pci_pmu_register+0x136/0x160 [intel_uncore]

Currently, the discovery table continues to be parsed even if all CPUs
in the associated die are offline.  This can lead to an array overflow
at "pmu->boxes[die] = box" in uncore_pci_pmu_register(), which may
trigger the warning above or cause other issues.

Fixes: edae1f06c2cd ("perf/x86/intel/uncore: Parse uncore discovery tables")
Reported-by: Steve Wahl <steve.wahl@hpe.com>
Signed-off-by: Zide Chen <zide.chen@intel.com>
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Reviewed-by: Dapeng Mi <dapeng1.mi@linux.intel.com>
Tested-by: Steve Wahl <steve.wahl@hpe.com>
Link: https://patch.msgid.link/20260313174050.171704-3-zide.chen@intel.com
arch/x86/events/intel/uncore_discovery.c

index 427939be2fb400639bb3281e97848f65ffed6054..583cbd06b9b8817c8a013b249d5cc460390a8914 100644 (file)
@@ -371,7 +371,7 @@ static bool uncore_discovery_pci(struct uncore_discovery_domain *domain)
                                     (val & UNCORE_DISCOVERY_DVSEC2_BIR_MASK) * UNCORE_DISCOVERY_BIR_STEP;
 
                        die = get_device_die_id(dev);
-                       if (die < 0)
+                       if ((die < 0) || (die >= uncore_max_dies()))
                                continue;
 
                        parse_discovery_table(domain, dev, die, bar_offset, &parsed);