Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

platform/x86/intel: power-domains: Add interface to get Linux die ID

The die ID in the Linux topology sysfs is a logical identifier that
differs from the one presented in CPUID leaf 0x1F or via MSR 0x54.

Introduce an interface that returns the Linux CPU die ID based on a
given package ID and power domain ID. This mapping is stored during the
CPU online callback in an array.

Signed-off-by: Srinivas Pandruvada <srinivas.pandruvada@linux.intel.com>
Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
Link: https://lore.kernel.org/r/20250508230250.1186619-4-srinivas.pandruvada@linux.intel.com
Signed-off-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>

authored by

Srinivas Pandruvada and committed by
Ilpo Järvinen
e37be5d8 bfbe7729

+31 -4
+30 -4
drivers/platform/x86/intel/tpmi_power_domains.c
··· 74 74 75 75 static cpumask_t *tpmi_power_domain_mask; 76 76 77 + static u16 *domain_die_map; 78 + 77 79 /* Lock to protect tpmi_power_domain_mask and tpmi_cpu_hash */ 78 80 static DEFINE_MUTEX(tpmi_lock); 79 81 ··· 154 152 } 155 153 EXPORT_SYMBOL_NS_GPL(tpmi_get_power_domain_mask, "INTEL_TPMI_POWER_DOMAIN"); 156 154 155 + int tpmi_get_linux_die_id(int pkg_id, int domain_id) 156 + { 157 + if (pkg_id >= topology_max_packages() || domain_id >= MAX_POWER_DOMAINS) 158 + return -EINVAL; 159 + 160 + return domain_die_map[pkg_id * MAX_POWER_DOMAINS + domain_id]; 161 + } 162 + EXPORT_SYMBOL_NS_GPL(tpmi_get_linux_die_id, "INTEL_TPMI_POWER_DOMAIN"); 163 + 157 164 static int tpmi_get_logical_id(unsigned int cpu, struct tpmi_cpu_info *info) 158 165 { 159 166 u64 data; ··· 200 189 cpumask_set_cpu(cpu, &tpmi_power_domain_mask[index]); 201 190 hash_add(tpmi_cpu_hash, &info->hnode, info->punit_core_id); 202 191 192 + domain_die_map[info->pkg_id * MAX_POWER_DOMAINS + info->punit_domain_id] = 193 + topology_die_id(cpu); 194 + 203 195 return 0; 204 196 } 205 197 ··· 226 212 if (!tpmi_power_domain_mask) 227 213 return -ENOMEM; 228 214 215 + domain_die_map = kcalloc(size_mul(topology_max_packages(), MAX_POWER_DOMAINS), 216 + sizeof(*domain_die_map), GFP_KERNEL); 217 + if (!domain_die_map) 218 + goto free_domain_mask; 219 + 229 220 ret = cpuhp_setup_state(CPUHP_AP_ONLINE_DYN, 230 221 "platform/x86/tpmi_power_domains:online", 231 222 tpmi_cpu_online, NULL); 232 - if (ret < 0) { 233 - kfree(tpmi_power_domain_mask); 234 - return ret; 235 - } 223 + if (ret < 0) 224 + goto free_domain_map; 236 225 237 226 tpmi_hp_state = ret; 238 227 239 228 return 0; 229 + 230 + free_domain_map: 231 + kfree(domain_die_map); 232 + 233 + free_domain_mask: 234 + kfree(tpmi_power_domain_mask); 235 + 236 + return ret; 240 237 } 241 238 module_init(tpmi_init) 242 239 ··· 255 230 { 256 231 cpuhp_remove_state(tpmi_hp_state); 257 232 kfree(tpmi_power_domain_mask); 233 + kfree(domain_die_map); 258 234 } 259 235 module_exit(tpmi_exit) 260 236
+1
drivers/platform/x86/intel/tpmi_power_domains.h
··· 14 14 int tpmi_get_punit_core_number(int cpu_no); 15 15 int tpmi_get_power_domain_id(int cpu_no); 16 16 cpumask_t *tpmi_get_power_domain_mask(int cpu_no); 17 + int tpmi_get_linux_die_id(int pkg_id, int domain_id); 17 18 18 19 #endif