Thomas Gleixner <t...@linutronix.de> writes:

> On Wed, 26 Jul 2017, Michael Ellerman wrote:
>
>> Hi Thomas,
>> 
>> I'm seeing the lockdep barf below on some bare metal Power8 machines.
>> 
>> This seems to be caused by our smp_cpus_done(), which does:
>> 
>>   void __init smp_cpus_done(unsigned int max_cpus)
>>   {
>>      /*
>>       * We want the setup_cpu() here to be called on the boot CPU, but
>>       * init might run on any CPU, so make sure it's invoked on the boot
>>       * CPU.
>>       */
>>      if (smp_ops && smp_ops->setup_cpu)
>>              work_on_cpu_safe(boot_cpuid, smp_setup_cpu_workfn, NULL);
>> 
>> 
>> I don't think CPU hotplug can happen at this point, so I don't think
>> there's really a bug.
>> 
>> But it looks like the work_on_cpu_safe() call could just go away, since
>> you pinned init to the boot CPU in 8fb12156b8db ("init: Pin init task to
>> the boot CPU, initially"). Though I can't see where init is unpinned, so
>> maybe we do still need to do it?
>
> It's undone in sched_init_smp(). So it looks safe. The call order is:
>
>      smp_init()
>       ...
>       smp_cpus_done()
>
>      sched_init_smp()

Great thanks.

Patch on the way.

cheers

Reply via email to