mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-27 23:35:03 +07:00
029e9f7366
IA32-Intel Devel guide Volume 3A - 14.3.2.1 ------------------------------------------- ... Opportunistic processor performance operation can be disabled by setting bit 38 of IA32_MISC_ENABLES. This mechanism is intended for BIOS only. If IA32_MISC_ENABLES[38] is set, CPUID.06H:EAX[1] will return 0. Better detect things via cpuid, this cleans up the code a bit and the MSR parts were not working correctly anyway. Signed-off-by: Thomas Renninger <trenn@suse.de> CC: lenb@kernel.org CC: linux@dominikbrodowski.net CC: cpufreq@vger.kernel.org Signed-off-by: Dominik Brodowski <linux@dominikbrodowski.net>
28 lines
635 B
C
28 lines
635 B
C
#if defined(__i386__) || defined(__x86_64__)
|
|
|
|
#include "helpers/helpers.h"
|
|
|
|
int cpufreq_has_boost_support(unsigned int cpu, int *support, int *active,
|
|
int *states)
|
|
{
|
|
struct cpupower_cpu_info cpu_info;
|
|
int ret;
|
|
|
|
*support = *active = *states = 0;
|
|
|
|
ret = get_cpu_info(0, &cpu_info);
|
|
if (ret)
|
|
return ret;
|
|
|
|
if (cpupower_cpu_info.caps & CPUPOWER_CAP_AMD_CBP) {
|
|
*support = 1;
|
|
amd_pci_get_num_boost_states(active, states);
|
|
if (ret <= 0)
|
|
return ret;
|
|
*support = 1;
|
|
} else if (cpupower_cpu_info.caps & CPUPOWER_CAP_INTEL_IDA)
|
|
*support = *active = 1;
|
|
return 0;
|
|
}
|
|
#endif /* #if defined(__i386__) || defined(__x86_64__) */
|