We found a problem. When a cpu is brought down using _cpu_down(), the corresponding cpu bit in the cpus_allowed of the current task is cleared. But this bit will not be set when the same cpu is online again. Then, the current task and its child processes will not be allowed to run on this cpu. To fix this problem, some related code in the commit cc4088a (hotplug: Lightweight get online cpus) is removed. Signed-off-by: Zhao Chenhui <chenhui.zhao@xxxxxxxxxxxxx> --- kernel/cpu.c | 15 +-------------- 1 files changed, 1 insertions(+), 14 deletions(-) diff --git a/kernel/cpu.c b/kernel/cpu.c index bfeeb00..e25b05f 100644 --- a/kernel/cpu.c +++ b/kernel/cpu.c @@ -524,14 +524,13 @@ static int __ref take_cpu_down(void *_param) /* Requires cpu_add_remove_lock to be held */ static int __ref _cpu_down(unsigned int cpu, int tasks_frozen) { - int mycpu, err, nr_calls = 0; + int err, nr_calls = 0; void *hcpu = (void *)(long)cpu; unsigned long mod = tasks_frozen ? CPU_TASKS_FROZEN : 0; struct take_cpu_down_param tcd_param = { .mod = mod, .hcpu = hcpu, }; - cpumask_var_t cpumask; if (num_online_cpus() == 1) return -EBUSY; @@ -539,19 +538,7 @@ static int __ref _cpu_down(unsigned int cpu, int tasks_frozen) if (!cpu_online(cpu)) return -EINVAL; - /* Move the downtaker off the unplug cpu */ - if (!alloc_cpumask_var(&cpumask, GFP_KERNEL)) - return -ENOMEM; - cpumask_andnot(cpumask, cpu_online_mask, cpumask_of(cpu)); - set_cpus_allowed_ptr(current, cpumask); - free_cpumask_var(cpumask); migrate_disable(); - mycpu = smp_processor_id(); - if (mycpu == cpu) { - printk(KERN_ERR "Yuck! Still on unplug CPU\n!"); - migrate_enable(); - return -EBUSY; - } cpu_hotplug_begin(); err = cpu_unplug_begin(cpu); -- 1.7.3 -- To unsubscribe from this list: send the line "unsubscribe linux-rt-users" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html