]> git.proxmox.com Git - mirror_ubuntu-jammy-kernel.git/commitdiff
cpupower: Add cpuid cap flag for MSR_AMD_HWCR support
authorNathan Fontenot <nathan.fontenot@amd.com>
Mon, 25 Jan 2021 17:36:23 +0000 (11:36 -0600)
committerShuah Khan <skhan@linuxfoundation.org>
Tue, 26 Jan 2021 16:40:45 +0000 (09:40 -0700)
Remove the family check for accessing the MSR_AMD_HWCR MSR and replace
it with a cpupower cap flag.

This update also allows for the removal of the local cpupower_cpu_info
variable in cpufreq_has_boost_support() since we no longer need it to
check the family.

Signed-off-by: Nathan Fontenot <nathan.fontenot@amd.com>
Reviewed-by: Robert Richter <rrichter@amd.com>
Signed-off-by: Shuah Khan <skhan@linuxfoundation.org>
tools/power/cpupower/utils/helpers/cpuid.c
tools/power/cpupower/utils/helpers/helpers.h
tools/power/cpupower/utils/helpers/misc.c

index db2e88ceb67b4f31f7d6fa05d8efa2eca934b01b..72eb4359318032f939e06db0ff5279a52573013d 100644 (file)
@@ -129,9 +129,13 @@ out:
        if (cpu_info->vendor == X86_VENDOR_AMD ||
            cpu_info->vendor == X86_VENDOR_HYGON) {
                if (ext_cpuid_level >= 0x80000007) {
-                       if (cpuid_edx(0x80000007) & (1 << 9))
+                       if (cpuid_edx(0x80000007) & (1 << 9)) {
                                cpu_info->caps |= CPUPOWER_CAP_AMD_CPB;
 
+                               if (cpu_info->family >= 0x17)
+                                       cpu_info->caps |= CPUPOWER_CAP_AMD_CPB_MSR;
+                       }
+
                        if ((cpuid_edx(0x80000007) & (1 << 7)) &&
                            cpu_info->family != 0x14) {
                                /* HW pstate was not implemented in family 0x14 */
index 8a0c11c6ec63b9ead624bd1cf82fbf884ebc1b85..33ffacee7fcb96b14cffc62c834c7f40e1d93514 100644 (file)
@@ -72,6 +72,7 @@ enum cpupower_cpu_vendor {X86_VENDOR_UNKNOWN = 0, X86_VENDOR_INTEL,
 #define CPUPOWER_CAP_AMD_RDPRU         0x00000080
 #define CPUPOWER_CAP_AMD_HW_PSTATE     0x00000100
 #define CPUPOWER_CAP_AMD_PSTATEDEF     0x00000200
+#define CPUPOWER_CAP_AMD_CPB_MSR       0x00000400
 
 #define CPUPOWER_AMD_CPBDIS            0x02000000
 
index f9bcce9c72d5ef3fcb0731a79281204cbcac0f55..fc6e345117216af5179f253bb77717cba223016f 100644 (file)
 int cpufreq_has_boost_support(unsigned int cpu, int *support, int *active,
                        int *states)
 {
-       struct cpupower_cpu_info cpu_info;
        int ret;
        unsigned long long val;
 
        *support = *active = *states = 0;
 
-       ret = get_cpu_info(&cpu_info);
-       if (ret)
-               return ret;
-
        if (cpupower_cpu_info.caps & CPUPOWER_CAP_AMD_CPB) {
                *support = 1;
 
@@ -34,7 +29,7 @@ int cpufreq_has_boost_support(unsigned int cpu, int *support, int *active,
                 * has Hardware determined variable increments instead.
                 */
 
-               if (cpu_info.family == 0x17 || cpu_info.family == 0x18) {
+               if (cpupower_cpu_info.caps & CPUPOWER_CAP_AMD_CPB_MSR) {
                        if (!read_msr(cpu, MSR_AMD_HWCR, &val)) {
                                if (!(val & CPUPOWER_AMD_CPBDIS))
                                        *active = 1;