cpu hotplug: Make cpu_active_map synchronization dependency clear
authorMax Krasnyansky <maxk@qualcomm.com>
Wed, 16 Jul 2008 03:56:26 +0000 (20:56 -0700)
committerIngo Molnar <mingo@elte.hu>
Fri, 18 Jul 2008 11:23:18 +0000 (13:23 +0200)
commit39b0fad7121eace85770e7a4c6dc35dfd2879768
treea5d85b06fd656ccb26c906c237fb45dccd46e18c
parente761b7725234276a802322549cee5255305a0930
cpu hotplug: Make cpu_active_map synchronization dependency clear

This goes on top of the cpu_active_map (take 2) patch.

Currently we depend on the stop_machine to provide nescessesary
synchronization for the cpu_active_map updates.
As Dmitry Adamushko pointed this is fragile and is not much clearer
than the previous scheme. In other words we do not want to depend on
the internal stop machine operation here.
So make the synchronization rules clear by doing synchronize_sched()
after clearing out cpu active bit.

Tested on quad-Core2 with:

   while true; do
      for i in 1 2 3; do
        echo 0 > /sys/devices/system/cpu/cpu$i/online
      done
      for i in 1 2 3; do
        echo 1 > /sys/devices/system/cpu/cpu$i/online
      done
   done
and
   stress -c 200

No lockdep, preempt or other complaints.

Signed-off-by: Max Krasnyansky <maxk@qualcomm.com>
Acked-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
kernel/cpu.c