|
@@ -1471,6 +1471,7 @@ int __cpuhp_setup_state(enum cpuhp_state state,
|
|
bool multi_instance)
|
|
bool multi_instance)
|
|
{
|
|
{
|
|
int cpu, ret = 0;
|
|
int cpu, ret = 0;
|
|
|
|
+ bool dynstate;
|
|
|
|
|
|
if (cpuhp_cb_check(state) || !name)
|
|
if (cpuhp_cb_check(state) || !name)
|
|
return -EINVAL;
|
|
return -EINVAL;
|
|
@@ -1480,6 +1481,12 @@ int __cpuhp_setup_state(enum cpuhp_state state,
|
|
ret = cpuhp_store_callbacks(state, name, startup, teardown,
|
|
ret = cpuhp_store_callbacks(state, name, startup, teardown,
|
|
multi_instance);
|
|
multi_instance);
|
|
|
|
|
|
|
|
+ dynstate = state == CPUHP_AP_ONLINE_DYN;
|
|
|
|
+ if (ret > 0 && dynstate) {
|
|
|
|
+ state = ret;
|
|
|
|
+ ret = 0;
|
|
|
|
+ }
|
|
|
|
+
|
|
if (ret || !invoke || !startup)
|
|
if (ret || !invoke || !startup)
|
|
goto out;
|
|
goto out;
|
|
|
|
|
|
@@ -1508,7 +1515,7 @@ out:
|
|
* If the requested state is CPUHP_AP_ONLINE_DYN, return the
|
|
* If the requested state is CPUHP_AP_ONLINE_DYN, return the
|
|
* dynamically allocated state in case of success.
|
|
* dynamically allocated state in case of success.
|
|
*/
|
|
*/
|
|
- if (!ret && state == CPUHP_AP_ONLINE_DYN)
|
|
|
|
|
|
+ if (!ret && dynstate)
|
|
return state;
|
|
return state;
|
|
return ret;
|
|
return ret;
|
|
}
|
|
}
|