Commit d05b5e0b authored by Sumeet Pawnikar's avatar Sumeet Pawnikar Committed by Rafael J. Wysocki

powercap: RAPL: fix invalid initialization for pl4_supported field

The current initialization of the struct x86_cpu_id via
pl4_support_ids[] is partial and wrong. It is initializing
"stepping" field with "X86_FEATURE_ANY" instead of "feature" field.

Use X86_MATCH_INTEL_FAM6_MODEL macro instead of initializing
each field of the struct x86_cpu_id for pl4_supported list of CPUs.
This X86_MATCH_INTEL_FAM6_MODEL macro internally uses another macro
X86_MATCH_VENDOR_FAM_MODEL_FEATURE for X86 based CPU matching with
appropriate initialized values.
Reported-by: default avatarDave Hansen <dave.hansen@intel.com>
Link: https://lore.kernel.org/lkml/28ead36b-2d9e-1a36-6f4e-04684e420260@intel.com
Fixes: eb52bc2a ("powercap: RAPL: Add Power Limit4 support for Meteor Lake SoC")
Fixes: b08b95cf ("powercap: RAPL: Add Power Limit4 support for Alder Lake-N and Raptor Lake-P")
Fixes: 51575590 ("powercap: RAPL: Add Power Limit4 support for RaptorLake")
Fixes: 1cc5b9a4 ("powercap: Add Power Limit4 support for Alder Lake SoC")
Fixes: 8365a898 ("powercap: Add Power Limit4 support")
Signed-off-by: default avatarSumeet Pawnikar <sumeet.r.pawnikar@intel.com>
Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
parent 9eef7f9d
...@@ -139,14 +139,14 @@ static int rapl_msr_write_raw(int cpu, struct reg_action *ra) ...@@ -139,14 +139,14 @@ static int rapl_msr_write_raw(int cpu, struct reg_action *ra)
/* List of verified CPUs. */ /* List of verified CPUs. */
static const struct x86_cpu_id pl4_support_ids[] = { static const struct x86_cpu_id pl4_support_ids[] = {
{ X86_VENDOR_INTEL, 6, INTEL_FAM6_TIGERLAKE_L, X86_FEATURE_ANY }, X86_MATCH_INTEL_FAM6_MODEL(TIGERLAKE_L, NULL),
{ X86_VENDOR_INTEL, 6, INTEL_FAM6_ALDERLAKE, X86_FEATURE_ANY }, X86_MATCH_INTEL_FAM6_MODEL(ALDERLAKE, NULL),
{ X86_VENDOR_INTEL, 6, INTEL_FAM6_ALDERLAKE_L, X86_FEATURE_ANY }, X86_MATCH_INTEL_FAM6_MODEL(ALDERLAKE_L, NULL),
{ X86_VENDOR_INTEL, 6, INTEL_FAM6_ALDERLAKE_N, X86_FEATURE_ANY }, X86_MATCH_INTEL_FAM6_MODEL(ALDERLAKE_N, NULL),
{ X86_VENDOR_INTEL, 6, INTEL_FAM6_RAPTORLAKE, X86_FEATURE_ANY }, X86_MATCH_INTEL_FAM6_MODEL(RAPTORLAKE, NULL),
{ X86_VENDOR_INTEL, 6, INTEL_FAM6_RAPTORLAKE_P, X86_FEATURE_ANY }, X86_MATCH_INTEL_FAM6_MODEL(RAPTORLAKE_P, NULL),
{ X86_VENDOR_INTEL, 6, INTEL_FAM6_METEORLAKE, X86_FEATURE_ANY }, X86_MATCH_INTEL_FAM6_MODEL(METEORLAKE, NULL),
{ X86_VENDOR_INTEL, 6, INTEL_FAM6_METEORLAKE_L, X86_FEATURE_ANY }, X86_MATCH_INTEL_FAM6_MODEL(METEORLAKE_L, NULL),
{} {}
}; };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment