powerpc: ONLINE to OFFLINE CPU state transition during removal
authorRobert Jennings <rcj@linux.vnet.ibm.com>
Thu, 22 Jul 2010 16:43:44 +0000 (16:43 +0000)
committerBenjamin Herrenschmidt <benh@kernel.crashing.org>
Sat, 31 Jul 2010 05:05:19 +0000 (15:05 +1000)
If a CPU remove is attempted using the 'release' interface on hardware
which supports extended cede, the CPU will be put in the INACTIVE state
rather than the OFFLINE state due to the default preferred_offline_state
in that situation.  In the INACTIVE state it will fail to be removed.

This patch changes the preferred offline state to OFFLINE when an CPU is
in the ONLINE state.  After cpu_down() is called in dlpar_offline_cpu()
the CPU will be OFFLINE and CPU removal can continue.

Signed-off-by: Robert Jennings <rcj@linux.vnet.ibm.com>
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
arch/powerpc/platforms/pseries/dlpar.c

index d71e5858408645889d0f6b13772f5daa9bb009d2..227c1c3d585e028874cc895afc3241afff0b3caf 100644 (file)
@@ -463,6 +463,7 @@ static int dlpar_offline_cpu(struct device_node *dn)
                                break;
 
                        if (get_cpu_current_state(cpu) == CPU_STATE_ONLINE) {
+                               set_preferred_offline_state(cpu, CPU_STATE_OFFLINE);
                                cpu_maps_update_done();
                                rc = cpu_down(cpu);
                                if (rc)