def test_hardware_pstates(ratio_to_control_value): IA32_PERF_CTL = 0x199 with bits.mwait.use_hint(), bits.preserve_msr(IA32_PERF_CTL): MSR_PLATFORM_INFO = 0xce min_ratio = testmsr.MSR("maximum efficiency ratio", bits.bsp_apicid(), MSR_PLATFORM_INFO, highbit=47, lowbit=40)[0] max_ratio = testmsr.MSR("max non-turbo ratio", bits.bsp_apicid(), MSR_PLATFORM_INFO, highbit=15, lowbit=8)[0] # Get the Turbo Mode Availability flag turbo_mode_available = bits.cpuid(bits.bsp_apicid(), 0).eax >= 6 and ( bits.cpuid(bits.bsp_apicid(), 6).eax & 0x2) last_ratio = max_ratio if turbo_mode_available: last_ratio += 1 bclk = testutil.adjust_to_nearest(bits.bclk(), 100.0 / 12) * 1000000 for ratio in range(min_ratio, last_ratio + 1): control_value = ratio_to_control_value(ratio, min_ratio, max_ratio) for apicid in bits.cpus(): bits.wrmsr(apicid, IA32_PERF_CTL, control_value) turbo = (ratio == max_ratio + 1) if turbo: # Needs to busywait, not sleep start = time.time() while (time.time() - start < 2): pass expected = int(ratio * bclk / 1000000) for duration in (0.1, 1.0): aperf = bits.cpu_frequency(duration)[1] aperf = testutil.adjust_to_nearest(aperf, bclk / 2) aperf = int(aperf / 1000000) if turbo: if aperf >= expected: break else: if aperf == expected: break if turbo: testsuite.test( "Turbo measured frequency {} >= expected {} MHz".format( aperf, expected), aperf >= expected) else: testsuite.test( "Ratio {} measured frequency {} MHz == expected {} MHz". format(ratio, aperf, expected), aperf == expected)
def test_hardware_pstates(ratio_to_control_value): IA32_PERF_CTL = 0x199 with bits.mwait.use_hint(), bits.preserve_msr(IA32_PERF_CTL): MSR_PLATFORM_INFO = 0xce min_ratio = testmsr.MSR("maximum efficiency ratio", bits.bsp_apicid(), MSR_PLATFORM_INFO, highbit=47, lowbit=40)[0] max_ratio = testmsr.MSR("max non-turbo ratio", bits.bsp_apicid(), MSR_PLATFORM_INFO, highbit=15, lowbit=8)[0] # Get the Turbo Mode Availability flag turbo_mode_available = bits.cpuid(bits.bsp_apicid(),0).eax >= 6 and (bits.cpuid(bits.bsp_apicid(),6).eax & 0x2) last_ratio = max_ratio if turbo_mode_available: last_ratio += 1 bclk = testutil.adjust_to_nearest(bits.bclk(), 100.0/12) * 1000000 for ratio in range(min_ratio, last_ratio + 1): control_value = ratio_to_control_value(ratio, min_ratio, max_ratio) for apicid in bits.cpus(): bits.wrmsr(apicid, IA32_PERF_CTL, control_value) turbo = (ratio == max_ratio + 1) if turbo: # Needs to busywait, not sleep start = time.time() while (time.time() - start < 2): pass expected = int(ratio * bclk / 1000000) for duration in (0.1, 1.0): aperf = bits.cpu_frequency(duration)[1] aperf = testutil.adjust_to_nearest(aperf, bclk/2) aperf = int(aperf / 1000000) if turbo: if aperf >= expected: break else: if aperf == expected: break if turbo: testsuite.test("Turbo measured frequency {} >= expected {} MHz".format(aperf, expected), aperf >= expected) else: testsuite.test("Ratio {} measured frequency {} MHz == expected {} MHz".format(ratio, aperf, expected), aperf == expected)
def test_pstates(): """Execute and verify frequency for each Pstate in the _PSS""" IA32_PERF_CTL = 0x199 with bits.mwait.use_hint(), bits.preserve_msr(IA32_PERF_CTL): cpupath_procid = acpi.find_procid() cpupath_uid = acpi.find_uid() apic = acpi.parse_apic() procid_apicid = apic.procid_apicid uid_x2apicid = apic.uid_x2apicid def cpupath_apicid(cpupath): if procid_apicid is not None: procid = cpupath_procid.get(cpupath, None) if procid is not None: apicid = procid_apicid.get(procid, None) if apicid is not None: return apicid if uid_x2apicid is not None: uid = cpupath_uid.get(cpupath, None) if uid is not None: apicid = uid_x2apicid.get(uid, None) if apicid is not None: return apicid return bits.cpus()[0] bclk = testutil.adjust_to_nearest(bits.bclk(), 100.0/12) * 1000000 uniques = acpi.parse_cpu_method("_PSS") for pss, cpupaths in uniques.iteritems(): if not testsuite.test("_PSS must exist", pss is not None): testsuite.print_detail(acpi.factor_commonprefix(cpupaths)) testsuite.print_detail('No _PSS exists') continue for n, pstate in enumerate(pss.pstates): for cpupath in cpupaths: apicid = cpupath_apicid(cpupath) if apicid is None: print 'Failed to find apicid for cpupath {}'.format(cpupath) continue bits.wrmsr(apicid, IA32_PERF_CTL, pstate.control) # Detecting Turbo frequency requires at least 2 pstates # since turbo frequency = max non-turbo frequency + 1 turbo = False if len(pss.pstates) >= 2: turbo = (n == 0 and pstate.core_frequency == (pss.pstates[1].core_frequency + 1)) if turbo: # Needs to busywait, not sleep start = time.time() while (time.time() - start < 2): pass for duration in (0.1, 1.0): frequency_data = bits.cpu_frequency(duration) # Abort the test if no cpu frequency is not available if frequency_data is None: continue aperf = frequency_data[1] aperf = testutil.adjust_to_nearest(aperf, bclk/2) aperf = int(aperf / 1000000) if turbo: if aperf >= pstate.core_frequency: break else: if aperf == pstate.core_frequency: break if turbo: testsuite.test("P{}: Turbo measured frequency {} >= expected {} MHz".format(n, aperf, pstate.core_frequency), aperf >= pstate.core_frequency) else: testsuite.test("P{}: measured frequency {} MHz == expected {} MHz".format(n, aperf, pstate.core_frequency), aperf == pstate.core_frequency)