[<prev] [next>] [day] [month] [year] [list]
Message-Id: <200909202305.10118.bzolnier@gmail.com>
Date: Sun, 20 Sep 2009 23:05:10 +0200
From: Bartlomiej Zolnierkiewicz <bzolnier@...il.com>
To: John Lee (Jung-Ik) <jilee@...gle.com>
Cc: Grant Grundler <grundler@...gle.com>,
Gwendal Gringo <gwendal@...gle.com>,
Jeff Garzik <jgarzik@...hat.com>, linux-ide@...r.kernel.org,
linux-kernel@...r.kernel.org
Subject: [PATCH] pata_atp867x: add Power Management support
From: Bartlomiej Zolnierkiewicz <bzolnier@...il.com>
Subject: [PATCH] pata_atp867x: add Power Management support
Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@...il.com>
---
needs testing with the real hardware
drivers/ata/pata_atp867x.c | 21 +++++++++++++++++++++
1 file changed, 21 insertions(+)
Index: b/drivers/ata/pata_atp867x.c
===================================================================
--- a/drivers/ata/pata_atp867x.c
+++ b/drivers/ata/pata_atp867x.c
@@ -507,6 +507,23 @@ err_out:
return rc;
}
+#ifdef CONFIG_PM
+static int atp867x_reinit_one(struct pci_dev *pdev)
+{
+ struct ata_host *host = dev_get_drvdata(&pdev->dev);
+ int rc;
+
+ rc = ata_pci_device_do_resume(pdev);
+ if (rc)
+ return rc;
+
+ atp867x_fixup(host);
+
+ ata_host_resume(host);
+ return 0;
+}
+#endif
+
static struct pci_device_id atp867x_pci_tbl[] = {
{ PCI_VDEVICE(ARTOP, PCI_DEVICE_ID_ARTOP_ATP867A), 0 },
{ PCI_VDEVICE(ARTOP, PCI_DEVICE_ID_ARTOP_ATP867B), 0 },
@@ -518,6 +535,10 @@ static struct pci_driver atp867x_driver
.id_table = atp867x_pci_tbl,
.probe = atp867x_init_one,
.remove = ata_pci_remove_one,
+#ifdef CONFIG_PM
+ .suspend = ata_pci_device_suspend,
+ .resume = atp867x_reinit_one,
+#endif
};
static int __init atp867x_init(void)
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists