x86: freeze non-current vCPUs of dom0 before entering S5
authorKeir Fraser <keir.fraser@citrix.com>
Thu, 20 Nov 2008 14:21:17 +0000 (14:21 +0000)
committerKeir Fraser <keir.fraser@citrix.com>
Thu, 20 Nov 2008 14:21:17 +0000 (14:21 +0000)
Signed-off-by: Jan Beulich <jbeulich@novell.com>
xen/arch/x86/acpi/power.c

index 2eb68600700280f282b7289a6e08afede7ebe291..ccad2ea5eea5c1e828424caa1f364a7a6d94c5b0 100644 (file)
@@ -77,19 +77,47 @@ static void device_power_up(void)
 static void freeze_domains(void)
 {
     struct domain *d;
+    struct vcpu *v;
 
+    rcu_read_lock(&domlist_read_lock);
     for_each_domain ( d )
-        if ( d->domain_id != 0 )
+    {
+        switch ( d->domain_id )
+        {
+        case 0:
+            for_each_vcpu ( d, v )
+                if ( v != current )
+                    vcpu_pause(v);
+            break;
+        default:
             domain_pause(d);
+            break;
+        }
+    }
+    rcu_read_unlock(&domlist_read_lock);
 }
 
 static void thaw_domains(void)
 {
     struct domain *d;
+    struct vcpu *v;
 
+    rcu_read_lock(&domlist_read_lock);
     for_each_domain ( d )
-        if ( d->domain_id != 0 )
+    {
+        switch ( d->domain_id )
+        {
+        case 0:
+            for_each_vcpu ( d, v )
+                if ( v != current )
+                    vcpu_unpause(v);
+            break;
+        default:
             domain_unpause(d);
+            break;
+        }
+    }
+    rcu_read_unlock(&domlist_read_lock);
 }
 
 static void acpi_sleep_prepare(u32 state)