Commit 4654e9f9 authored by Wyes Karny's avatar Wyes Karny Committed by Rafael J. Wysocki

amd-pstate: Fix amd_pstate mode switch

amd_pstate mode can be changed by writing the mode name to the `status`
sysfs. But some combinations are not working. Fix this issue by taking
care of the edge cases.

Before the fix the mode change combination test fails:

 #./pst_test.sh
Test passed: from: disable, to
Test passed: from: disable, to disable
Test failed: 1, From mode: disable, to mode: passive
Test failed: 1, From mode: disable, to mode: active
Test failed: 1, From mode: passive, to mode: active
Test passed: from: passive, to disable
Test failed: 1, From mode: passive, to mode: passive
Test failed: 1, From mode: passive, to mode: active
Test failed: 1, From mode: active, to mode: active
Test passed: from: active, to disable
Test failed: 1, From mode: active, to mode: passive
Test failed: 1, From mode: active, to mode: active

After the fix test passes:

 #./pst_test.sh
Test passed: from: disable, to
Test passed: from: disable, to disable
Test passed: from: disable, to passive
Test passed: from: disable, to active
Test passed: from: passive, to active
Test passed: from: passive, to disable
Test passed: from: passive, to passive
Test passed: from: passive, to active
Test passed: from: active, to active
Test passed: from: active, to disable
Test passed: from: active, to passive
Test passed: from: active, to active

Fixes: abd61c08 ("cpufreq: amd-pstate: add driver working mode switch support")
Acked-by: default avatarHuang Rui <ray.huang@amd.com>
Reviewed-by: default avatarAlexey Kardashevskiy <aik@amd.com>
Signed-off-by: default avatarWyes Karny <wyes.karny@amd.com>
Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
parent 09a9639e
...@@ -840,22 +840,20 @@ static int amd_pstate_update_status(const char *buf, size_t size) ...@@ -840,22 +840,20 @@ static int amd_pstate_update_status(const char *buf, size_t size)
switch(mode_idx) { switch(mode_idx) {
case AMD_PSTATE_DISABLE: case AMD_PSTATE_DISABLE:
if (!current_pstate_driver) if (current_pstate_driver) {
return -EINVAL; cpufreq_unregister_driver(current_pstate_driver);
if (cppc_state == AMD_PSTATE_ACTIVE) amd_pstate_driver_cleanup();
return -EBUSY; }
cpufreq_unregister_driver(current_pstate_driver);
amd_pstate_driver_cleanup();
break; break;
case AMD_PSTATE_PASSIVE: case AMD_PSTATE_PASSIVE:
if (current_pstate_driver) { if (current_pstate_driver) {
if (current_pstate_driver == &amd_pstate_driver) if (current_pstate_driver == &amd_pstate_driver)
return 0; return 0;
cpufreq_unregister_driver(current_pstate_driver); cpufreq_unregister_driver(current_pstate_driver);
cppc_state = AMD_PSTATE_PASSIVE;
current_pstate_driver = &amd_pstate_driver;
} }
current_pstate_driver = &amd_pstate_driver;
cppc_state = AMD_PSTATE_PASSIVE;
ret = cpufreq_register_driver(current_pstate_driver); ret = cpufreq_register_driver(current_pstate_driver);
break; break;
case AMD_PSTATE_ACTIVE: case AMD_PSTATE_ACTIVE:
...@@ -863,10 +861,10 @@ static int amd_pstate_update_status(const char *buf, size_t size) ...@@ -863,10 +861,10 @@ static int amd_pstate_update_status(const char *buf, size_t size)
if (current_pstate_driver == &amd_pstate_epp_driver) if (current_pstate_driver == &amd_pstate_epp_driver)
return 0; return 0;
cpufreq_unregister_driver(current_pstate_driver); cpufreq_unregister_driver(current_pstate_driver);
current_pstate_driver = &amd_pstate_epp_driver;
cppc_state = AMD_PSTATE_ACTIVE;
} }
current_pstate_driver = &amd_pstate_epp_driver;
cppc_state = AMD_PSTATE_ACTIVE;
ret = cpufreq_register_driver(current_pstate_driver); ret = cpufreq_register_driver(current_pstate_driver);
break; break;
default: default:
......
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