ARM: disable preemption in machine_shutdown
authorMike J. Chen <mjchen@google.com>
Thu, 24 May 2012 22:12:36 +0000 (15:12 -0700)
committerandroid code review <noreply-gerritcodereview@google.com>
Mon, 20 Aug 2012 22:50:55 +0000 (15:50 -0700)
Since the smp call to stop the other cpus are handled in those
cpus in interrupt context, there's a potential for those smp
handlers to interrupt threads holding spin locks (such as the
one a mutex holds).  This prevents those threads from ever
releasing their spin lock, so if the cpu doing the shutdown
is allowed to switch to another thread that tries to grab the
same lock/mutex, we could get into a deadlock (the spin lock
call is called with preemption disabled in the mutex lock code).

To avoid that possibility, disable preemption before doing the
smp_send_stop().

Change-Id: I7976c5382d7173fcb3cd14da8cc5083d442b2544
Signed-off-by: Mike J. Chen <mjchen@google.com>
arch/arm/kernel/process.c

index e5cfa6ac44a0f1b72b5e44082737607a40abba0e..c132e8145754c3b9a8ea8d5e1a82a2467f707795 100644 (file)
@@ -272,6 +272,15 @@ __setup("reboot=", reboot_setup);
 void machine_shutdown(void)
 {
 #ifdef CONFIG_SMP
+       /*
+        * Disable preemption so we're guaranteed to
+        * run to power off or reboot and prevent
+        * the possibility of switching to another
+        * thread that might wind up blocking on
+        * one of the stopped CPUs.
+        */
+       preempt_disable();
+
        smp_send_stop();
 #endif
 }