mirror of
https://git.FreeBSD.org/src.git
synced 2024-12-14 10:09:48 +00:00
cpufreq(4) hwpstate: Yield CPU awaiting frequency change
It doesn't seem necessary to busy the CPU while waiting to transition into a different p-state. PR: 221621 (related, but does not completely address) Reviewed by: truckman Sponsored by: Dell EMC Isilon Differential Revision: https://reviews.freebsd.org/D12260
This commit is contained in:
parent
f9fc9faa3a
commit
2e81566368
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=323286
@ -160,6 +160,7 @@ DRIVER_MODULE(hwpstate, cpu, hwpstate_driver, hwpstate_devclass, 0, 0);
|
||||
static int
|
||||
hwpstate_goto_pstate(device_t dev, int pstate)
|
||||
{
|
||||
sbintime_t sbt;
|
||||
int i;
|
||||
uint64_t msr;
|
||||
int j;
|
||||
@ -170,7 +171,7 @@ hwpstate_goto_pstate(device_t dev, int pstate)
|
||||
/* get the current pstate limit */
|
||||
msr = rdmsr(MSR_AMD_10H_11H_LIMIT);
|
||||
limit = AMD_10H_11H_GET_PSTATE_LIMIT(msr);
|
||||
if(limit > id)
|
||||
if (limit > id)
|
||||
id = limit;
|
||||
|
||||
/*
|
||||
@ -184,7 +185,7 @@ hwpstate_goto_pstate(device_t dev, int pstate)
|
||||
sched_bind(curthread, i);
|
||||
thread_unlock(curthread);
|
||||
HWPSTATE_DEBUG(dev, "setting P%d-state on cpu%d\n",
|
||||
id, PCPU_GET(cpuid));
|
||||
id, PCPU_GET(cpuid));
|
||||
/* Go To Px-state */
|
||||
wrmsr(MSR_AMD_10H_11H_CONTROL, id);
|
||||
}
|
||||
@ -194,13 +195,14 @@ hwpstate_goto_pstate(device_t dev, int pstate)
|
||||
sched_bind(curthread, i);
|
||||
thread_unlock(curthread);
|
||||
/* wait loop (100*100 usec is enough ?) */
|
||||
for(j = 0; j < 100; j++){
|
||||
for (j = 0; j < 100; j++){
|
||||
/* get the result. not assure msr=id */
|
||||
msr = rdmsr(MSR_AMD_10H_11H_STATUS);
|
||||
if(msr == id){
|
||||
if (msr == id)
|
||||
break;
|
||||
}
|
||||
DELAY(100);
|
||||
sbt = SBT_1MS / 10;
|
||||
tsleep_sbt(dev, PZERO, "pstate_goto", sbt,
|
||||
sbt >> tc_precexp, 0);
|
||||
}
|
||||
HWPSTATE_DEBUG(dev, "result: P%d-state on cpu%d\n",
|
||||
(int)msr, PCPU_GET(cpuid));
|
||||
|
Loading…
Reference in New Issue
Block a user