]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
virtio-pci: S3 support
authorAmit Shah <amit.shah@redhat.com>
Thu, 29 Mar 2012 08:28:10 +0000 (13:58 +0530)
committerMichael S. Tsirkin <mst@redhat.com>
Thu, 29 Mar 2012 11:47:15 +0000 (13:47 +0200)
There's no difference in supporting S3 and S4 for virtio devices: the
vqs have to be re-created as the device has to be assumed to be reset at
restore-time.  Since S4 already handles this situation, we can directly
use the same code and callbacks for S3 support.

Signed-off-by: Amit Shah <amit.shah@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
drivers/virtio/virtio_pci.c

index 982d6c9a2bf0a41cc3c543f9de99d1814135c0e4..0fa4f8551c3a3cc74e676deb6b824332be617555 100644 (file)
@@ -720,24 +720,6 @@ static void __devexit virtio_pci_remove(struct pci_dev *pci_dev)
 }
 
 #ifdef CONFIG_PM
-static int virtio_pci_suspend(struct device *dev)
-{
-       struct pci_dev *pci_dev = to_pci_dev(dev);
-
-       pci_save_state(pci_dev);
-       pci_set_power_state(pci_dev, PCI_D3hot);
-       return 0;
-}
-
-static int virtio_pci_resume(struct device *dev)
-{
-       struct pci_dev *pci_dev = to_pci_dev(dev);
-
-       pci_restore_state(pci_dev);
-       pci_set_power_state(pci_dev, PCI_D0);
-       return 0;
-}
-
 static int virtio_pci_freeze(struct device *dev)
 {
        struct pci_dev *pci_dev = to_pci_dev(dev);
@@ -786,12 +768,12 @@ static int virtio_pci_restore(struct device *dev)
 }
 
 static const struct dev_pm_ops virtio_pci_pm_ops = {
-       .suspend        = virtio_pci_suspend,
-       .resume         = virtio_pci_resume,
+       .suspend        = virtio_pci_freeze,
+       .resume         = virtio_pci_restore,
        .freeze         = virtio_pci_freeze,
        .thaw           = virtio_pci_restore,
        .restore        = virtio_pci_restore,
-       .poweroff       = virtio_pci_suspend,
+       .poweroff       = virtio_pci_freeze,
 };
 #endif