mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-08-05 16:54:27 +00:00
smp/hotplug: Undo tglxs brainfart
The attempt to prevent overwriting an active state resulted in a
disaster which effectively disables all dynamically allocated hotplug
states.
Cleanup the mess.
Fixes: dc280d9362
("cpu/hotplug: Prevent overwriting of callbacks")
Reported-by: Markus Trippelsdorf <markus@trippelsdorf.de>
Reported-by: Boris Ostrovsky <boris.ostrovsky@oracle.com>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
b4b8664d29
commit
b9d9d6911b
1 changed files with 8 additions and 1 deletions
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue