mirror of
https://github.com/hardkernel/linux.git
synced 2026-06-06 10:58:48 +09:00
Merge 28c8f9fe94 ("Merge tag 'smp-core-2022-05-23' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip") into android-mainline
Steps on the way to 5.19-rc1 Signed-off-by: Greg Kroah-Hartman <gregkh@google.com> Change-Id: I5e803e5b3e1d436f00d72a32308fc656ccb634d3
This commit is contained in:
@@ -260,8 +260,11 @@ cpu_initialize_context(unsigned int cpu, struct task_struct *idle)
|
||||
return 0;
|
||||
|
||||
ctxt = kzalloc(sizeof(*ctxt), GFP_KERNEL);
|
||||
if (ctxt == NULL)
|
||||
if (ctxt == NULL) {
|
||||
cpumask_clear_cpu(cpu, xen_cpu_initialized_map);
|
||||
cpumask_clear_cpu(cpu, cpu_callout_mask);
|
||||
return -ENOMEM;
|
||||
}
|
||||
|
||||
gdt = get_cpu_gdt_rw(cpu);
|
||||
|
||||
|
||||
22
kernel/cpu.c
22
kernel/cpu.c
@@ -717,14 +717,6 @@ static int cpuhp_up_callbacks(unsigned int cpu, struct cpuhp_cpu_state *st,
|
||||
/*
|
||||
* The cpu hotplug threads manage the bringup and teardown of the cpus
|
||||
*/
|
||||
static void cpuhp_create(unsigned int cpu)
|
||||
{
|
||||
struct cpuhp_cpu_state *st = per_cpu_ptr(&cpuhp_state, cpu);
|
||||
|
||||
init_completion(&st->done_up);
|
||||
init_completion(&st->done_down);
|
||||
}
|
||||
|
||||
static int cpuhp_should_run(unsigned int cpu)
|
||||
{
|
||||
struct cpuhp_cpu_state *st = this_cpu_ptr(&cpuhp_state);
|
||||
@@ -884,15 +876,27 @@ static int cpuhp_kick_ap_work(unsigned int cpu)
|
||||
|
||||
static struct smp_hotplug_thread cpuhp_threads = {
|
||||
.store = &cpuhp_state.thread,
|
||||
.create = &cpuhp_create,
|
||||
.thread_should_run = cpuhp_should_run,
|
||||
.thread_fn = cpuhp_thread_fun,
|
||||
.thread_comm = "cpuhp/%u",
|
||||
.selfparking = true,
|
||||
};
|
||||
|
||||
static __init void cpuhp_init_state(void)
|
||||
{
|
||||
struct cpuhp_cpu_state *st;
|
||||
int cpu;
|
||||
|
||||
for_each_possible_cpu(cpu) {
|
||||
st = per_cpu_ptr(&cpuhp_state, cpu);
|
||||
init_completion(&st->done_up);
|
||||
init_completion(&st->done_down);
|
||||
}
|
||||
}
|
||||
|
||||
void __init cpuhp_threads_init(void)
|
||||
{
|
||||
cpuhp_init_state();
|
||||
BUG_ON(smpboot_register_percpu_thread(&cpuhp_threads));
|
||||
kthread_unpark(this_cpu_read(cpuhp_state.thread));
|
||||
}
|
||||
|
||||
@@ -392,6 +392,13 @@ int cpu_check_up_prepare(int cpu)
|
||||
*/
|
||||
return -EAGAIN;
|
||||
|
||||
case CPU_UP_PREPARE:
|
||||
/*
|
||||
* Timeout while waiting for the CPU to show up. Allow to try
|
||||
* again later.
|
||||
*/
|
||||
return 0;
|
||||
|
||||
default:
|
||||
|
||||
/* Should not happen. Famous last words. */
|
||||
|
||||
Reference in New Issue
Block a user