When we advertise we are dead via cpu_exit_clear(), it is no longer
safe to handle interrupts as our per-cpu vars can go away.
In future, we may want to think about NMI handling in this scenario
too.
Signed-off-by: Keir Fraser <keir@xen.org>
static void play_dead(void)
{
+ local_irq_disable();
+ wbinvd();
+
/*
* NOTE: After cpu_exit_clear, per-cpu variables are no longer accessible,
* as they may be freed at any time. In this case, heap corruption or
* #PF can occur (when heap debugging is enabled). For example, even
* printk() can involve tasklet scheduling, which touches per-cpu vars.
*
- * Consider very carefully when adding code to this path. Most hypervisor
+ * Consider very carefully when adding code to *dead_idle. Most hypervisor
* subsystems are unsafe to call.
*/
cpu_exit_clear(smp_processor_id());
- mb();
- local_irq_disable();
- wbinvd();
+
(*dead_idle)();
}