diff options
| -rw-r--r-- | drivers/ata/pata_atp867x.c | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/drivers/ata/pata_atp867x.c b/drivers/ata/pata_atp867x.c index 4a2cd9a7bad1..6fe7ded40c6a 100644 --- a/drivers/ata/pata_atp867x.c +++ b/drivers/ata/pata_atp867x.c | |||
| @@ -533,6 +533,23 @@ err_out: | |||
| 533 | return rc; | 533 | return rc; |
| 534 | } | 534 | } |
| 535 | 535 | ||
| 536 | #ifdef CONFIG_PM | ||
| 537 | static int atp867x_reinit_one(struct pci_dev *pdev) | ||
| 538 | { | ||
| 539 | struct ata_host *host = dev_get_drvdata(&pdev->dev); | ||
| 540 | int rc; | ||
| 541 | |||
| 542 | rc = ata_pci_device_do_resume(pdev); | ||
| 543 | if (rc) | ||
| 544 | return rc; | ||
| 545 | |||
| 546 | atp867x_fixup(host); | ||
| 547 | |||
| 548 | ata_host_resume(host); | ||
| 549 | return 0; | ||
| 550 | } | ||
| 551 | #endif | ||
| 552 | |||
| 536 | static struct pci_device_id atp867x_pci_tbl[] = { | 553 | static struct pci_device_id atp867x_pci_tbl[] = { |
| 537 | { PCI_VDEVICE(ARTOP, PCI_DEVICE_ID_ARTOP_ATP867A), 0 }, | 554 | { PCI_VDEVICE(ARTOP, PCI_DEVICE_ID_ARTOP_ATP867A), 0 }, |
| 538 | { PCI_VDEVICE(ARTOP, PCI_DEVICE_ID_ARTOP_ATP867B), 0 }, | 555 | { PCI_VDEVICE(ARTOP, PCI_DEVICE_ID_ARTOP_ATP867B), 0 }, |
| @@ -544,6 +561,10 @@ static struct pci_driver atp867x_driver = { | |||
| 544 | .id_table = atp867x_pci_tbl, | 561 | .id_table = atp867x_pci_tbl, |
| 545 | .probe = atp867x_init_one, | 562 | .probe = atp867x_init_one, |
| 546 | .remove = ata_pci_remove_one, | 563 | .remove = ata_pci_remove_one, |
| 564 | #ifdef CONFIG_PM | ||
| 565 | .suspend = ata_pci_device_suspend, | ||
| 566 | .resume = atp867x_reinit_one, | ||
| 567 | #endif | ||
| 547 | }; | 568 | }; |
| 548 | 569 | ||
| 549 | static int __init atp867x_init(void) | 570 | static int __init atp867x_init(void) |
