[PATCH v1] ARM: rockchip: Add cpu hotplug support for RK3XXX SoCs
Romain Perier
romain.perier at gmail.com
Fri Jul 18 09:43:21 PDT 2014
Le 18/07/2014 10:29, Russell King - ARM Linux a écrit :
> On Fri, Jul 18, 2014 at 08:16:02AM +0200, Romain Perier wrote:
>> you're probably talking about __cpu_die at
>> http://lxr.free-electrons.com/source/arch/arm/kernel/smp.c#L223 . The
>> problem being that the thread below which executes cpu_die completes the
>> completion before executing smp_ops.cpu_die. So smp_ops.cpu_kill might
>> be executed before smp_ops.cpu_die (in some cases cache coherency would
>> not be turned off). Note that almost all SoCs do the same thing.
> Look at what's happening:
>
> CPU0 CPU1
> wait_for_completion_timeout()
> idle_task_exit()
> flush_cache_louis()
> complete(&cpu_died);
>
> At this point, it is safe for CPU1 to be powered down.
>
> smp_ops.cpu_kill(cpu);
> flush_cache_louis();
> smp_ops.cpu_die(cpu);
>
> If we include your code at that point, then the sequence in totality
> becomes:
>
> wait_for_completion_timeout()
> idle_task_exit()
> flush_cache_louis()
> complete(&cpu_died);
> --- rockchip_cpu_kill ---
> wait_for_completion_timeout()
> flush_cache_louis();
> --- rockchip_cpu_die ---
> complete(&cpu_died);
> pmu_set_power_domain(0 + cpu, false);
> flush_cache_louis();
> v7_exit_coherency_flush(louis);
> while(1)
> cpu_do_idle();
>
> So, I repeat my question. What is the point of your additional wait
> in rockchip_cpu_kill() and complete in rockchip_cpu_die()?
>
Mhhh... you're right... my bad ! So either smp_ops.cpu_kill(cpu) is
executed before smp_ops.cpu_die and in this case it is safe to power
down the cpu. or smp_ops.cpu_die(cpu) is executed before
smp_ops.cpu_kill(due) and it is safe too.
I will send a new patch (v2)
Romain
More information about the linux-arm-kernel
mailing list