aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/ata
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/ata')
-rw-r--r--drivers/ata/Kconfig3
-rw-r--r--drivers/ata/Makefile1
-rw-r--r--drivers/ata/ahci.c3
-rw-r--r--drivers/ata/ahci_platform.c55
-rw-r--r--drivers/ata/ata_piix.c153
-rw-r--r--drivers/ata/libata-core.c3
-rw-r--r--drivers/ata/libata-eh.c18
-rw-r--r--drivers/ata/libata-pmp.c8
-rw-r--r--drivers/ata/libata-scsi.c43
-rw-r--r--drivers/ata/libata-sff.c122
-rw-r--r--drivers/ata/pata_ali.c2
-rw-r--r--drivers/ata/pata_arasan_cf.c6
-rw-r--r--drivers/ata/pata_artop.c107
-rw-r--r--drivers/ata/pata_at91.c7
-rw-r--r--drivers/ata/pata_atiixp.c35
-rw-r--r--drivers/ata/pata_cmd64x.c44
-rw-r--r--drivers/ata/pata_cs5535.c16
-rw-r--r--drivers/ata/pata_efar.c22
-rw-r--r--drivers/ata/pata_hpt366.c35
-rw-r--r--drivers/ata/pata_it8213.c24
-rw-r--r--drivers/ata/pata_legacy.c129
-rw-r--r--drivers/ata/pata_mpc52xx.c2
-rw-r--r--drivers/ata/pata_of_platform.c8
-rw-r--r--drivers/ata/pata_pdc2027x.c30
-rw-r--r--drivers/ata/pata_qdi.c366
-rw-r--r--drivers/ata/pata_rdc.c16
-rw-r--r--drivers/ata/pata_sc1200.c14
-rw-r--r--drivers/ata/pata_scc.c14
-rw-r--r--drivers/ata/pata_serverworks.c127
-rw-r--r--drivers/ata/pata_sil680.c94
-rw-r--r--drivers/ata/pata_sis.c154
-rw-r--r--drivers/ata/pata_sl82c105.c37
-rw-r--r--drivers/ata/pata_via.c49
-rw-r--r--drivers/ata/sata_mv.c16
-rw-r--r--drivers/ata/sata_sil24.c4
-rw-r--r--drivers/ata/sata_sis.c2
36 files changed, 759 insertions, 1010 deletions
diff --git a/drivers/ata/Kconfig b/drivers/ata/Kconfig
index 5987e0ba8c2d..6bdedd7cca2c 100644
--- a/drivers/ata/Kconfig
+++ b/drivers/ata/Kconfig
@@ -820,7 +820,7 @@ config PATA_PLATFORM
820 820
821config PATA_OF_PLATFORM 821config PATA_OF_PLATFORM
822 tristate "OpenFirmware platform device PATA support" 822 tristate "OpenFirmware platform device PATA support"
823 depends on PATA_PLATFORM && PPC_OF 823 depends on PATA_PLATFORM && OF
824 help 824 help
825 This option enables support for generic directly connected ATA 825 This option enables support for generic directly connected ATA
826 devices commonly found on embedded systems with OpenFirmware 826 devices commonly found on embedded systems with OpenFirmware
@@ -831,6 +831,7 @@ config PATA_OF_PLATFORM
831config PATA_QDI 831config PATA_QDI
832 tristate "QDI VLB PATA support" 832 tristate "QDI VLB PATA support"
833 depends on ISA 833 depends on ISA
834 select PATA_LEGACY
834 help 835 help
835 Support for QDI 6500 and 6580 PATA controllers on VESA local bus. 836 Support for QDI 6500 and 6580 PATA controllers on VESA local bus.
836 837
diff --git a/drivers/ata/Makefile b/drivers/ata/Makefile
index 9550d691fd19..6ece5b7231a3 100644
--- a/drivers/ata/Makefile
+++ b/drivers/ata/Makefile
@@ -88,7 +88,6 @@ obj-$(CONFIG_PATA_PCMCIA) += pata_pcmcia.o
88obj-$(CONFIG_PATA_PALMLD) += pata_palmld.o 88obj-$(CONFIG_PATA_PALMLD) += pata_palmld.o
89obj-$(CONFIG_PATA_PLATFORM) += pata_platform.o 89obj-$(CONFIG_PATA_PLATFORM) += pata_platform.o
90obj-$(CONFIG_PATA_OF_PLATFORM) += pata_of_platform.o 90obj-$(CONFIG_PATA_OF_PLATFORM) += pata_of_platform.o
91obj-$(CONFIG_PATA_QDI) += pata_qdi.o
92obj-$(CONFIG_PATA_RB532) += pata_rb532_cf.o 91obj-$(CONFIG_PATA_RB532) += pata_rb532_cf.o
93obj-$(CONFIG_PATA_RZ1000) += pata_rz1000.o 92obj-$(CONFIG_PATA_RZ1000) += pata_rz1000.o
94obj-$(CONFIG_PATA_SAMSUNG_CF) += pata_samsung_cf.o 93obj-$(CONFIG_PATA_SAMSUNG_CF) += pata_samsung_cf.o
diff --git a/drivers/ata/ahci.c b/drivers/ata/ahci.c
index fb7b90b05922..cf26222a93c5 100644
--- a/drivers/ata/ahci.c
+++ b/drivers/ata/ahci.c
@@ -390,6 +390,9 @@ static const struct pci_device_id ahci_pci_tbl[] = {
390 /* Promise */ 390 /* Promise */
391 { PCI_VDEVICE(PROMISE, 0x3f20), board_ahci }, /* PDC42819 */ 391 { PCI_VDEVICE(PROMISE, 0x3f20), board_ahci }, /* PDC42819 */
392 392
393 /* Asmedia */
394 { PCI_VDEVICE(ASMEDIA, 0x0612), board_ahci }, /* ASM1061 */
395
393 /* Generic, PCI class code for AHCI */ 396 /* Generic, PCI class code for AHCI */
394 { PCI_ANY_ID, PCI_ANY_ID, PCI_ANY_ID, PCI_ANY_ID, 397 { PCI_ANY_ID, PCI_ANY_ID, PCI_ANY_ID, PCI_ANY_ID,
395 PCI_CLASS_STORAGE_SATA_AHCI, 0xffffff, board_ahci }, 398 PCI_CLASS_STORAGE_SATA_AHCI, 0xffffff, board_ahci },
diff --git a/drivers/ata/ahci_platform.c b/drivers/ata/ahci_platform.c
index 6fef1fa75c54..43b875810d1b 100644
--- a/drivers/ata/ahci_platform.c
+++ b/drivers/ata/ahci_platform.c
@@ -23,6 +23,41 @@
23#include <linux/ahci_platform.h> 23#include <linux/ahci_platform.h>
24#include "ahci.h" 24#include "ahci.h"
25 25
26enum ahci_type {
27 AHCI, /* standard platform ahci */
28 IMX53_AHCI, /* ahci on i.mx53 */
29};
30
31static struct platform_device_id ahci_devtype[] = {
32 {
33 .name = "ahci",
34 .driver_data = AHCI,
35 }, {
36 .name = "imx53-ahci",
37 .driver_data = IMX53_AHCI,
38 }, {
39 /* sentinel */
40 }
41};
42MODULE_DEVICE_TABLE(platform, ahci_devtype);
43
44
45static const struct ata_port_info ahci_port_info[] = {
46 /* by features */
47 [AHCI] = {
48 .flags = AHCI_FLAG_COMMON,
49 .pio_mask = ATA_PIO4,
50 .udma_mask = ATA_UDMA6,
51 .port_ops = &ahci_ops,
52 },
53 [IMX53_AHCI] = {
54 .flags = AHCI_FLAG_COMMON,
55 .pio_mask = ATA_PIO4,
56 .udma_mask = ATA_UDMA6,
57 .port_ops = &ahci_pmp_retry_srst_ops,
58 },
59};
60
26static struct scsi_host_template ahci_platform_sht = { 61static struct scsi_host_template ahci_platform_sht = {
27 AHCI_SHT("ahci_platform"), 62 AHCI_SHT("ahci_platform"),
28}; 63};
@@ -30,13 +65,9 @@ static struct scsi_host_template ahci_platform_sht = {
30static int __init ahci_probe(struct platform_device *pdev) 65static int __init ahci_probe(struct platform_device *pdev)
31{ 66{
32 struct device *dev = &pdev->dev; 67 struct device *dev = &pdev->dev;
33 struct ahci_platform_data *pdata = dev->platform_data; 68 struct ahci_platform_data *pdata = dev_get_platdata(dev);
34 struct ata_port_info pi = { 69 const struct platform_device_id *id = platform_get_device_id(pdev);
35 .flags = AHCI_FLAG_COMMON, 70 struct ata_port_info pi = ahci_port_info[id ? id->driver_data : 0];
36 .pio_mask = ATA_PIO4,
37 .udma_mask = ATA_UDMA6,
38 .port_ops = &ahci_ops,
39 };
40 const struct ata_port_info *ppi[] = { &pi, NULL }; 71 const struct ata_port_info *ppi[] = { &pi, NULL };
41 struct ahci_host_priv *hpriv; 72 struct ahci_host_priv *hpriv;
42 struct ata_host *host; 73 struct ata_host *host;
@@ -160,7 +191,7 @@ err0:
160static int __devexit ahci_remove(struct platform_device *pdev) 191static int __devexit ahci_remove(struct platform_device *pdev)
161{ 192{
162 struct device *dev = &pdev->dev; 193 struct device *dev = &pdev->dev;
163 struct ahci_platform_data *pdata = dev->platform_data; 194 struct ahci_platform_data *pdata = dev_get_platdata(dev);
164 struct ata_host *host = dev_get_drvdata(dev); 195 struct ata_host *host = dev_get_drvdata(dev);
165 196
166 ata_host_detach(host); 197 ata_host_detach(host);
@@ -171,12 +202,20 @@ static int __devexit ahci_remove(struct platform_device *pdev)
171 return 0; 202 return 0;
172} 203}
173 204
205static const struct of_device_id ahci_of_match[] = {
206 { .compatible = "calxeda,hb-ahci", },
207 {},
208};
209MODULE_DEVICE_TABLE(of, ahci_of_match);
210
174static struct platform_driver ahci_driver = { 211static struct platform_driver ahci_driver = {
175 .remove = __devexit_p(ahci_remove), 212 .remove = __devexit_p(ahci_remove),
176 .driver = { 213 .driver = {
177 .name = "ahci", 214 .name = "ahci",
178 .owner = THIS_MODULE, 215 .owner = THIS_MODULE,
216 .of_match_table = ahci_of_match,
179 }, 217 },
218 .id_table = ahci_devtype,
180}; 219};
181 220
182static int __init ahci_init(void) 221static int __init ahci_init(void)
diff --git a/drivers/ata/ata_piix.c b/drivers/ata/ata_piix.c
index 43107e9415da..69ac373c72ab 100644
--- a/drivers/ata/ata_piix.c
+++ b/drivers/ata/ata_piix.c
@@ -113,6 +113,8 @@ enum {
113 PIIX_PATA_FLAGS = ATA_FLAG_SLAVE_POSS, 113 PIIX_PATA_FLAGS = ATA_FLAG_SLAVE_POSS,
114 PIIX_SATA_FLAGS = ATA_FLAG_SATA | PIIX_FLAG_CHECKINTR, 114 PIIX_SATA_FLAGS = ATA_FLAG_SATA | PIIX_FLAG_CHECKINTR,
115 115
116 PIIX_FLAG_PIO16 = (1 << 30), /*support 16bit PIO only*/
117
116 PIIX_80C_PRI = (1 << 5) | (1 << 4), 118 PIIX_80C_PRI = (1 << 5) | (1 << 4),
117 PIIX_80C_SEC = (1 << 7) | (1 << 6), 119 PIIX_80C_SEC = (1 << 7) | (1 << 6),
118 120
@@ -147,6 +149,7 @@ enum piix_controller_ids {
147 ich8m_apple_sata, /* locks up on second port enable */ 149 ich8m_apple_sata, /* locks up on second port enable */
148 tolapai_sata, 150 tolapai_sata,
149 piix_pata_vmw, /* PIIX4 for VMware, spurious DMA_ERR */ 151 piix_pata_vmw, /* PIIX4 for VMware, spurious DMA_ERR */
152 ich8_sata_snb,
150}; 153};
151 154
152struct piix_map_db { 155struct piix_map_db {
@@ -177,6 +180,7 @@ static int piix_sidpr_scr_write(struct ata_link *link,
177static int piix_sidpr_set_lpm(struct ata_link *link, enum ata_lpm_policy policy, 180static int piix_sidpr_set_lpm(struct ata_link *link, enum ata_lpm_policy policy,
178 unsigned hints); 181 unsigned hints);
179static bool piix_irq_check(struct ata_port *ap); 182static bool piix_irq_check(struct ata_port *ap);
183static int piix_port_start(struct ata_port *ap);
180#ifdef CONFIG_PM 184#ifdef CONFIG_PM
181static int piix_pci_device_suspend(struct pci_dev *pdev, pm_message_t mesg); 185static int piix_pci_device_suspend(struct pci_dev *pdev, pm_message_t mesg);
182static int piix_pci_device_resume(struct pci_dev *pdev); 186static int piix_pci_device_resume(struct pci_dev *pdev);
@@ -298,21 +302,21 @@ static const struct pci_device_id piix_pci_tbl[] = {
298 /* SATA Controller IDE (PCH) */ 302 /* SATA Controller IDE (PCH) */
299 { 0x8086, 0x3b2e, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_sata }, 303 { 0x8086, 0x3b2e, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_sata },
300 /* SATA Controller IDE (CPT) */ 304 /* SATA Controller IDE (CPT) */
301 { 0x8086, 0x1c00, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_sata }, 305 { 0x8086, 0x1c00, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_sata_snb },
302 /* SATA Controller IDE (CPT) */ 306 /* SATA Controller IDE (CPT) */
303 { 0x8086, 0x1c01, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_sata }, 307 { 0x8086, 0x1c01, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_sata_snb },
304 /* SATA Controller IDE (CPT) */ 308 /* SATA Controller IDE (CPT) */
305 { 0x8086, 0x1c08, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_2port_sata }, 309 { 0x8086, 0x1c08, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_2port_sata },
306 /* SATA Controller IDE (CPT) */ 310 /* SATA Controller IDE (CPT) */
307 { 0x8086, 0x1c09, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_2port_sata }, 311 { 0x8086, 0x1c09, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_2port_sata },
308 /* SATA Controller IDE (PBG) */ 312 /* SATA Controller IDE (PBG) */
309 { 0x8086, 0x1d00, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_sata }, 313 { 0x8086, 0x1d00, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_sata_snb },
310 /* SATA Controller IDE (PBG) */ 314 /* SATA Controller IDE (PBG) */
311 { 0x8086, 0x1d08, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_2port_sata }, 315 { 0x8086, 0x1d08, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_2port_sata },
312 /* SATA Controller IDE (Panther Point) */ 316 /* SATA Controller IDE (Panther Point) */
313 { 0x8086, 0x1e00, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_sata }, 317 { 0x8086, 0x1e00, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_sata_snb },
314 /* SATA Controller IDE (Panther Point) */ 318 /* SATA Controller IDE (Panther Point) */
315 { 0x8086, 0x1e01, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_sata }, 319 { 0x8086, 0x1e01, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_sata_snb },
316 /* SATA Controller IDE (Panther Point) */ 320 /* SATA Controller IDE (Panther Point) */
317 { 0x8086, 0x1e08, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_2port_sata }, 321 { 0x8086, 0x1e08, PCI_ANY_ID, PCI_ANY_ID, 0, 0, ich8_2port_sata },
318 /* SATA Controller IDE (Panther Point) */ 322 /* SATA Controller IDE (Panther Point) */
@@ -338,6 +342,7 @@ static struct scsi_host_template piix_sht = {
338static struct ata_port_operations piix_sata_ops = { 342static struct ata_port_operations piix_sata_ops = {
339 .inherits = &ata_bmdma32_port_ops, 343 .inherits = &ata_bmdma32_port_ops,
340 .sff_irq_check = piix_irq_check, 344 .sff_irq_check = piix_irq_check,
345 .port_start = piix_port_start,
341}; 346};
342 347
343static struct ata_port_operations piix_pata_ops = { 348static struct ata_port_operations piix_pata_ops = {
@@ -478,6 +483,7 @@ static const struct piix_map_db *piix_map_db_table[] = {
478 [ich8_2port_sata] = &ich8_2port_map_db, 483 [ich8_2port_sata] = &ich8_2port_map_db,
479 [ich8m_apple_sata] = &ich8m_apple_map_db, 484 [ich8m_apple_sata] = &ich8m_apple_map_db,
480 [tolapai_sata] = &tolapai_map_db, 485 [tolapai_sata] = &tolapai_map_db,
486 [ich8_sata_snb] = &ich8_map_db,
481}; 487};
482 488
483static struct ata_port_info piix_port_info[] = { 489static struct ata_port_info piix_port_info[] = {
@@ -606,6 +612,19 @@ static struct ata_port_info piix_port_info[] = {
606 .port_ops = &piix_vmw_ops, 612 .port_ops = &piix_vmw_ops,
607 }, 613 },
608 614
615 /*
616 * some Sandybridge chipsets have broken 32 mode up to now,
617 * see https://bugzilla.kernel.org/show_bug.cgi?id=40592
618 */
619 [ich8_sata_snb] =
620 {
621 .flags = PIIX_SATA_FLAGS | PIIX_FLAG_SIDPR | PIIX_FLAG_PIO16,
622 .pio_mask = ATA_PIO4,
623 .mwdma_mask = ATA_MWDMA2,
624 .udma_mask = ATA_UDMA6,
625 .port_ops = &piix_sata_ops,
626 },
627
609}; 628};
610 629
611static struct pci_bits piix_enable_bits[] = { 630static struct pci_bits piix_enable_bits[] = {
@@ -649,6 +668,14 @@ static const struct ich_laptop ich_laptop[] = {
649 { 0, } 668 { 0, }
650}; 669};
651 670
671static int piix_port_start(struct ata_port *ap)
672{
673 if (!(ap->flags & PIIX_FLAG_PIO16))
674 ap->pflags |= ATA_PFLAG_PIO32 | ATA_PFLAG_PIO32CHANGE;
675
676 return ata_bmdma_port_start(ap);
677}
678
652/** 679/**
653 * ich_pata_cable_detect - Probe host controller cable detect info 680 * ich_pata_cable_detect - Probe host controller cable detect info
654 * @ap: Port for which cable detect info is desired 681 * @ap: Port for which cable detect info is desired
@@ -704,22 +731,11 @@ static int piix_pata_prereset(struct ata_link *link, unsigned long deadline)
704 731
705static DEFINE_SPINLOCK(piix_lock); 732static DEFINE_SPINLOCK(piix_lock);
706 733
707/** 734static void piix_set_timings(struct ata_port *ap, struct ata_device *adev,
708 * piix_set_piomode - Initialize host controller PATA PIO timings 735 u8 pio)
709 * @ap: Port whose timings we are configuring
710 * @adev: um
711 *
712 * Set PIO mode for device, in host controller PCI config space.
713 *
714 * LOCKING:
715 * None (inherited from caller).
716 */
717
718static void piix_set_piomode(struct ata_port *ap, struct ata_device *adev)
719{ 736{
720 struct pci_dev *dev = to_pci_dev(ap->host->dev); 737 struct pci_dev *dev = to_pci_dev(ap->host->dev);
721 unsigned long flags; 738 unsigned long flags;
722 unsigned int pio = adev->pio_mode - XFER_PIO_0;
723 unsigned int is_slave = (adev->devno != 0); 739 unsigned int is_slave = (adev->devno != 0);
724 unsigned int master_port= ap->port_no ? 0x42 : 0x40; 740 unsigned int master_port= ap->port_no ? 0x42 : 0x40;
725 unsigned int slave_port = 0x44; 741 unsigned int slave_port = 0x44;
@@ -744,10 +760,16 @@ static void piix_set_piomode(struct ata_port *ap, struct ata_device *adev)
744 control |= 1; /* TIME1 enable */ 760 control |= 1; /* TIME1 enable */
745 if (ata_pio_need_iordy(adev)) 761 if (ata_pio_need_iordy(adev))
746 control |= 2; /* IE enable */ 762 control |= 2; /* IE enable */
747
748 /* Intel specifies that the PPE functionality is for disk only */ 763 /* Intel specifies that the PPE functionality is for disk only */
749 if (adev->class == ATA_DEV_ATA) 764 if (adev->class == ATA_DEV_ATA)
750 control |= 4; /* PPE enable */ 765 control |= 4; /* PPE enable */
766 /*
767 * If the drive MWDMA is faster than it can do PIO then
768 * we must force PIO into PIO0
769 */
770 if (adev->pio_mode < XFER_PIO_0 + pio)
771 /* Enable DMA timing only */
772 control |= 8; /* PIO cycles in PIO0 */
751 773
752 spin_lock_irqsave(&piix_lock, flags); 774 spin_lock_irqsave(&piix_lock, flags);
753 775
@@ -759,8 +781,6 @@ static void piix_set_piomode(struct ata_port *ap, struct ata_device *adev)
759 if (is_slave) { 781 if (is_slave) {
760 /* clear TIME1|IE1|PPE1|DTE1 */ 782 /* clear TIME1|IE1|PPE1|DTE1 */
761 master_data &= 0xff0f; 783 master_data &= 0xff0f;
762 /* Enable SITRE (separate slave timing register) */
763 master_data |= 0x4000;
764 /* enable PPE1, IE1 and TIME1 as needed */ 784 /* enable PPE1, IE1 and TIME1 as needed */
765 master_data |= (control << 4); 785 master_data |= (control << 4);
766 pci_read_config_byte(dev, slave_port, &slave_data); 786 pci_read_config_byte(dev, slave_port, &slave_data);
@@ -778,6 +798,9 @@ static void piix_set_piomode(struct ata_port *ap, struct ata_device *adev)
778 (timings[pio][0] << 12) | 798 (timings[pio][0] << 12) |
779 (timings[pio][1] << 8); 799 (timings[pio][1] << 8);
780 } 800 }
801
802 /* Enable SITRE (separate slave timing register) */
803 master_data |= 0x4000;
781 pci_write_config_word(dev, master_port, master_data); 804 pci_write_config_word(dev, master_port, master_data);
782 if (is_slave) 805 if (is_slave)
783 pci_write_config_byte(dev, slave_port, slave_data); 806 pci_write_config_byte(dev, slave_port, slave_data);
@@ -795,6 +818,22 @@ static void piix_set_piomode(struct ata_port *ap, struct ata_device *adev)
795} 818}
796 819
797/** 820/**
821 * piix_set_piomode - Initialize host controller PATA PIO timings
822 * @ap: Port whose timings we are configuring
823 * @adev: Drive in question
824 *
825 * Set PIO mode for device, in host controller PCI config space.
826 *
827 * LOCKING:
828 * None (inherited from caller).
829 */
830
831static void piix_set_piomode(struct ata_port *ap, struct ata_device *adev)
832{
833 piix_set_timings(ap, adev, adev->pio_mode - XFER_PIO_0);
834}
835
836/**
798 * do_pata_set_dmamode - Initialize host controller PATA PIO timings 837 * do_pata_set_dmamode - Initialize host controller PATA PIO timings
799 * @ap: Port whose timings we are configuring 838 * @ap: Port whose timings we are configuring
800 * @adev: Drive in question 839 * @adev: Drive in question
@@ -810,31 +849,20 @@ static void do_pata_set_dmamode(struct ata_port *ap, struct ata_device *adev, in
810{ 849{
811 struct pci_dev *dev = to_pci_dev(ap->host->dev); 850 struct pci_dev *dev = to_pci_dev(ap->host->dev);
812 unsigned long flags; 851 unsigned long flags;
813 u8 master_port = ap->port_no ? 0x42 : 0x40;
814 u16 master_data;
815 u8 speed = adev->dma_mode; 852 u8 speed = adev->dma_mode;
816 int devid = adev->devno + 2 * ap->port_no; 853 int devid = adev->devno + 2 * ap->port_no;
817 u8 udma_enable = 0; 854 u8 udma_enable = 0;
818 855
819 static const /* ISP RTC */
820 u8 timings[][2] = { { 0, 0 },
821 { 0, 0 },
822 { 1, 0 },
823 { 2, 1 },
824 { 2, 3 }, };
825
826 spin_lock_irqsave(&piix_lock, flags);
827
828 pci_read_config_word(dev, master_port, &master_data);
829 if (ap->udma_mask)
830 pci_read_config_byte(dev, 0x48, &udma_enable);
831
832 if (speed >= XFER_UDMA_0) { 856 if (speed >= XFER_UDMA_0) {
833 unsigned int udma = adev->dma_mode - XFER_UDMA_0; 857 unsigned int udma = speed - XFER_UDMA_0;
834 u16 udma_timing; 858 u16 udma_timing;
835 u16 ideconf; 859 u16 ideconf;
836 int u_clock, u_speed; 860 int u_clock, u_speed;
837 861
862 spin_lock_irqsave(&piix_lock, flags);
863
864 pci_read_config_byte(dev, 0x48, &udma_enable);
865
838 /* 866 /*
839 * UDMA is handled by a combination of clock switching and 867 * UDMA is handled by a combination of clock switching and
840 * selection of dividers 868 * selection of dividers
@@ -867,56 +895,21 @@ static void do_pata_set_dmamode(struct ata_port *ap, struct ata_device *adev, in
867 performance (WR_PingPong_En) */ 895 performance (WR_PingPong_En) */
868 pci_write_config_word(dev, 0x54, ideconf); 896 pci_write_config_word(dev, 0x54, ideconf);
869 } 897 }
898
899 pci_write_config_byte(dev, 0x48, udma_enable);
900
901 spin_unlock_irqrestore(&piix_lock, flags);
870 } else { 902 } else {
871 /* 903 /* MWDMA is driven by the PIO timings. */
872 * MWDMA is driven by the PIO timings. We must also enable 904 unsigned int mwdma = speed - XFER_MW_DMA_0;
873 * IORDY unconditionally along with TIME1. PPE has already
874 * been set when the PIO timing was set.
875 */
876 unsigned int mwdma = adev->dma_mode - XFER_MW_DMA_0;
877 unsigned int control;
878 u8 slave_data;
879 const unsigned int needed_pio[3] = { 905 const unsigned int needed_pio[3] = {
880 XFER_PIO_0, XFER_PIO_3, XFER_PIO_4 906 XFER_PIO_0, XFER_PIO_3, XFER_PIO_4
881 }; 907 };
882 int pio = needed_pio[mwdma] - XFER_PIO_0; 908 int pio = needed_pio[mwdma] - XFER_PIO_0;
883 909
884 control = 3; /* IORDY|TIME1 */ 910 /* XFER_PIO_0 is never used currently */
885 911 piix_set_timings(ap, adev, pio);
886 /* If the drive MWDMA is faster than it can do PIO then
887 we must force PIO into PIO0 */
888
889 if (adev->pio_mode < needed_pio[mwdma])
890 /* Enable DMA timing only */
891 control |= 8; /* PIO cycles in PIO0 */
892
893 if (adev->devno) { /* Slave */
894 master_data &= 0xFF4F; /* Mask out IORDY|TIME1|DMAONLY */
895 master_data |= control << 4;
896 pci_read_config_byte(dev, 0x44, &slave_data);
897 slave_data &= (ap->port_no ? 0x0f : 0xf0);
898 /* Load the matching timing */
899 slave_data |= ((timings[pio][0] << 2) | timings[pio][1]) << (ap->port_no ? 4 : 0);
900 pci_write_config_byte(dev, 0x44, slave_data);
901 } else { /* Master */
902 master_data &= 0xCCF4; /* Mask out IORDY|TIME1|DMAONLY
903 and master timing bits */
904 master_data |= control;
905 master_data |=
906 (timings[pio][0] << 12) |
907 (timings[pio][1] << 8);
908 }
909
910 if (ap->udma_mask)
911 udma_enable &= ~(1 << devid);
912
913 pci_write_config_word(dev, master_port, master_data);
914 } 912 }
915 /* Don't scribble on 0x48 if the controller does not support UDMA */
916 if (ap->udma_mask)
917 pci_write_config_byte(dev, 0x48, udma_enable);
918
919 spin_unlock_irqrestore(&piix_lock, flags);
920} 913}
921 914
922/** 915/**
diff --git a/drivers/ata/libata-core.c b/drivers/ata/libata-core.c
index 4a3a5ae7bb45..c04ad68cb602 100644
--- a/drivers/ata/libata-core.c
+++ b/drivers/ata/libata-core.c
@@ -2938,7 +2938,7 @@ int ata_timing_compute(struct ata_device *adev, unsigned short speed,
2938 if (id[ATA_ID_FIELD_VALID] & 2) { /* EIDE drive */ 2938 if (id[ATA_ID_FIELD_VALID] & 2) { /* EIDE drive */
2939 memset(&p, 0, sizeof(p)); 2939 memset(&p, 0, sizeof(p));
2940 2940
2941 if (speed >= XFER_PIO_0 && speed <= XFER_SW_DMA_0) { 2941 if (speed >= XFER_PIO_0 && speed < XFER_SW_DMA_0) {
2942 if (speed <= XFER_PIO_2) 2942 if (speed <= XFER_PIO_2)
2943 p.cycle = p.cyc8b = id[ATA_ID_EIDE_PIO]; 2943 p.cycle = p.cyc8b = id[ATA_ID_EIDE_PIO];
2944 else if ((speed <= XFER_PIO_4) || 2944 else if ((speed <= XFER_PIO_4) ||
@@ -6713,6 +6713,7 @@ EXPORT_SYMBOL_GPL(ata_scsi_queuecmd);
6713EXPORT_SYMBOL_GPL(ata_scsi_slave_config); 6713EXPORT_SYMBOL_GPL(ata_scsi_slave_config);
6714EXPORT_SYMBOL_GPL(ata_scsi_slave_destroy); 6714EXPORT_SYMBOL_GPL(ata_scsi_slave_destroy);
6715EXPORT_SYMBOL_GPL(ata_scsi_change_queue_depth); 6715EXPORT_SYMBOL_GPL(ata_scsi_change_queue_depth);
6716EXPORT_SYMBOL_GPL(__ata_change_queue_depth);
6716EXPORT_SYMBOL_GPL(sata_scr_valid); 6717EXPORT_SYMBOL_GPL(sata_scr_valid);
6717EXPORT_SYMBOL_GPL(sata_scr_read); 6718EXPORT_SYMBOL_GPL(sata_scr_read);
6718EXPORT_SYMBOL_GPL(sata_scr_write); 6719EXPORT_SYMBOL_GPL(sata_scr_write);
diff --git a/drivers/ata/libata-eh.c b/drivers/ata/libata-eh.c
index ed16fbedaabd..a9b282038000 100644
--- a/drivers/ata/libata-eh.c
+++ b/drivers/ata/libata-eh.c
@@ -34,6 +34,7 @@
34 34
35#include <linux/kernel.h> 35#include <linux/kernel.h>
36#include <linux/blkdev.h> 36#include <linux/blkdev.h>
37#include <linux/export.h>
37#include <linux/pci.h> 38#include <linux/pci.h>
38#include <scsi/scsi.h> 39#include <scsi/scsi.h>
39#include <scsi/scsi_host.h> 40#include <scsi/scsi_host.h>
@@ -2532,8 +2533,7 @@ static int ata_do_reset(struct ata_link *link, ata_reset_fn_t reset,
2532 return reset(link, classes, deadline); 2533 return reset(link, classes, deadline);
2533} 2534}
2534 2535
2535static int ata_eh_followup_srst_needed(struct ata_link *link, 2536static int ata_eh_followup_srst_needed(struct ata_link *link, int rc)
2536 int rc, const unsigned int *classes)
2537{ 2537{
2538 if ((link->flags & ATA_LFLAG_NO_SRST) || ata_link_offline(link)) 2538 if ((link->flags & ATA_LFLAG_NO_SRST) || ata_link_offline(link))
2539 return 0; 2539 return 0;
@@ -2726,7 +2726,7 @@ int ata_eh_reset(struct ata_link *link, int classify,
2726 2726
2727 /* perform follow-up SRST if necessary */ 2727 /* perform follow-up SRST if necessary */
2728 if (reset == hardreset && 2728 if (reset == hardreset &&
2729 ata_eh_followup_srst_needed(link, rc, classes)) { 2729 ata_eh_followup_srst_needed(link, rc)) {
2730 reset = softreset; 2730 reset = softreset;
2731 2731
2732 if (!reset) { 2732 if (!reset) {
@@ -2883,7 +2883,7 @@ int ata_eh_reset(struct ata_link *link, int classify,
2883 sata_scr_read(link, SCR_STATUS, &sstatus)) 2883 sata_scr_read(link, SCR_STATUS, &sstatus))
2884 rc = -ERESTART; 2884 rc = -ERESTART;
2885 2885
2886 if (rc == -ERESTART || try >= max_tries) { 2886 if (try >= max_tries) {
2887 /* 2887 /*
2888 * Thaw host port even if reset failed, so that the port 2888 * Thaw host port even if reset failed, so that the port
2889 * can be retried on the next phy event. This risks 2889 * can be retried on the next phy event. This risks
@@ -2909,6 +2909,16 @@ int ata_eh_reset(struct ata_link *link, int classify,
2909 ata_eh_acquire(ap); 2909 ata_eh_acquire(ap);
2910 } 2910 }
2911 2911
2912 /*
2913 * While disks spinup behind PMP, some controllers fail sending SRST.
2914 * They need to be reset - as well as the PMP - before retrying.
2915 */
2916 if (rc == -ERESTART) {
2917 if (ata_is_host_link(link))
2918 ata_eh_thaw_port(ap);
2919 goto out;
2920 }
2921
2912 if (try == max_tries - 1) { 2922 if (try == max_tries - 1) {
2913 sata_down_spd_limit(link, 0); 2923 sata_down_spd_limit(link, 0);
2914 if (slave) 2924 if (slave)
diff --git a/drivers/ata/libata-pmp.c b/drivers/ata/libata-pmp.c
index 3eb2b816eb2a..21b80c555c60 100644
--- a/drivers/ata/libata-pmp.c
+++ b/drivers/ata/libata-pmp.c
@@ -8,6 +8,7 @@
8 */ 8 */
9 9
10#include <linux/kernel.h> 10#include <linux/kernel.h>
11#include <linux/export.h>
11#include <linux/libata.h> 12#include <linux/libata.h>
12#include <linux/slab.h> 13#include <linux/slab.h>
13#include "libata.h" 14#include "libata.h"
@@ -388,12 +389,9 @@ static void sata_pmp_quirks(struct ata_port *ap)
388 /* link reports offline after LPM */ 389 /* link reports offline after LPM */
389 link->flags |= ATA_LFLAG_NO_LPM; 390 link->flags |= ATA_LFLAG_NO_LPM;
390 391
391 /* Class code report is unreliable and SRST 392 /* Class code report is unreliable. */
392 * times out under certain configurations.
393 */
394 if (link->pmp < 5) 393 if (link->pmp < 5)
395 link->flags |= ATA_LFLAG_NO_SRST | 394 link->flags |= ATA_LFLAG_ASSUME_ATA;
396 ATA_LFLAG_ASSUME_ATA;
397 395
398 /* port 5 is for SEMB device and it doesn't like SRST */ 396 /* port 5 is for SEMB device and it doesn't like SRST */
399 if (link->pmp == 5) 397 if (link->pmp == 5)
diff --git a/drivers/ata/libata-scsi.c b/drivers/ata/libata-scsi.c
index 46d087f08607..2a5412e7e9c1 100644
--- a/drivers/ata/libata-scsi.c
+++ b/drivers/ata/libata-scsi.c
@@ -37,6 +37,7 @@
37#include <linux/kernel.h> 37#include <linux/kernel.h>
38#include <linux/blkdev.h> 38#include <linux/blkdev.h>
39#include <linux/spinlock.h> 39#include <linux/spinlock.h>
40#include <linux/export.h>
40#include <scsi/scsi.h> 41#include <scsi/scsi.h>
41#include <scsi/scsi_host.h> 42#include <scsi/scsi_host.h>
42#include <scsi/scsi_cmnd.h> 43#include <scsi/scsi_cmnd.h>
@@ -1215,25 +1216,19 @@ void ata_scsi_slave_destroy(struct scsi_device *sdev)
1215} 1216}
1216 1217
1217/** 1218/**
1218 * ata_scsi_change_queue_depth - SCSI callback for queue depth config 1219 * __ata_change_queue_depth - helper for ata_scsi_change_queue_depth
1220 * @ap: ATA port to which the device change the queue depth
1219 * @sdev: SCSI device to configure queue depth for 1221 * @sdev: SCSI device to configure queue depth for
1220 * @queue_depth: new queue depth 1222 * @queue_depth: new queue depth
1221 * @reason: calling context 1223 * @reason: calling context
1222 * 1224 *
1223 * This is libata standard hostt->change_queue_depth callback. 1225 * libsas and libata have different approaches for associating a sdev to
1224 * SCSI will call into this callback when user tries to set queue 1226 * its ata_port.
1225 * depth via sysfs.
1226 * 1227 *
1227 * LOCKING:
1228 * SCSI layer (we don't care)
1229 *
1230 * RETURNS:
1231 * Newly configured queue depth.
1232 */ 1228 */
1233int ata_scsi_change_queue_depth(struct scsi_device *sdev, int queue_depth, 1229int __ata_change_queue_depth(struct ata_port *ap, struct scsi_device *sdev,
1234 int reason) 1230 int queue_depth, int reason)
1235{ 1231{
1236 struct ata_port *ap = ata_shost_to_port(sdev->host);
1237 struct ata_device *dev; 1232 struct ata_device *dev;
1238 unsigned long flags; 1233 unsigned long flags;
1239 1234
@@ -1269,6 +1264,30 @@ int ata_scsi_change_queue_depth(struct scsi_device *sdev, int queue_depth,
1269} 1264}
1270 1265
1271/** 1266/**
1267 * ata_scsi_change_queue_depth - SCSI callback for queue depth config
1268 * @sdev: SCSI device to configure queue depth for
1269 * @queue_depth: new queue depth
1270 * @reason: calling context
1271 *
1272 * This is libata standard hostt->change_queue_depth callback.
1273 * SCSI will call into this callback when user tries to set queue
1274 * depth via sysfs.
1275 *
1276 * LOCKING:
1277 * SCSI layer (we don't care)
1278 *
1279 * RETURNS:
1280 * Newly configured queue depth.
1281 */
1282int ata_scsi_change_queue_depth(struct scsi_device *sdev, int queue_depth,
1283 int reason)
1284{
1285 struct ata_port *ap = ata_shost_to_port(sdev->host);
1286
1287 return __ata_change_queue_depth(ap, sdev, queue_depth, reason);
1288}
1289
1290/**
1272 * ata_scsi_start_stop_xlat - Translate SCSI START STOP UNIT command 1291 * ata_scsi_start_stop_xlat - Translate SCSI START STOP UNIT command
1273 * @qc: Storage for translated ATA taskfile 1292 * @qc: Storage for translated ATA taskfile
1274 * 1293 *
diff --git a/drivers/ata/libata-sff.c b/drivers/ata/libata-sff.c
index c24127dd6ef2..4cadfa28f940 100644
--- a/drivers/ata/libata-sff.c
+++ b/drivers/ata/libata-sff.c
@@ -35,6 +35,7 @@
35#include <linux/kernel.h> 35#include <linux/kernel.h>
36#include <linux/gfp.h> 36#include <linux/gfp.h>
37#include <linux/pci.h> 37#include <linux/pci.h>
38#include <linux/module.h>
38#include <linux/libata.h> 39#include <linux/libata.h>
39#include <linux/highmem.h> 40#include <linux/highmem.h>
40 41
@@ -569,7 +570,7 @@ unsigned int ata_sff_data_xfer(struct ata_device *dev, unsigned char *buf,
569 570
570 /* Transfer trailing byte, if any. */ 571 /* Transfer trailing byte, if any. */
571 if (unlikely(buflen & 0x01)) { 572 if (unlikely(buflen & 0x01)) {
572 unsigned char pad[2]; 573 unsigned char pad[2] = { };
573 574
574 /* Point buf to the tail of buffer */ 575 /* Point buf to the tail of buffer */
575 buf += buflen - 1; 576 buf += buflen - 1;
@@ -628,7 +629,7 @@ unsigned int ata_sff_data_xfer32(struct ata_device *dev, unsigned char *buf,
628 629
629 /* Transfer trailing bytes, if any */ 630 /* Transfer trailing bytes, if any */
630 if (unlikely(slop)) { 631 if (unlikely(slop)) {
631 unsigned char pad[4]; 632 unsigned char pad[4] = { };
632 633
633 /* Point buf to the tail of buffer */ 634 /* Point buf to the tail of buffer */
634 buf += buflen - slop; 635 buf += buflen - slop;
@@ -678,7 +679,7 @@ unsigned int ata_sff_data_xfer_noirq(struct ata_device *dev, unsigned char *buf,
678 unsigned int consumed; 679 unsigned int consumed;
679 680
680 local_irq_save(flags); 681 local_irq_save(flags);
681 consumed = ata_sff_data_xfer(dev, buf, buflen, rw); 682 consumed = ata_sff_data_xfer32(dev, buf, buflen, rw);
682 local_irq_restore(flags); 683 local_irq_restore(flags);
683 684
684 return consumed; 685 return consumed;
@@ -2507,31 +2508,10 @@ static const struct ata_port_info *ata_sff_find_valid_pi(
2507 return NULL; 2508 return NULL;
2508} 2509}
2509 2510
2510/** 2511static int ata_pci_init_one(struct pci_dev *pdev,
2511 * ata_pci_sff_init_one - Initialize/register PIO-only PCI IDE controller 2512 const struct ata_port_info * const *ppi,
2512 * @pdev: Controller to be initialized 2513 struct scsi_host_template *sht, void *host_priv,
2513 * @ppi: array of port_info, must be enough for two ports 2514 int hflags, bool bmdma)
2514 * @sht: scsi_host_template to use when registering the host
2515 * @host_priv: host private_data
2516 * @hflag: host flags
2517 *
2518 * This is a helper function which can be called from a driver's
2519 * xxx_init_one() probe function if the hardware uses traditional
2520 * IDE taskfile registers and is PIO only.
2521 *
2522 * ASSUMPTION:
2523 * Nobody makes a single channel controller that appears solely as
2524 * the secondary legacy port on PCI.
2525 *
2526 * LOCKING:
2527 * Inherited from PCI layer (may sleep).
2528 *
2529 * RETURNS:
2530 * Zero on success, negative on errno-based value on error.
2531 */
2532int ata_pci_sff_init_one(struct pci_dev *pdev,
2533 const struct ata_port_info * const *ppi,
2534 struct scsi_host_template *sht, void *host_priv, int hflag)
2535{ 2515{
2536 struct device *dev = &pdev->dev; 2516 struct device *dev = &pdev->dev;
2537 const struct ata_port_info *pi; 2517 const struct ata_port_info *pi;
@@ -2553,14 +2533,26 @@ int ata_pci_sff_init_one(struct pci_dev *pdev,
2553 if (rc) 2533 if (rc)
2554 goto out; 2534 goto out;
2555 2535
2556 /* prepare and activate SFF host */ 2536#ifdef CONFIG_ATA_BMDMA
2557 rc = ata_pci_sff_prepare_host(pdev, ppi, &host); 2537 if (bmdma)
2538 /* prepare and activate BMDMA host */
2539 rc = ata_pci_bmdma_prepare_host(pdev, ppi, &host);
2540 else
2541#endif
2542 /* prepare and activate SFF host */
2543 rc = ata_pci_sff_prepare_host(pdev, ppi, &host);
2558 if (rc) 2544 if (rc)
2559 goto out; 2545 goto out;
2560 host->private_data = host_priv; 2546 host->private_data = host_priv;
2561 host->flags |= hflag; 2547 host->flags |= hflags;
2562 2548
2563 rc = ata_pci_sff_activate_host(host, ata_sff_interrupt, sht); 2549#ifdef CONFIG_ATA_BMDMA
2550 if (bmdma) {
2551 pci_set_master(pdev);
2552 rc = ata_pci_sff_activate_host(host, ata_bmdma_interrupt, sht);
2553 } else
2554#endif
2555 rc = ata_pci_sff_activate_host(host, ata_sff_interrupt, sht);
2564out: 2556out:
2565 if (rc == 0) 2557 if (rc == 0)
2566 devres_remove_group(&pdev->dev, NULL); 2558 devres_remove_group(&pdev->dev, NULL);
@@ -2569,6 +2561,35 @@ out:
2569 2561
2570 return rc; 2562 return rc;
2571} 2563}
2564
2565/**
2566 * ata_pci_sff_init_one - Initialize/register PIO-only PCI IDE controller
2567 * @pdev: Controller to be initialized
2568 * @ppi: array of port_info, must be enough for two ports
2569 * @sht: scsi_host_template to use when registering the host
2570 * @host_priv: host private_data
2571 * @hflag: host flags
2572 *
2573 * This is a helper function which can be called from a driver's
2574 * xxx_init_one() probe function if the hardware uses traditional
2575 * IDE taskfile registers and is PIO only.
2576 *
2577 * ASSUMPTION:
2578 * Nobody makes a single channel controller that appears solely as
2579 * the secondary legacy port on PCI.
2580 *
2581 * LOCKING:
2582 * Inherited from PCI layer (may sleep).
2583 *
2584 * RETURNS:
2585 * Zero on success, negative on errno-based value on error.
2586 */
2587int ata_pci_sff_init_one(struct pci_dev *pdev,
2588 const struct ata_port_info * const *ppi,
2589 struct scsi_host_template *sht, void *host_priv, int hflag)
2590{
2591 return ata_pci_init_one(pdev, ppi, sht, host_priv, hflag, 0);
2592}
2572EXPORT_SYMBOL_GPL(ata_pci_sff_init_one); 2593EXPORT_SYMBOL_GPL(ata_pci_sff_init_one);
2573 2594
2574#endif /* CONFIG_PCI */ 2595#endif /* CONFIG_PCI */
@@ -3286,42 +3307,7 @@ int ata_pci_bmdma_init_one(struct pci_dev *pdev,
3286 struct scsi_host_template *sht, void *host_priv, 3307 struct scsi_host_template *sht, void *host_priv,
3287 int hflags) 3308 int hflags)
3288{ 3309{
3289 struct device *dev = &pdev->dev; 3310 return ata_pci_init_one(pdev, ppi, sht, host_priv, hflags, 1);
3290 const struct ata_port_info *pi;
3291 struct ata_host *host = NULL;
3292 int rc;
3293
3294 DPRINTK("ENTER\n");
3295
3296 pi = ata_sff_find_valid_pi(ppi);
3297 if (!pi) {
3298 dev_err(&pdev->dev, "no valid port_info specified\n");
3299 return -EINVAL;
3300 }
3301
3302 if (!devres_open_group(dev, NULL, GFP_KERNEL))
3303 return -ENOMEM;
3304
3305 rc = pcim_enable_device(pdev);
3306 if (rc)
3307 goto out;
3308
3309 /* prepare and activate BMDMA host */
3310 rc = ata_pci_bmdma_prepare_host(pdev, ppi, &host);
3311 if (rc)
3312 goto out;
3313 host->private_data = host_priv;
3314 host->flags |= hflags;
3315
3316 pci_set_master(pdev);
3317 rc = ata_pci_sff_activate_host(host, ata_bmdma_interrupt, sht);
3318 out:
3319 if (rc == 0)
3320 devres_remove_group(&pdev->dev, NULL);
3321 else
3322 devres_release_group(&pdev->dev, NULL);
3323
3324 return rc;
3325} 3311}
3326EXPORT_SYMBOL_GPL(ata_pci_bmdma_init_one); 3312EXPORT_SYMBOL_GPL(ata_pci_bmdma_init_one);
3327 3313
diff --git a/drivers/ata/pata_ali.c b/drivers/ata/pata_ali.c
index cadd67998bac..61da0694aecd 100644
--- a/drivers/ata/pata_ali.c
+++ b/drivers/ata/pata_ali.c
@@ -56,7 +56,7 @@ static const struct dmi_system_id cable_dmi_table[] = {
56 }, 56 },
57 }, 57 },
58 { 58 {
59 .ident = "Toshiba Satelite S1800-814", 59 .ident = "Toshiba Satellite S1800-814",
60 .matches = { 60 .matches = {
61 DMI_MATCH(DMI_SYS_VENDOR, "TOSHIBA"), 61 DMI_MATCH(DMI_SYS_VENDOR, "TOSHIBA"),
62 DMI_MATCH(DMI_PRODUCT_NAME, "S1800-814"), 62 DMI_MATCH(DMI_PRODUCT_NAME, "S1800-814"),
diff --git a/drivers/ata/pata_arasan_cf.c b/drivers/ata/pata_arasan_cf.c
index 719bb73a73e0..e8574bba3ee4 100644
--- a/drivers/ata/pata_arasan_cf.c
+++ b/drivers/ata/pata_arasan_cf.c
@@ -922,8 +922,7 @@ static int __devexit arasan_cf_remove(struct platform_device *pdev)
922#ifdef CONFIG_PM 922#ifdef CONFIG_PM
923static int arasan_cf_suspend(struct device *dev) 923static int arasan_cf_suspend(struct device *dev)
924{ 924{
925 struct platform_device *pdev = to_platform_device(dev); 925 struct ata_host *host = dev_get_drvdata(dev);
926 struct ata_host *host = dev_get_drvdata(&pdev->dev);
927 struct arasan_cf_dev *acdev = host->ports[0]->private_data; 926 struct arasan_cf_dev *acdev = host->ports[0]->private_data;
928 927
929 if (acdev->dma_chan) { 928 if (acdev->dma_chan) {
@@ -937,8 +936,7 @@ static int arasan_cf_suspend(struct device *dev)
937 936
938static int arasan_cf_resume(struct device *dev) 937static int arasan_cf_resume(struct device *dev)
939{ 938{
940 struct platform_device *pdev = to_platform_device(dev); 939 struct ata_host *host = dev_get_drvdata(dev);
941 struct ata_host *host = dev_get_drvdata(&pdev->dev);
942 struct arasan_cf_dev *acdev = host->ports[0]->private_data; 940 struct arasan_cf_dev *acdev = host->ports[0]->private_data;
943 941
944 cf_init(acdev); 942 cf_init(acdev);
diff --git a/drivers/ata/pata_artop.c b/drivers/ata/pata_artop.c
index 78a93b690959..4b8b22efc00b 100644
--- a/drivers/ata/pata_artop.c
+++ b/drivers/ata/pata_artop.c
@@ -2,7 +2,7 @@
2 * pata_artop.c - ARTOP ATA controller driver 2 * pata_artop.c - ARTOP ATA controller driver
3 * 3 *
4 * (C) 2006 Red Hat 4 * (C) 2006 Red Hat
5 * (C) 2007 Bartlomiej Zolnierkiewicz 5 * (C) 2007,2011 Bartlomiej Zolnierkiewicz
6 * 6 *
7 * Based in part on drivers/ide/pci/aec62xx.c 7 * Based in part on drivers/ide/pci/aec62xx.c
8 * Copyright (C) 1999-2002 Andre Hedrick <andre@linux-ide.org> 8 * Copyright (C) 1999-2002 Andre Hedrick <andre@linux-ide.org>
@@ -28,7 +28,7 @@
28#include <linux/ata.h> 28#include <linux/ata.h>
29 29
30#define DRV_NAME "pata_artop" 30#define DRV_NAME "pata_artop"
31#define DRV_VERSION "0.4.5" 31#define DRV_VERSION "0.4.6"
32 32
33/* 33/*
34 * The ARTOP has 33 Mhz and "over clocked" timing tables. Until we 34 * The ARTOP has 33 Mhz and "over clocked" timing tables. Until we
@@ -39,31 +39,15 @@
39 39
40static int clock = 0; 40static int clock = 0;
41 41
42static int artop6210_pre_reset(struct ata_link *link, unsigned long deadline)
43{
44 struct ata_port *ap = link->ap;
45 struct pci_dev *pdev = to_pci_dev(ap->host->dev);
46 const struct pci_bits artop_enable_bits[] = {
47 { 0x4AU, 1U, 0x02UL, 0x02UL }, /* port 0 */
48 { 0x4AU, 1U, 0x04UL, 0x04UL }, /* port 1 */
49 };
50
51 if (!pci_test_config_bits(pdev, &artop_enable_bits[ap->port_no]))
52 return -ENOENT;
53
54 return ata_sff_prereset(link, deadline);
55}
56
57/** 42/**
58 * artop6260_pre_reset - check for 40/80 pin 43 * artop62x0_pre_reset - probe begin
59 * @link: link 44 * @link: link
60 * @deadline: deadline jiffies for the operation 45 * @deadline: deadline jiffies for the operation
61 * 46 *
62 * The ARTOP hardware reports the cable detect bits in register 0x49.
63 * Nothing complicated needed here. 47 * Nothing complicated needed here.
64 */ 48 */
65 49
66static int artop6260_pre_reset(struct ata_link *link, unsigned long deadline) 50static int artop62x0_pre_reset(struct ata_link *link, unsigned long deadline)
67{ 51{
68 static const struct pci_bits artop_enable_bits[] = { 52 static const struct pci_bits artop_enable_bits[] = {
69 { 0x4AU, 1U, 0x02UL, 0x02UL }, /* port 0 */ 53 { 0x4AU, 1U, 0x02UL, 0x02UL }, /* port 0 */
@@ -73,7 +57,7 @@ static int artop6260_pre_reset(struct ata_link *link, unsigned long deadline)
73 struct ata_port *ap = link->ap; 57 struct ata_port *ap = link->ap;
74 struct pci_dev *pdev = to_pci_dev(ap->host->dev); 58 struct pci_dev *pdev = to_pci_dev(ap->host->dev);
75 59
76 /* Odd numbered device ids are the units with enable bits (the -R cards) */ 60 /* Odd numbered device ids are the units with enable bits. */
77 if ((pdev->device & 1) && 61 if ((pdev->device & 1) &&
78 !pci_test_config_bits(pdev, &artop_enable_bits[ap->port_no])) 62 !pci_test_config_bits(pdev, &artop_enable_bits[ap->port_no]))
79 return -ENOENT; 63 return -ENOENT;
@@ -317,7 +301,7 @@ static struct ata_port_operations artop6210_ops = {
317 .cable_detect = ata_cable_40wire, 301 .cable_detect = ata_cable_40wire,
318 .set_piomode = artop6210_set_piomode, 302 .set_piomode = artop6210_set_piomode,
319 .set_dmamode = artop6210_set_dmamode, 303 .set_dmamode = artop6210_set_dmamode,
320 .prereset = artop6210_pre_reset, 304 .prereset = artop62x0_pre_reset,
321 .qc_defer = artop6210_qc_defer, 305 .qc_defer = artop6210_qc_defer,
322}; 306};
323 307
@@ -326,9 +310,36 @@ static struct ata_port_operations artop6260_ops = {
326 .cable_detect = artop6260_cable_detect, 310 .cable_detect = artop6260_cable_detect,
327 .set_piomode = artop6260_set_piomode, 311 .set_piomode = artop6260_set_piomode,
328 .set_dmamode = artop6260_set_dmamode, 312 .set_dmamode = artop6260_set_dmamode,
329 .prereset = artop6260_pre_reset, 313 .prereset = artop62x0_pre_reset,
330}; 314};
331 315
316static void atp8xx_fixup(struct pci_dev *pdev)
317{
318 if (pdev->device == 0x0005)
319 /* BIOS may have left us in UDMA, clear it before libata probe */
320 pci_write_config_byte(pdev, 0x54, 0);
321 else if (pdev->device == 0x0008 || pdev->device == 0x0009) {
322 u8 reg;
323
324 /* Mac systems come up with some registers not set as we
325 will need them */
326
327 /* Clear reset & test bits */
328 pci_read_config_byte(pdev, 0x49, &reg);
329 pci_write_config_byte(pdev, 0x49, reg & ~0x30);
330
331 /* PCI latency must be > 0x80 for burst mode, tweak it
332 * if required.
333 */
334 pci_read_config_byte(pdev, PCI_LATENCY_TIMER, &reg);
335 if (reg <= 0x80)
336 pci_write_config_byte(pdev, PCI_LATENCY_TIMER, 0x90);
337
338 /* Enable IRQ output and burst mode */
339 pci_read_config_byte(pdev, 0x4a, &reg);
340 pci_write_config_byte(pdev, 0x4a, (reg & ~0x01) | 0x80);
341 }
342}
332 343
333/** 344/**
334 * artop_init_one - Register ARTOP ATA PCI device with kernel services 345 * artop_init_one - Register ARTOP ATA PCI device with kernel services
@@ -383,42 +394,22 @@ static int artop_init_one (struct pci_dev *pdev, const struct pci_device_id *id)
383 if (rc) 394 if (rc)
384 return rc; 395 return rc;
385 396
386 if (id->driver_data == 0) { /* 6210 variant */ 397 if (id->driver_data == 0) /* 6210 variant */
387 ppi[0] = &info_6210; 398 ppi[0] = &info_6210;
388 /* BIOS may have left us in UDMA, clear it before libata probe */
389 pci_write_config_byte(pdev, 0x54, 0);
390 }
391 else if (id->driver_data == 1) /* 6260 */ 399 else if (id->driver_data == 1) /* 6260 */
392 ppi[0] = &info_626x; 400 ppi[0] = &info_626x;
393 else if (id->driver_data == 2) { /* 6280 or 6280 + fast */ 401 else if (id->driver_data == 2) { /* 6280 or 6280 + fast */
394 unsigned long io = pci_resource_start(pdev, 4); 402 unsigned long io = pci_resource_start(pdev, 4);
395 u8 reg;
396 403
397 ppi[0] = &info_628x; 404 ppi[0] = &info_628x;
398 if (inb(io) & 0x10) 405 if (inb(io) & 0x10)
399 ppi[0] = &info_628x_fast; 406 ppi[0] = &info_628x_fast;
400 /* Mac systems come up with some registers not set as we
401 will need them */
402
403 /* Clear reset & test bits */
404 pci_read_config_byte(pdev, 0x49, &reg);
405 pci_write_config_byte(pdev, 0x49, reg & ~ 0x30);
406
407 /* PCI latency must be > 0x80 for burst mode, tweak it
408 * if required.
409 */
410 pci_read_config_byte(pdev, PCI_LATENCY_TIMER, &reg);
411 if (reg <= 0x80)
412 pci_write_config_byte(pdev, PCI_LATENCY_TIMER, 0x90);
413
414 /* Enable IRQ output and burst mode */
415 pci_read_config_byte(pdev, 0x4a, &reg);
416 pci_write_config_byte(pdev, 0x4a, (reg & ~0x01) | 0x80);
417
418 } 407 }
419 408
420 BUG_ON(ppi[0] == NULL); 409 BUG_ON(ppi[0] == NULL);
421 410
411 atp8xx_fixup(pdev);
412
422 return ata_pci_bmdma_init_one(pdev, ppi, &artop_sht, NULL, 0); 413 return ata_pci_bmdma_init_one(pdev, ppi, &artop_sht, NULL, 0);
423} 414}
424 415
@@ -432,11 +423,32 @@ static const struct pci_device_id artop_pci_tbl[] = {
432 { } /* terminate list */ 423 { } /* terminate list */
433}; 424};
434 425
426#ifdef CONFIG_PM
427static int atp8xx_reinit_one(struct pci_dev *pdev)
428{
429 struct ata_host *host = dev_get_drvdata(&pdev->dev);
430 int rc;
431
432 rc = ata_pci_device_do_resume(pdev);
433 if (rc)
434 return rc;
435
436 atp8xx_fixup(pdev);
437
438 ata_host_resume(host);
439 return 0;
440}
441#endif
442
435static struct pci_driver artop_pci_driver = { 443static struct pci_driver artop_pci_driver = {
436 .name = DRV_NAME, 444 .name = DRV_NAME,
437 .id_table = artop_pci_tbl, 445 .id_table = artop_pci_tbl,
438 .probe = artop_init_one, 446 .probe = artop_init_one,
439 .remove = ata_pci_remove_one, 447 .remove = ata_pci_remove_one,
448#ifdef CONFIG_PM
449 .suspend = ata_pci_device_suspend,
450 .resume = atp8xx_reinit_one,
451#endif
440}; 452};
441 453
442static int __init artop_init(void) 454static int __init artop_init(void)
@@ -452,9 +464,8 @@ static void __exit artop_exit(void)
452module_init(artop_init); 464module_init(artop_init);
453module_exit(artop_exit); 465module_exit(artop_exit);
454 466
455MODULE_AUTHOR("Alan Cox"); 467MODULE_AUTHOR("Alan Cox, Bartlomiej Zolnierkiewicz");
456MODULE_DESCRIPTION("SCSI low-level driver for ARTOP PATA"); 468MODULE_DESCRIPTION("SCSI low-level driver for ARTOP PATA");
457MODULE_LICENSE("GPL"); 469MODULE_LICENSE("GPL");
458MODULE_DEVICE_TABLE(pci, artop_pci_tbl); 470MODULE_DEVICE_TABLE(pci, artop_pci_tbl);
459MODULE_VERSION(DRV_VERSION); 471MODULE_VERSION(DRV_VERSION);
460
diff --git a/drivers/ata/pata_at91.c b/drivers/ata/pata_at91.c
index 960c72571395..a76f24a8e5db 100644
--- a/drivers/ata/pata_at91.c
+++ b/drivers/ata/pata_at91.c
@@ -30,7 +30,7 @@
30 30
31#include <mach/at91sam9_smc.h> 31#include <mach/at91sam9_smc.h>
32#include <mach/board.h> 32#include <mach/board.h>
33#include <mach/gpio.h> 33#include <asm/gpio.h>
34 34
35#define DRV_NAME "pata_at91" 35#define DRV_NAME "pata_at91"
36#define DRV_VERSION "0.3" 36#define DRV_VERSION "0.3"
@@ -414,10 +414,13 @@ static int __devinit pata_at91_probe(struct platform_device *pdev)
414 414
415 host->private_data = info; 415 host->private_data = info;
416 416
417 return ata_host_activate(host, irq ? gpio_to_irq(irq) : 0, 417 ret = ata_host_activate(host, irq ? gpio_to_irq(irq) : 0,
418 irq ? ata_sff_interrupt : NULL, 418 irq ? ata_sff_interrupt : NULL,
419 irq_flags, &pata_at91_sht); 419 irq_flags, &pata_at91_sht);
420 420
421 if (!ret)
422 return 0;
423
421err_put: 424err_put:
422 clk_put(info->mck); 425 clk_put(info->mck);
423 return ret; 426 return ret;
diff --git a/drivers/ata/pata_atiixp.c b/drivers/ata/pata_atiixp.c
index 43755616dc5a..be1aa1486d39 100644
--- a/drivers/ata/pata_atiixp.c
+++ b/drivers/ata/pata_atiixp.c
@@ -49,6 +49,31 @@ static int atiixp_cable_detect(struct ata_port *ap)
49static DEFINE_SPINLOCK(atiixp_lock); 49static DEFINE_SPINLOCK(atiixp_lock);
50 50
51/** 51/**
52 * atiixp_prereset - perform reset handling
53 * @link: ATA link
54 * @deadline: deadline jiffies for the operation
55 *
56 * Reset sequence checking enable bits to see which ports are
57 * active.
58 */
59
60static int atiixp_prereset(struct ata_link *link, unsigned long deadline)
61{
62 static const struct pci_bits atiixp_enable_bits[] = {
63 { 0x48, 1, 0x01, 0x00 },
64 { 0x48, 1, 0x08, 0x00 }
65 };
66
67 struct ata_port *ap = link->ap;
68 struct pci_dev *pdev = to_pci_dev(ap->host->dev);
69
70 if (!pci_test_config_bits(pdev, &atiixp_enable_bits[ap->port_no]))
71 return -ENOENT;
72
73 return ata_sff_prereset(link, deadline);
74}
75
76/**
52 * atiixp_set_pio_timing - set initial PIO mode data 77 * atiixp_set_pio_timing - set initial PIO mode data
53 * @ap: ATA interface 78 * @ap: ATA interface
54 * @adev: ATA device 79 * @adev: ATA device
@@ -221,6 +246,7 @@ static struct ata_port_operations atiixp_port_ops = {
221 .bmdma_start = atiixp_bmdma_start, 246 .bmdma_start = atiixp_bmdma_start,
222 .bmdma_stop = atiixp_bmdma_stop, 247 .bmdma_stop = atiixp_bmdma_stop,
223 248
249 .prereset = atiixp_prereset,
224 .cable_detect = atiixp_cable_detect, 250 .cable_detect = atiixp_cable_detect,
225 .set_piomode = atiixp_set_piomode, 251 .set_piomode = atiixp_set_piomode,
226 .set_dmamode = atiixp_set_dmamode, 252 .set_dmamode = atiixp_set_dmamode,
@@ -235,16 +261,7 @@ static int atiixp_init_one(struct pci_dev *pdev, const struct pci_device_id *id)
235 .udma_mask = ATA_UDMA5, 261 .udma_mask = ATA_UDMA5,
236 .port_ops = &atiixp_port_ops 262 .port_ops = &atiixp_port_ops
237 }; 263 };
238 static const struct pci_bits atiixp_enable_bits[] = {
239 { 0x48, 1, 0x01, 0x00 },
240 { 0x48, 1, 0x08, 0x00 }
241 };
242 const struct ata_port_info *ppi[] = { &info, &info }; 264 const struct ata_port_info *ppi[] = { &info, &info };
243 int i;
244
245 for (i = 0; i < 2; i++)
246 if (!pci_test_config_bits(pdev, &atiixp_enable_bits[i]))
247 ppi[i] = &ata_dummy_port_info;
248 265
249 return ata_pci_bmdma_init_one(pdev, ppi, &atiixp_sht, NULL, 266 return ata_pci_bmdma_init_one(pdev, ppi, &atiixp_sht, NULL,
250 ATA_HOST_PARALLEL_SCAN); 267 ATA_HOST_PARALLEL_SCAN);
diff --git a/drivers/ata/pata_cmd64x.c b/drivers/ata/pata_cmd64x.c
index 7bafc16cf5e0..e1fb39a74ce1 100644
--- a/drivers/ata/pata_cmd64x.c
+++ b/drivers/ata/pata_cmd64x.c
@@ -82,7 +82,7 @@ static int cmd648_cable_detect(struct ata_port *ap)
82} 82}
83 83
84/** 84/**
85 * cmd64x_set_piomode - set PIO and MWDMA timing 85 * cmd64x_set_timing - set PIO and MWDMA timing
86 * @ap: ATA interface 86 * @ap: ATA interface
87 * @adev: ATA device 87 * @adev: ATA device
88 * @mode: mode 88 * @mode: mode
@@ -288,6 +288,22 @@ static struct ata_port_operations cmd648_port_ops = {
288 .cable_detect = cmd648_cable_detect, 288 .cable_detect = cmd648_cable_detect,
289}; 289};
290 290
291static void cmd64x_fixup(struct pci_dev *pdev)
292{
293 u8 mrdmode;
294
295 pci_write_config_byte(pdev, PCI_LATENCY_TIMER, 64);
296 pci_read_config_byte(pdev, MRDMODE, &mrdmode);
297 mrdmode &= ~0x30; /* IRQ set up */
298 mrdmode |= 0x02; /* Memory read line enable */
299 pci_write_config_byte(pdev, MRDMODE, mrdmode);
300
301 /* PPC specific fixup copied from old driver */
302#ifdef CONFIG_PPC
303 pci_write_config_byte(pdev, UDIDETCR0, 0xF0);
304#endif
305}
306
291static int cmd64x_init_one(struct pci_dev *pdev, const struct pci_device_id *id) 307static int cmd64x_init_one(struct pci_dev *pdev, const struct pci_device_id *id)
292{ 308{
293 static const struct ata_port_info cmd_info[6] = { 309 static const struct ata_port_info cmd_info[6] = {
@@ -336,7 +352,7 @@ static int cmd64x_init_one(struct pci_dev *pdev, const struct pci_device_id *id)
336 &cmd_info[id->driver_data], 352 &cmd_info[id->driver_data],
337 NULL 353 NULL
338 }; 354 };
339 u8 mrdmode, reg; 355 u8 reg;
340 int rc; 356 int rc;
341 struct pci_dev *bridge = pdev->bus->self; 357 struct pci_dev *bridge = pdev->bus->self;
342 /* mobility split bridges don't report enabled ports correctly */ 358 /* mobility split bridges don't report enabled ports correctly */
@@ -368,11 +384,7 @@ static int cmd64x_init_one(struct pci_dev *pdev, const struct pci_device_id *id)
368 cntrl_ch0_ok = 0; 384 cntrl_ch0_ok = 0;
369 } 385 }
370 386
371 pci_write_config_byte(pdev, PCI_LATENCY_TIMER, 64); 387 cmd64x_fixup(pdev);
372 pci_read_config_byte(pdev, MRDMODE, &mrdmode);
373 mrdmode &= ~ 0x30; /* IRQ set up */
374 mrdmode |= 0x02; /* Memory read line enable */
375 pci_write_config_byte(pdev, MRDMODE, mrdmode);
376 388
377 /* check for enabled ports */ 389 /* check for enabled ports */
378 pci_read_config_byte(pdev, CNTRL, &reg); 390 pci_read_config_byte(pdev, CNTRL, &reg);
@@ -388,13 +400,6 @@ static int cmd64x_init_one(struct pci_dev *pdev, const struct pci_device_id *id)
388 ppi[1] = &ata_dummy_port_info; 400 ppi[1] = &ata_dummy_port_info;
389 } 401 }
390 402
391 /* Force PIO 0 here.. */
392
393 /* PPC specific fixup copied from old driver */
394#ifdef CONFIG_PPC
395 pci_write_config_byte(pdev, UDIDETCR0, 0xF0);
396#endif
397
398 return ata_pci_bmdma_init_one(pdev, ppi, &cmd64x_sht, NULL, 0); 403 return ata_pci_bmdma_init_one(pdev, ppi, &cmd64x_sht, NULL, 0);
399} 404}
400 405
@@ -402,21 +407,14 @@ static int cmd64x_init_one(struct pci_dev *pdev, const struct pci_device_id *id)
402static int cmd64x_reinit_one(struct pci_dev *pdev) 407static int cmd64x_reinit_one(struct pci_dev *pdev)
403{ 408{
404 struct ata_host *host = dev_get_drvdata(&pdev->dev); 409 struct ata_host *host = dev_get_drvdata(&pdev->dev);
405 u8 mrdmode;
406 int rc; 410 int rc;
407 411
408 rc = ata_pci_device_do_resume(pdev); 412 rc = ata_pci_device_do_resume(pdev);
409 if (rc) 413 if (rc)
410 return rc; 414 return rc;
411 415
412 pci_write_config_byte(pdev, PCI_LATENCY_TIMER, 64); 416 cmd64x_fixup(pdev);
413 pci_read_config_byte(pdev, MRDMODE, &mrdmode); 417
414 mrdmode &= ~ 0x30; /* IRQ set up */
415 mrdmode |= 0x02; /* Memory read line enable */
416 pci_write_config_byte(pdev, MRDMODE, mrdmode);
417#ifdef CONFIG_PPC
418 pci_write_config_byte(pdev, UDIDETCR0, 0xF0);
419#endif
420 ata_host_resume(host); 418 ata_host_resume(host);
421 return 0; 419 return 0;
422} 420}
diff --git a/drivers/ata/pata_cs5535.c b/drivers/ata/pata_cs5535.c
index 03a93186aa19..a0b4640125ae 100644
--- a/drivers/ata/pata_cs5535.c
+++ b/drivers/ata/pata_cs5535.c
@@ -38,7 +38,7 @@
38#include <linux/libata.h> 38#include <linux/libata.h>
39#include <asm/msr.h> 39#include <asm/msr.h>
40 40
41#define DRV_NAME "cs5535" 41#define DRV_NAME "pata_cs5535"
42#define DRV_VERSION "0.2.12" 42#define DRV_VERSION "0.2.12"
43 43
44/* 44/*
@@ -67,8 +67,6 @@
67 67
68#define CS5535_CABLE_DETECT 0x48 68#define CS5535_CABLE_DETECT 0x48
69 69
70#define CS5535_BAD_PIO(timings) ( (timings&~0x80000000UL)==0x00009172 )
71
72/** 70/**
73 * cs5535_cable_detect - detect cable type 71 * cs5535_cable_detect - detect cable type
74 * @ap: Port to detect on 72 * @ap: Port to detect on
@@ -188,16 +186,6 @@ static int cs5535_init_one(struct pci_dev *dev, const struct pci_device_id *id)
188 }; 186 };
189 const struct ata_port_info *ppi[] = { &info, &ata_dummy_port_info }; 187 const struct ata_port_info *ppi[] = { &info, &ata_dummy_port_info };
190 188
191 u32 timings, dummy;
192
193 /* Check the BIOS set the initial timing clock. If not set the
194 timings for PIO0 */
195 rdmsr(ATAC_CH0D0_PIO, timings, dummy);
196 if (CS5535_BAD_PIO(timings))
197 wrmsr(ATAC_CH0D0_PIO, 0xF7F4F7F4UL, 0);
198 rdmsr(ATAC_CH0D1_PIO, timings, dummy);
199 if (CS5535_BAD_PIO(timings))
200 wrmsr(ATAC_CH0D1_PIO, 0xF7F4F7F4UL, 0);
201 return ata_pci_bmdma_init_one(dev, ppi, &cs5535_sht, NULL, 0); 189 return ata_pci_bmdma_init_one(dev, ppi, &cs5535_sht, NULL, 0);
202} 190}
203 191
@@ -230,7 +218,7 @@ static void __exit cs5535_exit(void)
230} 218}
231 219
232MODULE_AUTHOR("Alan Cox, Jens Altmann, Wolfgan Zuleger, Alexander Kiausch"); 220MODULE_AUTHOR("Alan Cox, Jens Altmann, Wolfgan Zuleger, Alexander Kiausch");
233MODULE_DESCRIPTION("low-level driver for the NS/AMD 5530"); 221MODULE_DESCRIPTION("low-level driver for the NS/AMD 5535");
234MODULE_LICENSE("GPL"); 222MODULE_LICENSE("GPL");
235MODULE_DEVICE_TABLE(pci, cs5535); 223MODULE_DEVICE_TABLE(pci, cs5535);
236MODULE_VERSION(DRV_VERSION); 224MODULE_VERSION(DRV_VERSION);
diff --git a/drivers/ata/pata_efar.c b/drivers/ata/pata_efar.c
index aca47e4e29ea..f0243ed206f7 100644
--- a/drivers/ata/pata_efar.c
+++ b/drivers/ata/pata_efar.c
@@ -73,7 +73,7 @@ static DEFINE_SPINLOCK(efar_lock);
73/** 73/**
74 * efar_set_piomode - Initialize host controller PATA PIO timings 74 * efar_set_piomode - Initialize host controller PATA PIO timings
75 * @ap: Port whose timings we are configuring 75 * @ap: Port whose timings we are configuring
76 * @adev: um 76 * @adev: Device to program
77 * 77 *
78 * Set PIO mode for device, in host controller PCI config space. 78 * Set PIO mode for device, in host controller PCI config space.
79 * 79 *
@@ -85,9 +85,9 @@ static void efar_set_piomode (struct ata_port *ap, struct ata_device *adev)
85{ 85{
86 unsigned int pio = adev->pio_mode - XFER_PIO_0; 86 unsigned int pio = adev->pio_mode - XFER_PIO_0;
87 struct pci_dev *dev = to_pci_dev(ap->host->dev); 87 struct pci_dev *dev = to_pci_dev(ap->host->dev);
88 unsigned int idetm_port= ap->port_no ? 0x42 : 0x40; 88 unsigned int master_port = ap->port_no ? 0x42 : 0x40;
89 unsigned long flags; 89 unsigned long flags;
90 u16 idetm_data; 90 u16 master_data;
91 u8 udma_enable; 91 u8 udma_enable;
92 int control = 0; 92 int control = 0;
93 93
@@ -113,20 +113,20 @@ static void efar_set_piomode (struct ata_port *ap, struct ata_device *adev)
113 113
114 spin_lock_irqsave(&efar_lock, flags); 114 spin_lock_irqsave(&efar_lock, flags);
115 115
116 pci_read_config_word(dev, idetm_port, &idetm_data); 116 pci_read_config_word(dev, master_port, &master_data);
117 117
118 /* Set PPE, IE, and TIME as appropriate */ 118 /* Set PPE, IE, and TIME as appropriate */
119 if (adev->devno == 0) { 119 if (adev->devno == 0) {
120 idetm_data &= 0xCCF0; 120 master_data &= 0xCCF0;
121 idetm_data |= control; 121 master_data |= control;
122 idetm_data |= (timings[pio][0] << 12) | 122 master_data |= (timings[pio][0] << 12) |
123 (timings[pio][1] << 8); 123 (timings[pio][1] << 8);
124 } else { 124 } else {
125 int shift = 4 * ap->port_no; 125 int shift = 4 * ap->port_no;
126 u8 slave_data; 126 u8 slave_data;
127 127
128 idetm_data &= 0xFF0F; 128 master_data &= 0xFF0F;
129 idetm_data |= (control << 4); 129 master_data |= (control << 4);
130 130
131 /* Slave timing in separate register */ 131 /* Slave timing in separate register */
132 pci_read_config_byte(dev, 0x44, &slave_data); 132 pci_read_config_byte(dev, 0x44, &slave_data);
@@ -135,8 +135,8 @@ static void efar_set_piomode (struct ata_port *ap, struct ata_device *adev)
135 pci_write_config_byte(dev, 0x44, slave_data); 135 pci_write_config_byte(dev, 0x44, slave_data);
136 } 136 }
137 137
138 idetm_data |= 0x4000; /* Ensure SITRE is set */ 138 master_data |= 0x4000; /* Ensure SITRE is set */
139 pci_write_config_word(dev, idetm_port, idetm_data); 139 pci_write_config_word(dev, master_port, master_data);
140 140
141 pci_read_config_byte(dev, 0x48, &udma_enable); 141 pci_read_config_byte(dev, 0x48, &udma_enable);
142 udma_enable &= ~(1 << (2 * ap->port_no + adev->devno)); 142 udma_enable &= ~(1 << (2 * ap->port_no + adev->devno));
diff --git a/drivers/ata/pata_hpt366.c b/drivers/ata/pata_hpt366.c
index 6c77d68dbd05..42cffd38910d 100644
--- a/drivers/ata/pata_hpt366.c
+++ b/drivers/ata/pata_hpt366.c
@@ -111,6 +111,28 @@ static const struct hpt_clock hpt366_25[] = {
111 { 0, 0x01208585 } 111 { 0, 0x01208585 }
112}; 112};
113 113
114/**
115 * hpt36x_find_mode - find the hpt36x timing
116 * @ap: ATA port
117 * @speed: transfer mode
118 *
119 * Return the 32bit register programming information for this channel
120 * that matches the speed provided.
121 */
122
123static u32 hpt36x_find_mode(struct ata_port *ap, int speed)
124{
125 struct hpt_clock *clocks = ap->host->private_data;
126
127 while (clocks->xfer_mode) {
128 if (clocks->xfer_mode == speed)
129 return clocks->timing;
130 clocks++;
131 }
132 BUG();
133 return 0xffffffffU; /* silence compiler warning */
134}
135
114static const char * const bad_ata33[] = { 136static const char * const bad_ata33[] = {
115 "Maxtor 92720U8", "Maxtor 92040U6", "Maxtor 91360U4", "Maxtor 91020U3", 137 "Maxtor 92720U8", "Maxtor 92040U6", "Maxtor 91360U4", "Maxtor 91020U3",
116 "Maxtor 90845U3", "Maxtor 90650U2", 138 "Maxtor 90845U3", "Maxtor 90650U2",
@@ -210,10 +232,9 @@ static int hpt36x_cable_detect(struct ata_port *ap)
210static void hpt366_set_mode(struct ata_port *ap, struct ata_device *adev, 232static void hpt366_set_mode(struct ata_port *ap, struct ata_device *adev,
211 u8 mode) 233 u8 mode)
212{ 234{
213 struct hpt_clock *clocks = ap->host->private_data;
214 struct pci_dev *pdev = to_pci_dev(ap->host->dev); 235 struct pci_dev *pdev = to_pci_dev(ap->host->dev);
215 u32 addr = 0x40 + 4 * adev->devno; 236 u32 addr = 0x40 + 4 * adev->devno;
216 u32 mask, reg; 237 u32 mask, reg, t;
217 238
218 /* determine timing mask and find matching clock entry */ 239 /* determine timing mask and find matching clock entry */
219 if (mode < XFER_MW_DMA_0) 240 if (mode < XFER_MW_DMA_0)
@@ -223,13 +244,7 @@ static void hpt366_set_mode(struct ata_port *ap, struct ata_device *adev,
223 else 244 else
224 mask = 0x30070000; 245 mask = 0x30070000;
225 246
226 while (clocks->xfer_mode) { 247 t = hpt36x_find_mode(ap, mode);
227 if (clocks->xfer_mode == mode)
228 break;
229 clocks++;
230 }
231 if (!clocks->xfer_mode)
232 BUG();
233 248
234 /* 249 /*
235 * Combine new mode bits with old config bits and disable 250 * Combine new mode bits with old config bits and disable
@@ -237,7 +252,7 @@ static void hpt366_set_mode(struct ata_port *ap, struct ata_device *adev,
237 * problems handling I/O errors later. 252 * problems handling I/O errors later.
238 */ 253 */
239 pci_read_config_dword(pdev, addr, &reg); 254 pci_read_config_dword(pdev, addr, &reg);
240 reg = ((reg & ~mask) | (clocks->timing & mask)) & ~0xc0000000; 255 reg = ((reg & ~mask) | (t & mask)) & ~0xc0000000;
241 pci_write_config_dword(pdev, addr, reg); 256 pci_write_config_dword(pdev, addr, reg);
242} 257}
243 258
diff --git a/drivers/ata/pata_it8213.c b/drivers/ata/pata_it8213.c
index 998af0e629b1..cf9164d79f11 100644
--- a/drivers/ata/pata_it8213.c
+++ b/drivers/ata/pata_it8213.c
@@ -76,8 +76,8 @@ static void it8213_set_piomode (struct ata_port *ap, struct ata_device *adev)
76{ 76{
77 unsigned int pio = adev->pio_mode - XFER_PIO_0; 77 unsigned int pio = adev->pio_mode - XFER_PIO_0;
78 struct pci_dev *dev = to_pci_dev(ap->host->dev); 78 struct pci_dev *dev = to_pci_dev(ap->host->dev);
79 unsigned int idetm_port= ap->port_no ? 0x42 : 0x40; 79 unsigned int master_port = ap->port_no ? 0x42 : 0x40;
80 u16 idetm_data; 80 u16 master_data;
81 int control = 0; 81 int control = 0;
82 82
83 /* 83 /*
@@ -100,19 +100,19 @@ static void it8213_set_piomode (struct ata_port *ap, struct ata_device *adev)
100 if (adev->class != ATA_DEV_ATA) 100 if (adev->class != ATA_DEV_ATA)
101 control |= 4; /* PPE */ 101 control |= 4; /* PPE */
102 102
103 pci_read_config_word(dev, idetm_port, &idetm_data); 103 pci_read_config_word(dev, master_port, &master_data);
104 104
105 /* Set PPE, IE, and TIME as appropriate */ 105 /* Set PPE, IE, and TIME as appropriate */
106 if (adev->devno == 0) { 106 if (adev->devno == 0) {
107 idetm_data &= 0xCCF0; 107 master_data &= 0xCCF0;
108 idetm_data |= control; 108 master_data |= control;
109 idetm_data |= (timings[pio][0] << 12) | 109 master_data |= (timings[pio][0] << 12) |
110 (timings[pio][1] << 8); 110 (timings[pio][1] << 8);
111 } else { 111 } else {
112 u8 slave_data; 112 u8 slave_data;
113 113
114 idetm_data &= 0xFF0F; 114 master_data &= 0xFF0F;
115 idetm_data |= (control << 4); 115 master_data |= (control << 4);
116 116
117 /* Slave timing in separate register */ 117 /* Slave timing in separate register */
118 pci_read_config_byte(dev, 0x44, &slave_data); 118 pci_read_config_byte(dev, 0x44, &slave_data);
@@ -121,8 +121,8 @@ static void it8213_set_piomode (struct ata_port *ap, struct ata_device *adev)
121 pci_write_config_byte(dev, 0x44, slave_data); 121 pci_write_config_byte(dev, 0x44, slave_data);
122 } 122 }
123 123
124 idetm_data |= 0x4000; /* Ensure SITRE is set */ 124 master_data |= 0x4000; /* Ensure SITRE is set */
125 pci_write_config_word(dev, idetm_port, idetm_data); 125 pci_write_config_word(dev, master_port, master_data);
126} 126}
127 127
128/** 128/**
@@ -163,7 +163,7 @@ static void it8213_set_dmamode (struct ata_port *ap, struct ata_device *adev)
163 163
164 /* Clocks follow the PIIX style */ 164 /* Clocks follow the PIIX style */
165 u_speed = min(2 - (udma & 1), udma); 165 u_speed = min(2 - (udma & 1), udma);
166 if (udma == 5) 166 if (udma > 4)
167 u_clock = 0x1000; /* 100Mhz */ 167 u_clock = 0x1000; /* 100Mhz */
168 else if (udma > 2) 168 else if (udma > 2)
169 u_clock = 1; /* 66Mhz */ 169 u_clock = 1; /* 66Mhz */
@@ -262,7 +262,7 @@ static int it8213_init_one (struct pci_dev *pdev, const struct pci_device_id *en
262 .flags = ATA_FLAG_SLAVE_POSS, 262 .flags = ATA_FLAG_SLAVE_POSS,
263 .pio_mask = ATA_PIO4, 263 .pio_mask = ATA_PIO4,
264 .mwdma_mask = ATA_MWDMA12_ONLY, 264 .mwdma_mask = ATA_MWDMA12_ONLY,
265 .udma_mask = ATA_UDMA4, /* FIXME: want UDMA 100? */ 265 .udma_mask = ATA_UDMA6,
266 .port_ops = &it8213_ops, 266 .port_ops = &it8213_ops,
267 }; 267 };
268 /* Current IT8213 stuff is single port */ 268 /* Current IT8213 stuff is single port */
diff --git a/drivers/ata/pata_legacy.c b/drivers/ata/pata_legacy.c
index d960f8e9e8b1..35aca7d1a3eb 100644
--- a/drivers/ata/pata_legacy.c
+++ b/drivers/ata/pata_legacy.c
@@ -79,15 +79,6 @@ static int all;
79module_param(all, int, 0444); 79module_param(all, int, 0444);
80MODULE_PARM_DESC(all, "Grab all legacy port devices, even if PCI(0=off, 1=on)"); 80MODULE_PARM_DESC(all, "Grab all legacy port devices, even if PCI(0=off, 1=on)");
81 81
82struct legacy_data {
83 unsigned long timing;
84 u8 clock[2];
85 u8 last;
86 int fast;
87 struct platform_device *platform_dev;
88
89};
90
91enum controller { 82enum controller {
92 BIOS = 0, 83 BIOS = 0,
93 SNOOP = 1, 84 SNOOP = 1,
@@ -104,6 +95,14 @@ enum controller {
104 UNKNOWN = -1 95 UNKNOWN = -1
105}; 96};
106 97
98struct legacy_data {
99 unsigned long timing;
100 u8 clock[2];
101 u8 last;
102 int fast;
103 enum controller type;
104 struct platform_device *platform_dev;
105};
107 106
108struct legacy_probe { 107struct legacy_probe {
109 unsigned char *name; 108 unsigned char *name;
@@ -137,11 +136,17 @@ static int ht6560a; /* HT 6560A on primary 1, second 2, both 3 */
137static int ht6560b; /* HT 6560A on primary 1, second 2, both 3 */ 136static int ht6560b; /* HT 6560A on primary 1, second 2, both 3 */
138static int opti82c611a; /* Opti82c611A on primary 1, sec 2, both 3 */ 137static int opti82c611a; /* Opti82c611A on primary 1, sec 2, both 3 */
139static int opti82c46x; /* Opti 82c465MV present(pri/sec autodetect) */ 138static int opti82c46x; /* Opti 82c465MV present(pri/sec autodetect) */
140static int qdi; /* Set to probe QDI controllers */
141static int autospeed; /* Chip present which snoops speed changes */ 139static int autospeed; /* Chip present which snoops speed changes */
142static int pio_mask = ATA_PIO4; /* PIO range for autospeed devices */ 140static int pio_mask = ATA_PIO4; /* PIO range for autospeed devices */
143static int iordy_mask = 0xFFFFFFFF; /* Use iordy if available */ 141static int iordy_mask = 0xFFFFFFFF; /* Use iordy if available */
144 142
143/* Set to probe QDI controllers */
144#ifdef CONFIG_PATA_QDI_MODULE
145static int qdi = 1;
146#else
147static int qdi;
148#endif
149
145#ifdef CONFIG_PATA_WINBOND_VLB_MODULE 150#ifdef CONFIG_PATA_WINBOND_VLB_MODULE
146static int winbond = 1; /* Set to probe Winbond controllers, 151static int winbond = 1; /* Set to probe Winbond controllers,
147 give I/O port if non standard */ 152 give I/O port if non standard */
@@ -631,40 +636,20 @@ static struct ata_port_operations opti82c46x_port_ops = {
631 .qc_issue = opti82c46x_qc_issue, 636 .qc_issue = opti82c46x_qc_issue,
632}; 637};
633 638
634static void qdi6500_set_piomode(struct ata_port *ap, struct ata_device *adev)
635{
636 struct ata_timing t;
637 struct legacy_data *ld_qdi = ap->host->private_data;
638 int active, recovery;
639 u8 timing;
640
641 /* Get the timing data in cycles */
642 ata_timing_compute(adev, adev->pio_mode, &t, 30303, 1000);
643
644 if (ld_qdi->fast) {
645 active = 8 - clamp_val(t.active, 1, 8);
646 recovery = 18 - clamp_val(t.recover, 3, 18);
647 } else {
648 active = 9 - clamp_val(t.active, 2, 9);
649 recovery = 15 - clamp_val(t.recover, 0, 15);
650 }
651 timing = (recovery << 4) | active | 0x08;
652
653 ld_qdi->clock[adev->devno] = timing;
654
655 outb(timing, ld_qdi->timing);
656}
657
658/** 639/**
659 * qdi6580dp_set_piomode - PIO setup for dual channel 640 * qdi65x0_set_piomode - PIO setup for QDI65x0
660 * @ap: Port 641 * @ap: Port
661 * @adev: Device 642 * @adev: Device
662 * 643 *
644 * In single channel mode the 6580 has one clock per device and we can
645 * avoid the requirement to clock switch. We also have to load the timing
646 * into the right clock according to whether we are master or slave.
647 *
663 * In dual channel mode the 6580 has one clock per channel and we have 648 * In dual channel mode the 6580 has one clock per channel and we have
664 * to software clockswitch in qc_issue. 649 * to software clockswitch in qc_issue.
665 */ 650 */
666 651
667static void qdi6580dp_set_piomode(struct ata_port *ap, struct ata_device *adev) 652static void qdi65x0_set_piomode(struct ata_port *ap, struct ata_device *adev)
668{ 653{
669 struct ata_timing t; 654 struct ata_timing t;
670 struct legacy_data *ld_qdi = ap->host->private_data; 655 struct legacy_data *ld_qdi = ap->host->private_data;
@@ -682,47 +667,15 @@ static void qdi6580dp_set_piomode(struct ata_port *ap, struct ata_device *adev)
682 recovery = 15 - clamp_val(t.recover, 0, 15); 667 recovery = 15 - clamp_val(t.recover, 0, 15);
683 } 668 }
684 timing = (recovery << 4) | active | 0x08; 669 timing = (recovery << 4) | active | 0x08;
685
686 ld_qdi->clock[adev->devno] = timing; 670 ld_qdi->clock[adev->devno] = timing;
687 671
688 outb(timing, ld_qdi->timing + 2 * ap->port_no); 672 if (ld_qdi->type == QDI6580)
689 /* Clear the FIFO */ 673 outb(timing, ld_qdi->timing + 2 * adev->devno);
690 if (adev->class != ATA_DEV_ATA) 674 else
691 outb(0x5F, (ld_qdi->timing & 0xFFF0) + 3); 675 outb(timing, ld_qdi->timing + 2 * ap->port_no);
692}
693
694/**
695 * qdi6580_set_piomode - PIO setup for single channel
696 * @ap: Port
697 * @adev: Device
698 *
699 * In single channel mode the 6580 has one clock per device and we can
700 * avoid the requirement to clock switch. We also have to load the timing
701 * into the right clock according to whether we are master or slave.
702 */
703
704static void qdi6580_set_piomode(struct ata_port *ap, struct ata_device *adev)
705{
706 struct ata_timing t;
707 struct legacy_data *ld_qdi = ap->host->private_data;
708 int active, recovery;
709 u8 timing;
710
711 /* Get the timing data in cycles */
712 ata_timing_compute(adev, adev->pio_mode, &t, 30303, 1000);
713 676
714 if (ld_qdi->fast) {
715 active = 8 - clamp_val(t.active, 1, 8);
716 recovery = 18 - clamp_val(t.recover, 3, 18);
717 } else {
718 active = 9 - clamp_val(t.active, 2, 9);
719 recovery = 15 - clamp_val(t.recover, 0, 15);
720 }
721 timing = (recovery << 4) | active | 0x08;
722 ld_qdi->clock[adev->devno] = timing;
723 outb(timing, ld_qdi->timing + 2 * adev->devno);
724 /* Clear the FIFO */ 677 /* Clear the FIFO */
725 if (adev->class != ATA_DEV_ATA) 678 if (ld_qdi->type != QDI6500 && adev->class != ATA_DEV_ATA)
726 outb(0x5F, (ld_qdi->timing & 0xFFF0) + 3); 679 outb(0x5F, (ld_qdi->timing & 0xFFF0) + 3);
727} 680}
728 681
@@ -789,20 +742,20 @@ static int qdi_port(struct platform_device *dev,
789 742
790static struct ata_port_operations qdi6500_port_ops = { 743static struct ata_port_operations qdi6500_port_ops = {
791 .inherits = &legacy_base_port_ops, 744 .inherits = &legacy_base_port_ops,
792 .set_piomode = qdi6500_set_piomode, 745 .set_piomode = qdi65x0_set_piomode,
793 .qc_issue = qdi_qc_issue, 746 .qc_issue = qdi_qc_issue,
794 .sff_data_xfer = vlb32_data_xfer, 747 .sff_data_xfer = vlb32_data_xfer,
795}; 748};
796 749
797static struct ata_port_operations qdi6580_port_ops = { 750static struct ata_port_operations qdi6580_port_ops = {
798 .inherits = &legacy_base_port_ops, 751 .inherits = &legacy_base_port_ops,
799 .set_piomode = qdi6580_set_piomode, 752 .set_piomode = qdi65x0_set_piomode,
800 .sff_data_xfer = vlb32_data_xfer, 753 .sff_data_xfer = vlb32_data_xfer,
801}; 754};
802 755
803static struct ata_port_operations qdi6580dp_port_ops = { 756static struct ata_port_operations qdi6580dp_port_ops = {
804 .inherits = &legacy_base_port_ops, 757 .inherits = &legacy_base_port_ops,
805 .set_piomode = qdi6580dp_set_piomode, 758 .set_piomode = qdi65x0_set_piomode,
806 .qc_issue = qdi_qc_issue, 759 .qc_issue = qdi_qc_issue,
807 .sff_data_xfer = vlb32_data_xfer, 760 .sff_data_xfer = vlb32_data_xfer,
808}; 761};
@@ -879,29 +832,29 @@ static struct ata_port_operations winbond_port_ops = {
879}; 832};
880 833
881static struct legacy_controller controllers[] = { 834static struct legacy_controller controllers[] = {
882 {"BIOS", &legacy_port_ops, 0x1F, 835 {"BIOS", &legacy_port_ops, ATA_PIO4,
883 ATA_FLAG_NO_IORDY, 0, NULL }, 836 ATA_FLAG_NO_IORDY, 0, NULL },
884 {"Snooping", &simple_port_ops, 0x1F, 837 {"Snooping", &simple_port_ops, ATA_PIO4,
885 0, 0, NULL }, 838 0, 0, NULL },
886 {"PDC20230", &pdc20230_port_ops, 0x7, 839 {"PDC20230", &pdc20230_port_ops, ATA_PIO2,
887 ATA_FLAG_NO_IORDY, 840 ATA_FLAG_NO_IORDY,
888 ATA_PFLAG_PIO32 | ATA_PFLAG_PIO32CHANGE, NULL }, 841 ATA_PFLAG_PIO32 | ATA_PFLAG_PIO32CHANGE, NULL },
889 {"HT6560A", &ht6560a_port_ops, 0x07, 842 {"HT6560A", &ht6560a_port_ops, ATA_PIO2,
890 ATA_FLAG_NO_IORDY, 0, NULL }, 843 ATA_FLAG_NO_IORDY, 0, NULL },
891 {"HT6560B", &ht6560b_port_ops, 0x1F, 844 {"HT6560B", &ht6560b_port_ops, ATA_PIO4,
892 ATA_FLAG_NO_IORDY, 0, NULL }, 845 ATA_FLAG_NO_IORDY, 0, NULL },
893 {"OPTI82C611A", &opti82c611a_port_ops, 0x0F, 846 {"OPTI82C611A", &opti82c611a_port_ops, ATA_PIO3,
894 0, 0, NULL }, 847 0, 0, NULL },
895 {"OPTI82C46X", &opti82c46x_port_ops, 0x0F, 848 {"OPTI82C46X", &opti82c46x_port_ops, ATA_PIO3,
896 0, 0, NULL }, 849 0, 0, NULL },
897 {"QDI6500", &qdi6500_port_ops, 0x07, 850 {"QDI6500", &qdi6500_port_ops, ATA_PIO2,
898 ATA_FLAG_NO_IORDY, 851 ATA_FLAG_NO_IORDY,
899 ATA_PFLAG_PIO32 | ATA_PFLAG_PIO32CHANGE, qdi_port }, 852 ATA_PFLAG_PIO32 | ATA_PFLAG_PIO32CHANGE, qdi_port },
900 {"QDI6580", &qdi6580_port_ops, 0x1F, 853 {"QDI6580", &qdi6580_port_ops, ATA_PIO4,
901 0, ATA_PFLAG_PIO32 | ATA_PFLAG_PIO32CHANGE, qdi_port }, 854 0, ATA_PFLAG_PIO32 | ATA_PFLAG_PIO32CHANGE, qdi_port },
902 {"QDI6580DP", &qdi6580dp_port_ops, 0x1F, 855 {"QDI6580DP", &qdi6580dp_port_ops, ATA_PIO4,
903 0, ATA_PFLAG_PIO32 | ATA_PFLAG_PIO32CHANGE, qdi_port }, 856 0, ATA_PFLAG_PIO32 | ATA_PFLAG_PIO32CHANGE, qdi_port },
904 {"W83759A", &winbond_port_ops, 0x1F, 857 {"W83759A", &winbond_port_ops, ATA_PIO4,
905 0, ATA_PFLAG_PIO32 | ATA_PFLAG_PIO32CHANGE, 858 0, ATA_PFLAG_PIO32 | ATA_PFLAG_PIO32CHANGE,
906 winbond_port } 859 winbond_port }
907}; 860};
@@ -1022,6 +975,7 @@ static __init int legacy_init_one(struct legacy_probe *probe)
1022 ctrl_addr = devm_ioport_map(&pdev->dev, io + 0x0206, 1); 975 ctrl_addr = devm_ioport_map(&pdev->dev, io + 0x0206, 1);
1023 if (!io_addr || !ctrl_addr) 976 if (!io_addr || !ctrl_addr)
1024 goto fail; 977 goto fail;
978 ld->type = probe->type;
1025 if (controller->setup) 979 if (controller->setup)
1026 if (controller->setup(pdev, probe, ld) < 0) 980 if (controller->setup(pdev, probe, ld) < 0)
1027 goto fail; 981 goto fail;
@@ -1306,6 +1260,7 @@ MODULE_AUTHOR("Alan Cox");
1306MODULE_DESCRIPTION("low-level driver for legacy ATA"); 1260MODULE_DESCRIPTION("low-level driver for legacy ATA");
1307MODULE_LICENSE("GPL"); 1261MODULE_LICENSE("GPL");
1308MODULE_VERSION(DRV_VERSION); 1262MODULE_VERSION(DRV_VERSION);
1263MODULE_ALIAS("pata_qdi");
1309MODULE_ALIAS("pata_winbond"); 1264MODULE_ALIAS("pata_winbond");
1310 1265
1311module_param(probe_all, int, 0); 1266module_param(probe_all, int, 0);
diff --git a/drivers/ata/pata_mpc52xx.c b/drivers/ata/pata_mpc52xx.c
index 2fcac511d39c..3e1746314f22 100644
--- a/drivers/ata/pata_mpc52xx.c
+++ b/drivers/ata/pata_mpc52xx.c
@@ -780,7 +780,7 @@ mpc52xx_ata_probe(struct platform_device *op)
780 } 780 }
781 781
782 task_irq = bcom_get_task_irq(dmatsk); 782 task_irq = bcom_get_task_irq(dmatsk);
783 ret = request_irq(task_irq, &mpc52xx_ata_task_irq, IRQF_DISABLED, 783 ret = request_irq(task_irq, &mpc52xx_ata_task_irq, 0,
784 "ATA task", priv); 784 "ATA task", priv);
785 if (ret) { 785 if (ret) {
786 dev_err(&op->dev, "error requesting DMA IRQ\n"); 786 dev_err(&op->dev, "error requesting DMA IRQ\n");
diff --git a/drivers/ata/pata_of_platform.c b/drivers/ata/pata_of_platform.c
index f3054009bd25..2a472c5bb7db 100644
--- a/drivers/ata/pata_of_platform.c
+++ b/drivers/ata/pata_of_platform.c
@@ -11,6 +11,8 @@
11 11
12#include <linux/kernel.h> 12#include <linux/kernel.h>
13#include <linux/module.h> 13#include <linux/module.h>
14#include <linux/of_address.h>
15#include <linux/of_irq.h>
14#include <linux/of_platform.h> 16#include <linux/of_platform.h>
15#include <linux/ata_platform.h> 17#include <linux/ata_platform.h>
16 18
@@ -50,18 +52,18 @@ static int __devinit pata_of_platform_probe(struct platform_device *ofdev)
50 } 52 }
51 53
52 ret = of_irq_to_resource(dn, 0, &irq_res); 54 ret = of_irq_to_resource(dn, 0, &irq_res);
53 if (ret == NO_IRQ) 55 if (!ret)
54 irq_res.start = irq_res.end = 0; 56 irq_res.start = irq_res.end = 0;
55 else 57 else
56 irq_res.flags = 0; 58 irq_res.flags = 0;
57 59
58 prop = of_get_property(dn, "reg-shift", NULL); 60 prop = of_get_property(dn, "reg-shift", NULL);
59 if (prop) 61 if (prop)
60 reg_shift = *prop; 62 reg_shift = be32_to_cpup(prop);
61 63
62 prop = of_get_property(dn, "pio-mode", NULL); 64 prop = of_get_property(dn, "pio-mode", NULL);
63 if (prop) { 65 if (prop) {
64 pio_mode = *prop; 66 pio_mode = be32_to_cpup(prop);
65 if (pio_mode > 6) { 67 if (pio_mode > 6) {
66 dev_err(&ofdev->dev, "invalid pio-mode\n"); 68 dev_err(&ofdev->dev, "invalid pio-mode\n");
67 return -EINVAL; 69 return -EINVAL;
diff --git a/drivers/ata/pata_pdc2027x.c b/drivers/ata/pata_pdc2027x.c
index b1511f38b0e8..7d63f24179c7 100644
--- a/drivers/ata/pata_pdc2027x.c
+++ b/drivers/ata/pata_pdc2027x.c
@@ -63,6 +63,7 @@ enum {
63}; 63};
64 64
65static int pdc2027x_init_one(struct pci_dev *pdev, const struct pci_device_id *ent); 65static int pdc2027x_init_one(struct pci_dev *pdev, const struct pci_device_id *ent);
66static int pdc2027x_reinit_one(struct pci_dev *pdev);
66static int pdc2027x_prereset(struct ata_link *link, unsigned long deadline); 67static int pdc2027x_prereset(struct ata_link *link, unsigned long deadline);
67static void pdc2027x_set_piomode(struct ata_port *ap, struct ata_device *adev); 68static void pdc2027x_set_piomode(struct ata_port *ap, struct ata_device *adev);
68static void pdc2027x_set_dmamode(struct ata_port *ap, struct ata_device *adev); 69static void pdc2027x_set_dmamode(struct ata_port *ap, struct ata_device *adev);
@@ -126,6 +127,10 @@ static struct pci_driver pdc2027x_pci_driver = {
126 .id_table = pdc2027x_pci_tbl, 127 .id_table = pdc2027x_pci_tbl,
127 .probe = pdc2027x_init_one, 128 .probe = pdc2027x_init_one,
128 .remove = ata_pci_remove_one, 129 .remove = ata_pci_remove_one,
130#ifdef CONFIG_PM
131 .suspend = ata_pci_device_suspend,
132 .resume = pdc2027x_reinit_one,
133#endif
129}; 134};
130 135
131static struct scsi_host_template pdc2027x_sht = { 136static struct scsi_host_template pdc2027x_sht = {
@@ -754,6 +759,31 @@ static int __devinit pdc2027x_init_one(struct pci_dev *pdev, const struct pci_de
754 IRQF_SHARED, &pdc2027x_sht); 759 IRQF_SHARED, &pdc2027x_sht);
755} 760}
756 761
762#ifdef CONFIG_PM
763static int pdc2027x_reinit_one(struct pci_dev *pdev)
764{
765 struct ata_host *host = dev_get_drvdata(&pdev->dev);
766 unsigned int board_idx;
767 int rc;
768
769 rc = ata_pci_device_do_resume(pdev);
770 if (rc)
771 return rc;
772
773 if (pdev->device == PCI_DEVICE_ID_PROMISE_20268 ||
774 pdev->device == PCI_DEVICE_ID_PROMISE_20270)
775 board_idx = PDC_UDMA_100;
776 else
777 board_idx = PDC_UDMA_133;
778
779 if (pdc_hardware_init(host, board_idx))
780 return -EIO;
781
782 ata_host_resume(host);
783 return 0;
784}
785#endif
786
757/** 787/**
758 * pdc2027x_init - Called after this module is loaded into the kernel. 788 * pdc2027x_init - Called after this module is loaded into the kernel.
759 */ 789 */
diff --git a/drivers/ata/pata_qdi.c b/drivers/ata/pata_qdi.c
deleted file mode 100644
index 45879dc6fa41..000000000000
--- a/drivers/ata/pata_qdi.c
+++ /dev/null
@@ -1,366 +0,0 @@
1/*
2 * pata_qdi.c - QDI VLB ATA controllers
3 * (C) 2006 Red Hat
4 *
5 * This driver mostly exists as a proof of concept for non PCI devices under
6 * libata. While the QDI6580 was 'neat' in 1993 it is no longer terribly
7 * useful.
8 *
9 * Tuning code written from the documentation at
10 * http://www.ryston.cz/petr/vlb/qd6500.html
11 * http://www.ryston.cz/petr/vlb/qd6580.html
12 *
13 * Probe code based on drivers/ide/legacy/qd65xx.c
14 * Rewritten from the work of Colten Edwards <pje120@cs.usask.ca> by
15 * Samuel Thibault <samuel.thibault@ens-lyon.org>
16 */
17
18#include <linux/kernel.h>
19#include <linux/module.h>
20#include <linux/pci.h>
21#include <linux/init.h>
22#include <linux/blkdev.h>
23#include <linux/delay.h>
24#include <scsi/scsi_host.h>
25#include <linux/libata.h>
26#include <linux/platform_device.h>
27
28#define DRV_NAME "pata_qdi"
29#define DRV_VERSION "0.3.1"
30
31#define NR_HOST 4 /* Two 6580s */
32
33struct qdi_data {
34 unsigned long timing;
35 u8 clock[2];
36 u8 last;
37 int fast;
38 struct platform_device *platform_dev;
39
40};
41
42static struct ata_host *qdi_host[NR_HOST];
43static struct qdi_data qdi_data[NR_HOST];
44static int nr_qdi_host;
45
46#ifdef MODULE
47static int probe_qdi = 1;
48#else
49static int probe_qdi;
50#endif
51
52static void qdi6500_set_piomode(struct ata_port *ap, struct ata_device *adev)
53{
54 struct ata_timing t;
55 struct qdi_data *qdi = ap->host->private_data;
56 int active, recovery;
57 u8 timing;
58
59 /* Get the timing data in cycles */
60 ata_timing_compute(adev, adev->pio_mode, &t, 30303, 1000);
61
62 if (qdi->fast) {
63 active = 8 - clamp_val(t.active, 1, 8);
64 recovery = 18 - clamp_val(t.recover, 3, 18);
65 } else {
66 active = 9 - clamp_val(t.active, 2, 9);
67 recovery = 15 - clamp_val(t.recover, 0, 15);
68 }
69 timing = (recovery << 4) | active | 0x08;
70
71 qdi->clock[adev->devno] = timing;
72
73 outb(timing, qdi->timing);
74}
75
76static void qdi6580_set_piomode(struct ata_port *ap, struct ata_device *adev)
77{
78 struct ata_timing t;
79 struct qdi_data *qdi = ap->host->private_data;
80 int active, recovery;
81 u8 timing;
82
83 /* Get the timing data in cycles */
84 ata_timing_compute(adev, adev->pio_mode, &t, 30303, 1000);
85
86 if (qdi->fast) {
87 active = 8 - clamp_val(t.active, 1, 8);
88 recovery = 18 - clamp_val(t.recover, 3, 18);
89 } else {
90 active = 9 - clamp_val(t.active, 2, 9);
91 recovery = 15 - clamp_val(t.recover, 0, 15);
92 }
93 timing = (recovery << 4) | active | 0x08;
94
95 qdi->clock[adev->devno] = timing;
96
97 outb(timing, qdi->timing);
98
99 /* Clear the FIFO */
100 if (adev->class != ATA_DEV_ATA)
101 outb(0x5F, (qdi->timing & 0xFFF0) + 3);
102}
103
104/**
105 * qdi_qc_issue - command issue
106 * @qc: command pending
107 *
108 * Called when the libata layer is about to issue a command. We wrap
109 * this interface so that we can load the correct ATA timings.
110 */
111
112static unsigned int qdi_qc_issue(struct ata_queued_cmd *qc)
113{
114 struct ata_port *ap = qc->ap;
115 struct ata_device *adev = qc->dev;
116 struct qdi_data *qdi = ap->host->private_data;
117
118 if (qdi->clock[adev->devno] != qdi->last) {
119 if (adev->pio_mode) {
120 qdi->last = qdi->clock[adev->devno];
121 outb(qdi->clock[adev->devno], qdi->timing);
122 }
123 }
124 return ata_sff_qc_issue(qc);
125}
126
127static unsigned int qdi_data_xfer(struct ata_device *dev, unsigned char *buf,
128 unsigned int buflen, int rw)
129{
130 if (ata_id_has_dword_io(dev->id)) {
131 struct ata_port *ap = dev->link->ap;
132 int slop = buflen & 3;
133
134 if (rw == READ)
135 ioread32_rep(ap->ioaddr.data_addr, buf, buflen >> 2);
136 else
137 iowrite32_rep(ap->ioaddr.data_addr, buf, buflen >> 2);
138
139 if (unlikely(slop)) {
140 __le32 pad;
141 if (rw == READ) {
142 pad = cpu_to_le32(ioread32(ap->ioaddr.data_addr));
143 memcpy(buf + buflen - slop, &pad, slop);
144 } else {
145 memcpy(&pad, buf + buflen - slop, slop);
146 iowrite32(le32_to_cpu(pad), ap->ioaddr.data_addr);
147 }
148 buflen += 4 - slop;
149 }
150 } else
151 buflen = ata_sff_data_xfer(dev, buf, buflen, rw);
152
153 return buflen;
154}
155
156static struct scsi_host_template qdi_sht = {
157 ATA_PIO_SHT(DRV_NAME),
158};
159
160static struct ata_port_operations qdi6500_port_ops = {
161 .inherits = &ata_sff_port_ops,
162 .qc_issue = qdi_qc_issue,
163 .sff_data_xfer = qdi_data_xfer,
164 .cable_detect = ata_cable_40wire,
165 .set_piomode = qdi6500_set_piomode,
166};
167
168static struct ata_port_operations qdi6580_port_ops = {
169 .inherits = &qdi6500_port_ops,
170 .set_piomode = qdi6580_set_piomode,
171};
172
173/**
174 * qdi_init_one - attach a qdi interface
175 * @type: Type to display
176 * @io: I/O port start
177 * @irq: interrupt line
178 * @fast: True if on a > 33Mhz VLB
179 *
180 * Register an ISA bus IDE interface. Such interfaces are PIO and we
181 * assume do not support IRQ sharing.
182 */
183
184static __init int qdi_init_one(unsigned long port, int type, unsigned long io, int irq, int fast)
185{
186 unsigned long ctl = io + 0x206;
187 struct platform_device *pdev;
188 struct ata_host *host;
189 struct ata_port *ap;
190 void __iomem *io_addr, *ctl_addr;
191 int ret;
192
193 /*
194 * Fill in a probe structure first of all
195 */
196
197 pdev = platform_device_register_simple(DRV_NAME, nr_qdi_host, NULL, 0);
198 if (IS_ERR(pdev))
199 return PTR_ERR(pdev);
200
201 ret = -ENOMEM;
202 io_addr = devm_ioport_map(&pdev->dev, io, 8);
203 ctl_addr = devm_ioport_map(&pdev->dev, ctl, 1);
204 if (!io_addr || !ctl_addr)
205 goto fail;
206
207 ret = -ENOMEM;
208 host = ata_host_alloc(&pdev->dev, 1);
209 if (!host)
210 goto fail;
211 ap = host->ports[0];
212
213 if (type == 6580) {
214 ap->ops = &qdi6580_port_ops;
215 ap->pio_mask = ATA_PIO4;
216 ap->flags |= ATA_FLAG_SLAVE_POSS;
217 } else {
218 ap->ops = &qdi6500_port_ops;
219 ap->pio_mask = ATA_PIO2; /* Actually PIO3 !IORDY is possible */
220 ap->flags = ATA_FLAG_SLAVE_POSS | ATA_FLAG_NO_IORDY;
221 }
222
223 ap->ioaddr.cmd_addr = io_addr;
224 ap->ioaddr.altstatus_addr = ctl_addr;
225 ap->ioaddr.ctl_addr = ctl_addr;
226 ata_sff_std_ports(&ap->ioaddr);
227
228 ata_port_desc(ap, "cmd %lx ctl %lx", io, ctl);
229
230 /*
231 * Hook in a private data structure per channel
232 */
233 ap->private_data = &qdi_data[nr_qdi_host];
234
235 qdi_data[nr_qdi_host].timing = port;
236 qdi_data[nr_qdi_host].fast = fast;
237 qdi_data[nr_qdi_host].platform_dev = pdev;
238
239 printk(KERN_INFO DRV_NAME": qd%d at 0x%lx.\n", type, io);
240
241 /* activate */
242 ret = ata_host_activate(host, irq, ata_sff_interrupt, 0, &qdi_sht);
243 if (ret)
244 goto fail;
245
246 qdi_host[nr_qdi_host++] = dev_get_drvdata(&pdev->dev);
247 return 0;
248
249 fail:
250 platform_device_unregister(pdev);
251 return ret;
252}
253
254/**
255 * qdi_init - attach qdi interfaces
256 *
257 * Attach qdi IDE interfaces by scanning the ports it may occupy.
258 */
259
260static __init int qdi_init(void)
261{
262 unsigned long flags;
263 static const unsigned long qd_port[2] = { 0x30, 0xB0 };
264 static const unsigned long ide_port[2] = { 0x170, 0x1F0 };
265 static const int ide_irq[2] = { 14, 15 };
266
267 int ct = 0;
268 int i;
269
270 if (probe_qdi == 0)
271 return -ENODEV;
272
273 /*
274 * Check each possible QD65xx base address
275 */
276
277 for (i = 0; i < 2; i++) {
278 unsigned long port = qd_port[i];
279 u8 r, res;
280
281
282 if (request_region(port, 2, "pata_qdi")) {
283 /* Check for a card */
284 local_irq_save(flags);
285 r = inb_p(port);
286 outb_p(0x19, port);
287 res = inb_p(port);
288 outb_p(r, port);
289 local_irq_restore(flags);
290
291 /* Fail */
292 if (res == 0x19)
293 {
294 release_region(port, 2);
295 continue;
296 }
297
298 /* Passes the presence test */
299 r = inb_p(port + 1); /* Check port agrees with port set */
300 if ((r & 2) >> 1 != i) {
301 release_region(port, 2);
302 continue;
303 }
304
305 /* Check card type */
306 if ((r & 0xF0) == 0xC0) {
307 /* QD6500: single channel */
308 if (r & 8) {
309 /* Disabled ? */
310 release_region(port, 2);
311 continue;
312 }
313 if (qdi_init_one(port, 6500, ide_port[r & 0x01], ide_irq[r & 0x01], r & 0x04) == 0)
314 ct++;
315 }
316 if (((r & 0xF0) == 0xA0) || (r & 0xF0) == 0x50) {
317 /* QD6580: dual channel */
318 if (!request_region(port + 2 , 2, "pata_qdi"))
319 {
320 release_region(port, 2);
321 continue;
322 }
323 res = inb(port + 3);
324 if (res & 1) {
325 /* Single channel mode */
326 if (qdi_init_one(port, 6580, ide_port[r & 0x01], ide_irq[r & 0x01], r & 0x04) == 0)
327 ct++;
328 } else {
329 /* Dual channel mode */
330 if (qdi_init_one(port, 6580, 0x1F0, 14, r & 0x04) == 0)
331 ct++;
332 if (qdi_init_one(port + 2, 6580, 0x170, 15, r & 0x04) == 0)
333 ct++;
334 }
335 }
336 }
337 }
338 if (ct != 0)
339 return 0;
340 return -ENODEV;
341}
342
343static __exit void qdi_exit(void)
344{
345 int i;
346
347 for (i = 0; i < nr_qdi_host; i++) {
348 ata_host_detach(qdi_host[i]);
349 /* Free the control resource. The 6580 dual channel has the resources
350 * claimed as a pair of 2 byte resources so we need no special cases...
351 */
352 release_region(qdi_data[i].timing, 2);
353 platform_device_unregister(qdi_data[i].platform_dev);
354 }
355}
356
357MODULE_AUTHOR("Alan Cox");
358MODULE_DESCRIPTION("low-level driver for qdi ATA");
359MODULE_LICENSE("GPL");
360MODULE_VERSION(DRV_VERSION);
361
362module_init(qdi_init);
363module_exit(qdi_exit);
364
365module_param(probe_qdi, int, 0);
366
diff --git a/drivers/ata/pata_rdc.c b/drivers/ata/pata_rdc.c
index 4d318f86ae86..e6a2dd7809c1 100644
--- a/drivers/ata/pata_rdc.c
+++ b/drivers/ata/pata_rdc.c
@@ -86,6 +86,8 @@ static int rdc_pata_prereset(struct ata_link *link, unsigned long deadline)
86 return ata_sff_prereset(link, deadline); 86 return ata_sff_prereset(link, deadline);
87} 87}
88 88
89static DEFINE_SPINLOCK(rdc_lock);
90
89/** 91/**
90 * rdc_set_piomode - Initialize host controller PATA PIO timings 92 * rdc_set_piomode - Initialize host controller PATA PIO timings
91 * @ap: Port whose timings we are configuring 93 * @ap: Port whose timings we are configuring
@@ -101,6 +103,7 @@ static void rdc_set_piomode(struct ata_port *ap, struct ata_device *adev)
101{ 103{
102 unsigned int pio = adev->pio_mode - XFER_PIO_0; 104 unsigned int pio = adev->pio_mode - XFER_PIO_0;
103 struct pci_dev *dev = to_pci_dev(ap->host->dev); 105 struct pci_dev *dev = to_pci_dev(ap->host->dev);
106 unsigned long flags;
104 unsigned int is_slave = (adev->devno != 0); 107 unsigned int is_slave = (adev->devno != 0);
105 unsigned int master_port= ap->port_no ? 0x42 : 0x40; 108 unsigned int master_port= ap->port_no ? 0x42 : 0x40;
106 unsigned int slave_port = 0x44; 109 unsigned int slave_port = 0x44;
@@ -124,6 +127,8 @@ static void rdc_set_piomode(struct ata_port *ap, struct ata_device *adev)
124 if (adev->class == ATA_DEV_ATA) 127 if (adev->class == ATA_DEV_ATA)
125 control |= 4; /* PPE enable */ 128 control |= 4; /* PPE enable */
126 129
130 spin_lock_irqsave(&rdc_lock, flags);
131
127 /* PIO configuration clears DTE unconditionally. It will be 132 /* PIO configuration clears DTE unconditionally. It will be
128 * programmed in set_dmamode which is guaranteed to be called 133 * programmed in set_dmamode which is guaranteed to be called
129 * after set_piomode if any DMA mode is available. 134 * after set_piomode if any DMA mode is available.
@@ -161,6 +166,8 @@ static void rdc_set_piomode(struct ata_port *ap, struct ata_device *adev)
161 pci_read_config_byte(dev, 0x48, &udma_enable); 166 pci_read_config_byte(dev, 0x48, &udma_enable);
162 udma_enable &= ~(1 << (2 * ap->port_no + adev->devno)); 167 udma_enable &= ~(1 << (2 * ap->port_no + adev->devno));
163 pci_write_config_byte(dev, 0x48, udma_enable); 168 pci_write_config_byte(dev, 0x48, udma_enable);
169
170 spin_unlock_irqrestore(&rdc_lock, flags);
164} 171}
165 172
166/** 173/**
@@ -177,6 +184,7 @@ static void rdc_set_piomode(struct ata_port *ap, struct ata_device *adev)
177static void rdc_set_dmamode(struct ata_port *ap, struct ata_device *adev) 184static void rdc_set_dmamode(struct ata_port *ap, struct ata_device *adev)
178{ 185{
179 struct pci_dev *dev = to_pci_dev(ap->host->dev); 186 struct pci_dev *dev = to_pci_dev(ap->host->dev);
187 unsigned long flags;
180 u8 master_port = ap->port_no ? 0x42 : 0x40; 188 u8 master_port = ap->port_no ? 0x42 : 0x40;
181 u16 master_data; 189 u16 master_data;
182 u8 speed = adev->dma_mode; 190 u8 speed = adev->dma_mode;
@@ -190,6 +198,8 @@ static void rdc_set_dmamode(struct ata_port *ap, struct ata_device *adev)
190 { 2, 1 }, 198 { 2, 1 },
191 { 2, 3 }, }; 199 { 2, 3 }, };
192 200
201 spin_lock_irqsave(&rdc_lock, flags);
202
193 pci_read_config_word(dev, master_port, &master_data); 203 pci_read_config_word(dev, master_port, &master_data);
194 pci_read_config_byte(dev, 0x48, &udma_enable); 204 pci_read_config_byte(dev, 0x48, &udma_enable);
195 205
@@ -271,6 +281,8 @@ static void rdc_set_dmamode(struct ata_port *ap, struct ata_device *adev)
271 pci_write_config_word(dev, master_port, master_data); 281 pci_write_config_word(dev, master_port, master_data);
272 } 282 }
273 pci_write_config_byte(dev, 0x48, udma_enable); 283 pci_write_config_byte(dev, 0x48, udma_enable);
284
285 spin_unlock_irqrestore(&rdc_lock, flags);
274} 286}
275 287
276static struct ata_port_operations rdc_pata_ops = { 288static struct ata_port_operations rdc_pata_ops = {
@@ -375,6 +387,10 @@ static struct pci_driver rdc_pci_driver = {
375 .id_table = rdc_pci_tbl, 387 .id_table = rdc_pci_tbl,
376 .probe = rdc_init_one, 388 .probe = rdc_init_one,
377 .remove = rdc_remove_one, 389 .remove = rdc_remove_one,
390#ifdef CONFIG_PM
391 .suspend = ata_pci_device_suspend,
392 .resume = ata_pci_device_resume,
393#endif
378}; 394};
379 395
380 396
diff --git a/drivers/ata/pata_sc1200.c b/drivers/ata/pata_sc1200.c
index e2c18257adff..c0e603a84f7f 100644
--- a/drivers/ata/pata_sc1200.c
+++ b/drivers/ata/pata_sc1200.c
@@ -38,7 +38,7 @@
38#include <scsi/scsi_host.h> 38#include <scsi/scsi_host.h>
39#include <linux/libata.h> 39#include <linux/libata.h>
40 40
41#define DRV_NAME "sc1200" 41#define DRV_NAME "pata_sc1200"
42#define DRV_VERSION "0.2.6" 42#define DRV_VERSION "0.2.6"
43 43
44#define SC1200_REV_A 0x00 44#define SC1200_REV_A 0x00
@@ -86,10 +86,14 @@ static int sc1200_clock(void)
86static void sc1200_set_piomode(struct ata_port *ap, struct ata_device *adev) 86static void sc1200_set_piomode(struct ata_port *ap, struct ata_device *adev)
87{ 87{
88 static const u32 pio_timings[4][5] = { 88 static const u32 pio_timings[4][5] = {
89 {0x00009172, 0x00012171, 0x00020080, 0x00032010, 0x00040010}, // format0 33Mhz 89 /* format0, 33Mhz */
90 {0xd1329172, 0x71212171, 0x30200080, 0x20102010, 0x00100010}, // format1, 33Mhz 90 { 0x00009172, 0x00012171, 0x00020080, 0x00032010, 0x00040010 },
91 {0xfaa3f4f3, 0xc23232b2, 0x513101c1, 0x31213121, 0x10211021}, // format1, 48Mhz 91 /* format1, 33Mhz */
92 {0xfff4fff4, 0xf35353d3, 0x814102f1, 0x42314231, 0x11311131} // format1, 66Mhz 92 { 0xd1329172, 0x71212171, 0x30200080, 0x20102010, 0x00100010 },
93 /* format1, 48Mhz */
94 { 0xfaa3f4f3, 0xc23232b2, 0x513101c1, 0x31213121, 0x10211021 },
95 /* format1, 66Mhz */
96 { 0xfff4fff4, 0xf35353d3, 0x814102f1, 0x42314231, 0x11311131 }
93 }; 97 };
94 98
95 struct pci_dev *pdev = to_pci_dev(ap->host->dev); 99 struct pci_dev *pdev = to_pci_dev(ap->host->dev);
diff --git a/drivers/ata/pata_scc.c b/drivers/ata/pata_scc.c
index eb748e327143..e265f835c95d 100644
--- a/drivers/ata/pata_scc.c
+++ b/drivers/ata/pata_scc.c
@@ -826,18 +826,6 @@ static unsigned int scc_data_xfer (struct ata_device *dev, unsigned char *buf,
826} 826}
827 827
828/** 828/**
829 * scc_pata_prereset - prepare for reset
830 * @ap: ATA port to be reset
831 * @deadline: deadline jiffies for the operation
832 */
833
834static int scc_pata_prereset(struct ata_link *link, unsigned long deadline)
835{
836 link->ap->cbl = ATA_CBL_PATA80;
837 return ata_sff_prereset(link, deadline);
838}
839
840/**
841 * scc_postreset - standard postreset callback 829 * scc_postreset - standard postreset callback
842 * @ap: the target ata_port 830 * @ap: the target ata_port
843 * @classes: classes of attached devices 831 * @classes: classes of attached devices
@@ -946,7 +934,7 @@ static struct ata_port_operations scc_pata_ops = {
946 .bmdma_status = scc_bmdma_status, 934 .bmdma_status = scc_bmdma_status,
947 .sff_data_xfer = scc_data_xfer, 935 .sff_data_xfer = scc_data_xfer,
948 936
949 .prereset = scc_pata_prereset, 937 .cable_detect = ata_cable_80wire,
950 .softreset = scc_softreset, 938 .softreset = scc_softreset,
951 .postreset = scc_postreset, 939 .postreset = scc_postreset,
952 940
diff --git a/drivers/ata/pata_serverworks.c b/drivers/ata/pata_serverworks.c
index 86dd714e3e1d..71eaf385e970 100644
--- a/drivers/ata/pata_serverworks.c
+++ b/drivers/ata/pata_serverworks.c
@@ -58,31 +58,15 @@ static const char *csb_bad_ata100[] = {
58}; 58};
59 59
60/** 60/**
61 * dell_cable - Dell serverworks cable detection 61 * oem_cable - Dell/Sun serverworks cable detection
62 * @ap: ATA port to do cable detect 62 * @ap: ATA port to do cable detect
63 * 63 *
64 * Dell hide the 40/80 pin select for their interfaces in the top two 64 * Dell PowerEdge and Sun Cobalt 'Alpine' hide the 40/80 pin select
65 * bits of the subsystem ID. 65 * for their interfaces in the top two bits of the subsystem ID.
66 */ 66 */
67 67
68static int dell_cable(struct ata_port *ap) { 68static int oem_cable(struct ata_port *ap)
69 struct pci_dev *pdev = to_pci_dev(ap->host->dev); 69{
70
71 if (pdev->subsystem_device & (1 << (ap->port_no + 14)))
72 return ATA_CBL_PATA80;
73 return ATA_CBL_PATA40;
74}
75
76/**
77 * sun_cable - Sun Cobalt 'Alpine' cable detection
78 * @ap: ATA port to do cable select
79 *
80 * Cobalt CSB5 IDE hides the 40/80pin in the top two bits of the
81 * subsystem ID the same as dell. We could use one function but we may
82 * need to extend the Dell one in future
83 */
84
85static int sun_cable(struct ata_port *ap) {
86 struct pci_dev *pdev = to_pci_dev(ap->host->dev); 70 struct pci_dev *pdev = to_pci_dev(ap->host->dev);
87 71
88 if (pdev->subsystem_device & (1 << (ap->port_no + 14))) 72 if (pdev->subsystem_device & (1 << (ap->port_no + 14)))
@@ -90,49 +74,21 @@ static int sun_cable(struct ata_port *ap) {
90 return ATA_CBL_PATA40; 74 return ATA_CBL_PATA40;
91} 75}
92 76
93/**
94 * osb4_cable - OSB4 cable detect
95 * @ap: ATA port to check
96 *
97 * The OSB4 isn't UDMA66 capable so this is easy
98 */
99
100static int osb4_cable(struct ata_port *ap) {
101 return ATA_CBL_PATA40;
102}
103
104/**
105 * csb_cable - CSB5/6 cable detect
106 * @ap: ATA port to check
107 *
108 * Serverworks default arrangement is to use the drive side detection
109 * only.
110 */
111
112static int csb_cable(struct ata_port *ap) {
113 return ATA_CBL_PATA_UNK;
114}
115
116struct sv_cable_table { 77struct sv_cable_table {
117 int device; 78 int device;
118 int subvendor; 79 int subvendor;
119 int (*cable_detect)(struct ata_port *ap); 80 int (*cable_detect)(struct ata_port *ap);
120}; 81};
121 82
122/*
123 * Note that we don't copy the old serverworks code because the old
124 * code contains obvious mistakes
125 */
126
127static struct sv_cable_table cable_detect[] = { 83static struct sv_cable_table cable_detect[] = {
128 { PCI_DEVICE_ID_SERVERWORKS_CSB5IDE, PCI_VENDOR_ID_DELL, dell_cable }, 84 { PCI_DEVICE_ID_SERVERWORKS_CSB5IDE, PCI_VENDOR_ID_DELL, oem_cable },
129 { PCI_DEVICE_ID_SERVERWORKS_CSB6IDE, PCI_VENDOR_ID_DELL, dell_cable }, 85 { PCI_DEVICE_ID_SERVERWORKS_CSB6IDE, PCI_VENDOR_ID_DELL, oem_cable },
130 { PCI_DEVICE_ID_SERVERWORKS_CSB5IDE, PCI_VENDOR_ID_SUN, sun_cable }, 86 { PCI_DEVICE_ID_SERVERWORKS_CSB5IDE, PCI_VENDOR_ID_SUN, oem_cable },
131 { PCI_DEVICE_ID_SERVERWORKS_OSB4IDE, PCI_ANY_ID, osb4_cable }, 87 { PCI_DEVICE_ID_SERVERWORKS_OSB4IDE, PCI_ANY_ID, ata_cable_40wire },
132 { PCI_DEVICE_ID_SERVERWORKS_CSB5IDE, PCI_ANY_ID, csb_cable }, 88 { PCI_DEVICE_ID_SERVERWORKS_CSB5IDE, PCI_ANY_ID, ata_cable_unknown },
133 { PCI_DEVICE_ID_SERVERWORKS_CSB6IDE, PCI_ANY_ID, csb_cable }, 89 { PCI_DEVICE_ID_SERVERWORKS_CSB6IDE, PCI_ANY_ID, ata_cable_unknown },
134 { PCI_DEVICE_ID_SERVERWORKS_CSB6IDE2, PCI_ANY_ID, csb_cable }, 90 { PCI_DEVICE_ID_SERVERWORKS_CSB6IDE2, PCI_ANY_ID, ata_cable_unknown },
135 { PCI_DEVICE_ID_SERVERWORKS_HT1000IDE, PCI_ANY_ID, csb_cable }, 91 { PCI_DEVICE_ID_SERVERWORKS_HT1000IDE, PCI_ANY_ID, ata_cable_unknown },
136 { } 92 { }
137}; 93};
138 94
@@ -393,6 +349,31 @@ static void serverworks_fixup_ht1000(struct pci_dev *pdev)
393 pci_write_config_byte(pdev, 0x5A, btr); 349 pci_write_config_byte(pdev, 0x5A, btr);
394} 350}
395 351
352static int serverworks_fixup(struct pci_dev *pdev)
353{
354 int rc = 0;
355
356 /* Force master latency timer to 64 PCI clocks */
357 pci_write_config_byte(pdev, PCI_LATENCY_TIMER, 0x40);
358
359 switch (pdev->device) {
360 case PCI_DEVICE_ID_SERVERWORKS_OSB4IDE:
361 rc = serverworks_fixup_osb4(pdev);
362 break;
363 case PCI_DEVICE_ID_SERVERWORKS_CSB5IDE:
364 ata_pci_bmdma_clear_simplex(pdev);
365 /* fall through */
366 case PCI_DEVICE_ID_SERVERWORKS_CSB6IDE:
367 case PCI_DEVICE_ID_SERVERWORKS_CSB6IDE2:
368 rc = serverworks_fixup_csb(pdev);
369 break;
370 case PCI_DEVICE_ID_SERVERWORKS_HT1000IDE:
371 serverworks_fixup_ht1000(pdev);
372 break;
373 }
374
375 return rc;
376}
396 377
397static int serverworks_init_one(struct pci_dev *pdev, const struct pci_device_id *id) 378static int serverworks_init_one(struct pci_dev *pdev, const struct pci_device_id *id)
398{ 379{
@@ -430,13 +411,12 @@ static int serverworks_init_one(struct pci_dev *pdev, const struct pci_device_id
430 if (rc) 411 if (rc)
431 return rc; 412 return rc;
432 413
433 /* Force master latency timer to 64 PCI clocks */ 414 rc = serverworks_fixup(pdev);
434 pci_write_config_byte(pdev, PCI_LATENCY_TIMER, 0x40);
435 415
436 /* OSB4 : South Bridge and IDE */ 416 /* OSB4 : South Bridge and IDE */
437 if (pdev->device == PCI_DEVICE_ID_SERVERWORKS_OSB4IDE) { 417 if (pdev->device == PCI_DEVICE_ID_SERVERWORKS_OSB4IDE) {
438 /* Select non UDMA capable OSB4 if we can't do fixups */ 418 /* Select non UDMA capable OSB4 if we can't do fixups */
439 if ( serverworks_fixup_osb4(pdev) < 0) 419 if (rc < 0)
440 ppi[0] = &info[1]; 420 ppi[0] = &info[1];
441 } 421 }
442 /* setup CSB5/CSB6 : South Bridge and IDE option RAID */ 422 /* setup CSB5/CSB6 : South Bridge and IDE option RAID */
@@ -446,19 +426,13 @@ static int serverworks_init_one(struct pci_dev *pdev, const struct pci_device_id
446 426
447 /* If the returned btr is the newer revision then 427 /* If the returned btr is the newer revision then
448 select the right info block */ 428 select the right info block */
449 if (serverworks_fixup_csb(pdev) == 3) 429 if (rc == 3)
450 ppi[0] = &info[3]; 430 ppi[0] = &info[3];
451 431
452 /* Is this the 3rd channel CSB6 IDE ? */ 432 /* Is this the 3rd channel CSB6 IDE ? */
453 if (pdev->device == PCI_DEVICE_ID_SERVERWORKS_CSB6IDE2) 433 if (pdev->device == PCI_DEVICE_ID_SERVERWORKS_CSB6IDE2)
454 ppi[1] = &ata_dummy_port_info; 434 ppi[1] = &ata_dummy_port_info;
455 } 435 }
456 /* setup HT1000E */
457 else if (pdev->device == PCI_DEVICE_ID_SERVERWORKS_HT1000IDE)
458 serverworks_fixup_ht1000(pdev);
459
460 if (pdev->device == PCI_DEVICE_ID_SERVERWORKS_CSB5IDE)
461 ata_pci_bmdma_clear_simplex(pdev);
462 436
463 return ata_pci_bmdma_init_one(pdev, ppi, &serverworks_sht, NULL, 0); 437 return ata_pci_bmdma_init_one(pdev, ppi, &serverworks_sht, NULL, 0);
464} 438}
@@ -473,24 +447,7 @@ static int serverworks_reinit_one(struct pci_dev *pdev)
473 if (rc) 447 if (rc)
474 return rc; 448 return rc;
475 449
476 /* Force master latency timer to 64 PCI clocks */ 450 (void)serverworks_fixup(pdev);
477 pci_write_config_byte(pdev, PCI_LATENCY_TIMER, 0x40);
478
479 switch (pdev->device) {
480 case PCI_DEVICE_ID_SERVERWORKS_OSB4IDE:
481 serverworks_fixup_osb4(pdev);
482 break;
483 case PCI_DEVICE_ID_SERVERWORKS_CSB5IDE:
484 ata_pci_bmdma_clear_simplex(pdev);
485 /* fall through */
486 case PCI_DEVICE_ID_SERVERWORKS_CSB6IDE:
487 case PCI_DEVICE_ID_SERVERWORKS_CSB6IDE2:
488 serverworks_fixup_csb(pdev);
489 break;
490 case PCI_DEVICE_ID_SERVERWORKS_HT1000IDE:
491 serverworks_fixup_ht1000(pdev);
492 break;
493 }
494 451
495 ata_host_resume(host); 452 ata_host_resume(host);
496 return 0; 453 return 0;
diff --git a/drivers/ata/pata_sil680.c b/drivers/ata/pata_sil680.c
index 31f759b0ab71..b92eacf8dd3c 100644
--- a/drivers/ata/pata_sil680.c
+++ b/drivers/ata/pata_sil680.c
@@ -38,11 +38,12 @@
38 38
39/** 39/**
40 * sil680_selreg - return register base 40 * sil680_selreg - return register base
41 * @hwif: interface 41 * @ap: ATA interface
42 * @r: config offset 42 * @r: config offset
43 * 43 *
44 * Turn a config register offset into the right address in either 44 * Turn a config register offset into the right address in PCI space
45 * PCI space or MMIO space to access the control register in question 45 * to access the control register in question.
46 *
46 * Thankfully this is a configuration operation so isn't performance 47 * Thankfully this is a configuration operation so isn't performance
47 * criticial. 48 * criticial.
48 */ 49 */
@@ -56,12 +57,12 @@ static unsigned long sil680_selreg(struct ata_port *ap, int r)
56 57
57/** 58/**
58 * sil680_seldev - return register base 59 * sil680_seldev - return register base
59 * @hwif: interface 60 * @ap: ATA interface
60 * @r: config offset 61 * @r: config offset
61 * 62 *
62 * Turn a config register offset into the right address in either 63 * Turn a config register offset into the right address in PCI space
63 * PCI space or MMIO space to access the control register in question 64 * to access the control register in question including accounting for
64 * including accounting for the unit shift. 65 * the unit shift.
65 */ 66 */
66 67
67static unsigned long sil680_seldev(struct ata_port *ap, struct ata_device *adev, int r) 68static unsigned long sil680_seldev(struct ata_port *ap, struct ata_device *adev, int r)
@@ -81,7 +82,8 @@ static unsigned long sil680_seldev(struct ata_port *ap, struct ata_device *adev,
81 * space for us. 82 * space for us.
82 */ 83 */
83 84
84static int sil680_cable_detect(struct ata_port *ap) { 85static int sil680_cable_detect(struct ata_port *ap)
86{
85 struct pci_dev *pdev = to_pci_dev(ap->host->dev); 87 struct pci_dev *pdev = to_pci_dev(ap->host->dev);
86 unsigned long addr = sil680_selreg(ap, 0); 88 unsigned long addr = sil680_selreg(ap, 0);
87 u8 ata66; 89 u8 ata66;
@@ -93,7 +95,7 @@ static int sil680_cable_detect(struct ata_port *ap) {
93} 95}
94 96
95/** 97/**
96 * sil680_set_piomode - set initial PIO mode data 98 * sil680_set_piomode - set PIO mode data
97 * @ap: ATA interface 99 * @ap: ATA interface
98 * @adev: ATA device 100 * @adev: ATA device
99 * 101 *
@@ -104,8 +106,12 @@ static int sil680_cable_detect(struct ata_port *ap) {
104 106
105static void sil680_set_piomode(struct ata_port *ap, struct ata_device *adev) 107static void sil680_set_piomode(struct ata_port *ap, struct ata_device *adev)
106{ 108{
107 static u16 speed_p[5] = { 0x328A, 0x2283, 0x1104, 0x10C3, 0x10C1 }; 109 static const u16 speed_p[5] = {
108 static u16 speed_t[5] = { 0x328A, 0x2283, 0x1281, 0x10C3, 0x10C1 }; 110 0x328A, 0x2283, 0x1104, 0x10C3, 0x10C1
111 };
112 static const u16 speed_t[5] = {
113 0x328A, 0x2283, 0x1281, 0x10C3, 0x10C1
114 };
109 115
110 unsigned long tfaddr = sil680_selreg(ap, 0x02); 116 unsigned long tfaddr = sil680_selreg(ap, 0x02);
111 unsigned long addr = sil680_seldev(ap, adev, 0x04); 117 unsigned long addr = sil680_seldev(ap, adev, 0x04);
@@ -140,22 +146,23 @@ static void sil680_set_piomode(struct ata_port *ap, struct ata_device *adev)
140} 146}
141 147
142/** 148/**
143 * sil680_set_dmamode - set initial DMA mode data 149 * sil680_set_dmamode - set DMA mode data
144 * @ap: ATA interface 150 * @ap: ATA interface
145 * @adev: ATA device 151 * @adev: ATA device
146 * 152 *
147 * Program the MWDMA/UDMA modes for the sil680 k 153 * Program the MWDMA/UDMA modes for the sil680 chipset.
148 * chipset. The MWDMA mode values are pulled from a lookup table 154 *
155 * The MWDMA mode values are pulled from a lookup table
149 * while the chipset uses mode number for UDMA. 156 * while the chipset uses mode number for UDMA.
150 */ 157 */
151 158
152static void sil680_set_dmamode(struct ata_port *ap, struct ata_device *adev) 159static void sil680_set_dmamode(struct ata_port *ap, struct ata_device *adev)
153{ 160{
154 static u8 ultra_table[2][7] = { 161 static const u8 ultra_table[2][7] = {
155 { 0x0C, 0x07, 0x05, 0x04, 0x02, 0x01, 0xFF }, /* 100MHz */ 162 { 0x0C, 0x07, 0x05, 0x04, 0x02, 0x01, 0xFF }, /* 100MHz */
156 { 0x0F, 0x0B, 0x07, 0x05, 0x03, 0x02, 0x01 }, /* 133Mhz */ 163 { 0x0F, 0x0B, 0x07, 0x05, 0x03, 0x02, 0x01 }, /* 133Mhz */
157 }; 164 };
158 static u16 dma_table[3] = { 0x2208, 0x10C2, 0x10C1 }; 165 static const u16 dma_table[3] = { 0x2208, 0x10C2, 0x10C1 };
159 166
160 struct pci_dev *pdev = to_pci_dev(ap->host->dev); 167 struct pci_dev *pdev = to_pci_dev(ap->host->dev);
161 unsigned long ma = sil680_seldev(ap, adev, 0x08); 168 unsigned long ma = sil680_seldev(ap, adev, 0x08);
@@ -175,7 +182,7 @@ static void sil680_set_dmamode(struct ata_port *ap, struct ata_device *adev)
175 mode &= ~(0x03 << port_shift); 182 mode &= ~(0x03 << port_shift);
176 183
177 /* Extract scsc */ 184 /* Extract scsc */
178 scsc = (scsc & 0x30) ? 1: 0; 185 scsc = (scsc & 0x30) ? 1 : 0;
179 186
180 if (adev->dma_mode >= XFER_UDMA_0) { 187 if (adev->dma_mode >= XFER_UDMA_0) {
181 multi = 0x10C1; 188 multi = 0x10C1;
@@ -248,7 +255,7 @@ static u8 sil680_init_chip(struct pci_dev *pdev, int *try_mmio)
248{ 255{
249 u8 tmpbyte = 0; 256 u8 tmpbyte = 0;
250 257
251 /* FIXME: double check */ 258 /* FIXME: double check */
252 pci_write_config_byte(pdev, PCI_CACHE_LINE_SIZE, 259 pci_write_config_byte(pdev, PCI_CACHE_LINE_SIZE,
253 pdev->revision ? 1 : 255); 260 pdev->revision ? 1 : 255);
254 261
@@ -266,22 +273,22 @@ static u8 sil680_init_chip(struct pci_dev *pdev, int *try_mmio)
266 *try_mmio = (tmpbyte & 1) || pci_resource_start(pdev, 5); 273 *try_mmio = (tmpbyte & 1) || pci_resource_start(pdev, 5);
267#endif 274#endif
268 275
269 switch(tmpbyte & 0x30) { 276 switch (tmpbyte & 0x30) {
270 case 0x00: 277 case 0x00:
271 /* 133 clock attempt to force it on */ 278 /* 133 clock attempt to force it on */
272 pci_write_config_byte(pdev, 0x8A, tmpbyte|0x10); 279 pci_write_config_byte(pdev, 0x8A, tmpbyte|0x10);
273 break; 280 break;
274 case 0x30: 281 case 0x30:
275 /* if clocking is disabled */ 282 /* if clocking is disabled */
276 /* 133 clock attempt to force it on */ 283 /* 133 clock attempt to force it on */
277 pci_write_config_byte(pdev, 0x8A, tmpbyte & ~0x20); 284 pci_write_config_byte(pdev, 0x8A, tmpbyte & ~0x20);
278 break; 285 break;
279 case 0x10: 286 case 0x10:
280 /* 133 already */ 287 /* 133 already */
281 break; 288 break;
282 case 0x20: 289 case 0x20:
283 /* BIOS set PCI x2 clocking */ 290 /* BIOS set PCI x2 clocking */
284 break; 291 break;
285 } 292 }
286 293
287 pci_read_config_byte(pdev, 0x8A, &tmpbyte); 294 pci_read_config_byte(pdev, 0x8A, &tmpbyte);
@@ -299,12 +306,19 @@ static u8 sil680_init_chip(struct pci_dev *pdev, int *try_mmio)
299 pci_write_config_dword(pdev, 0xB8, 0x43924392); 306 pci_write_config_dword(pdev, 0xB8, 0x43924392);
300 pci_write_config_dword(pdev, 0xBC, 0x40094009); 307 pci_write_config_dword(pdev, 0xBC, 0x40094009);
301 308
302 switch(tmpbyte & 0x30) { 309 switch (tmpbyte & 0x30) {
303 case 0x00: printk(KERN_INFO "sil680: 100MHz clock.\n");break; 310 case 0x00:
304 case 0x10: printk(KERN_INFO "sil680: 133MHz clock.\n");break; 311 printk(KERN_INFO "sil680: 100MHz clock.\n");
305 case 0x20: printk(KERN_INFO "sil680: Using PCI clock.\n");break; 312 break;
306 /* This last case is _NOT_ ok */ 313 case 0x10:
307 case 0x30: printk(KERN_ERR "sil680: Clock disabled ?\n"); 314 printk(KERN_INFO "sil680: 133MHz clock.\n");
315 break;
316 case 0x20:
317 printk(KERN_INFO "sil680: Using PCI clock.\n");
318 break;
319 /* This last case is _NOT_ ok */
320 case 0x30:
321 printk(KERN_ERR "sil680: Clock disabled ?\n");
308 } 322 }
309 return tmpbyte & 0x30; 323 return tmpbyte & 0x30;
310} 324}
diff --git a/drivers/ata/pata_sis.c b/drivers/ata/pata_sis.c
index 533f2aefab87..b0edc7de7b2d 100644
--- a/drivers/ata/pata_sis.c
+++ b/drivers/ata/pata_sis.c
@@ -55,7 +55,7 @@ static const struct sis_laptop sis_laptop[] = {
55 /* devid, subvendor, subdev */ 55 /* devid, subvendor, subdev */
56 { 0x5513, 0x1043, 0x1107 }, /* ASUS A6K */ 56 { 0x5513, 0x1043, 0x1107 }, /* ASUS A6K */
57 { 0x5513, 0x1734, 0x105F }, /* FSC Amilo A1630 */ 57 { 0x5513, 0x1734, 0x105F }, /* FSC Amilo A1630 */
58 { 0x5513, 0x1071, 0x8640 }, /* EasyNote K5305 */ 58 { 0x5513, 0x1071, 0x8640 }, /* EasyNote K5305 */
59 /* end marker */ 59 /* end marker */
60 { 0, } 60 { 0, }
61}; 61};
@@ -76,7 +76,7 @@ static int sis_short_ata40(struct pci_dev *dev)
76} 76}
77 77
78/** 78/**
79 * sis_old_port_base - return PCI configuration base for dev 79 * sis_old_port_base - return PCI configuration base for dev
80 * @adev: device 80 * @adev: device
81 * 81 *
82 * Returns the base of the PCI configuration registers for this port 82 * Returns the base of the PCI configuration registers for this port
@@ -85,11 +85,34 @@ static int sis_short_ata40(struct pci_dev *dev)
85 85
86static int sis_old_port_base(struct ata_device *adev) 86static int sis_old_port_base(struct ata_device *adev)
87{ 87{
88 return 0x40 + (4 * adev->link->ap->port_no) + (2 * adev->devno); 88 return 0x40 + (4 * adev->link->ap->port_no) + (2 * adev->devno);
89} 89}
90 90
91/** 91/**
92 * sis_133_cable_detect - check for 40/80 pin 92 * sis_port_base - return PCI configuration base for dev
93 * @adev: device
94 *
95 * Returns the base of the PCI configuration registers for this port
96 * number.
97 */
98
99static int sis_port_base(struct ata_device *adev)
100{
101 struct ata_port *ap = adev->link->ap;
102 struct pci_dev *pdev = to_pci_dev(ap->host->dev);
103 int port = 0x40;
104 u32 reg54;
105
106 /* If bit 30 is set then the registers are mapped at 0x70 not 0x40 */
107 pci_read_config_dword(pdev, 0x54, &reg54);
108 if (reg54 & 0x40000000)
109 port = 0x70;
110
111 return port + (8 * ap->port_no) + (4 * adev->devno);
112}
113
114/**
115 * sis_133_cable_detect - check for 40/80 pin
93 * @ap: Port 116 * @ap: Port
94 * @deadline: deadline jiffies for the operation 117 * @deadline: deadline jiffies for the operation
95 * 118 *
@@ -110,7 +133,7 @@ static int sis_133_cable_detect(struct ata_port *ap)
110} 133}
111 134
112/** 135/**
113 * sis_66_cable_detect - check for 40/80 pin 136 * sis_66_cable_detect - check for 40/80 pin
114 * @ap: Port 137 * @ap: Port
115 * 138 *
116 * Perform cable detection on the UDMA66, UDMA100 and early UDMA133 139 * Perform cable detection on the UDMA66, UDMA100 and early UDMA133
@@ -132,7 +155,7 @@ static int sis_66_cable_detect(struct ata_port *ap)
132 155
133 156
134/** 157/**
135 * sis_pre_reset - probe begin 158 * sis_pre_reset - probe begin
136 * @link: ATA link 159 * @link: ATA link
137 * @deadline: deadline jiffies for the operation 160 * @deadline: deadline jiffies for the operation
138 * 161 *
@@ -160,7 +183,7 @@ static int sis_pre_reset(struct ata_link *link, unsigned long deadline)
160 183
161 184
162/** 185/**
163 * sis_set_fifo - Set RWP fifo bits for this device 186 * sis_set_fifo - Set RWP fifo bits for this device
164 * @ap: Port 187 * @ap: Port
165 * @adev: Device 188 * @adev: Device
166 * 189 *
@@ -203,13 +226,13 @@ static void sis_set_fifo(struct ata_port *ap, struct ata_device *adev)
203 226
204static void sis_old_set_piomode (struct ata_port *ap, struct ata_device *adev) 227static void sis_old_set_piomode (struct ata_port *ap, struct ata_device *adev)
205{ 228{
206 struct pci_dev *pdev = to_pci_dev(ap->host->dev); 229 struct pci_dev *pdev = to_pci_dev(ap->host->dev);
207 int port = sis_old_port_base(adev); 230 int port = sis_old_port_base(adev);
208 u8 t1, t2; 231 u8 t1, t2;
209 int speed = adev->pio_mode - XFER_PIO_0; 232 int speed = adev->pio_mode - XFER_PIO_0;
210 233
211 const u8 active[] = { 0x00, 0x07, 0x04, 0x03, 0x01 }; 234 static const u8 active[] = { 0x00, 0x07, 0x04, 0x03, 0x01 };
212 const u8 recovery[] = { 0x00, 0x06, 0x04, 0x03, 0x03 }; 235 static const u8 recovery[] = { 0x00, 0x06, 0x04, 0x03, 0x03 };
213 236
214 sis_set_fifo(ap, adev); 237 sis_set_fifo(ap, adev);
215 238
@@ -240,11 +263,11 @@ static void sis_old_set_piomode (struct ata_port *ap, struct ata_device *adev)
240 263
241static void sis_100_set_piomode (struct ata_port *ap, struct ata_device *adev) 264static void sis_100_set_piomode (struct ata_port *ap, struct ata_device *adev)
242{ 265{
243 struct pci_dev *pdev = to_pci_dev(ap->host->dev); 266 struct pci_dev *pdev = to_pci_dev(ap->host->dev);
244 int port = sis_old_port_base(adev); 267 int port = sis_old_port_base(adev);
245 int speed = adev->pio_mode - XFER_PIO_0; 268 int speed = adev->pio_mode - XFER_PIO_0;
246 269
247 const u8 actrec[] = { 0x00, 0x67, 0x44, 0x33, 0x31 }; 270 static const u8 actrec[] = { 0x00, 0x67, 0x44, 0x33, 0x31 };
248 271
249 sis_set_fifo(ap, adev); 272 sis_set_fifo(ap, adev);
250 273
@@ -265,20 +288,19 @@ static void sis_100_set_piomode (struct ata_port *ap, struct ata_device *adev)
265 288
266static void sis_133_set_piomode (struct ata_port *ap, struct ata_device *adev) 289static void sis_133_set_piomode (struct ata_port *ap, struct ata_device *adev)
267{ 290{
268 struct pci_dev *pdev = to_pci_dev(ap->host->dev); 291 struct pci_dev *pdev = to_pci_dev(ap->host->dev);
269 int port = 0x40; 292 int port;
270 u32 t1; 293 u32 t1;
271 u32 reg54;
272 int speed = adev->pio_mode - XFER_PIO_0; 294 int speed = adev->pio_mode - XFER_PIO_0;
273 295
274 const u32 timing133[] = { 296 static const u32 timing133[] = {
275 0x28269000, /* Recovery << 24 | Act << 16 | Ini << 12 */ 297 0x28269000, /* Recovery << 24 | Act << 16 | Ini << 12 */
276 0x0C266000, 298 0x0C266000,
277 0x04263000, 299 0x04263000,
278 0x0C0A3000, 300 0x0C0A3000,
279 0x05093000 301 0x05093000
280 }; 302 };
281 const u32 timing100[] = { 303 static const u32 timing100[] = {
282 0x1E1C6000, /* Recovery << 24 | Act << 16 | Ini << 12 */ 304 0x1E1C6000, /* Recovery << 24 | Act << 16 | Ini << 12 */
283 0x091C4000, 305 0x091C4000,
284 0x031C2000, 306 0x031C2000,
@@ -288,12 +310,7 @@ static void sis_133_set_piomode (struct ata_port *ap, struct ata_device *adev)
288 310
289 sis_set_fifo(ap, adev); 311 sis_set_fifo(ap, adev);
290 312
291 /* If bit 14 is set then the registers are mapped at 0x70 not 0x40 */ 313 port = sis_port_base(adev);
292 pci_read_config_dword(pdev, 0x54, &reg54);
293 if (reg54 & 0x40000000)
294 port = 0x70;
295 port += 8 * ap->port_no + 4 * adev->devno;
296
297 pci_read_config_dword(pdev, port, &t1); 314 pci_read_config_dword(pdev, port, &t1);
298 t1 &= 0xC0C00FFF; /* Mask out timing */ 315 t1 &= 0xC0C00FFF; /* Mask out timing */
299 316
@@ -319,13 +336,13 @@ static void sis_133_set_piomode (struct ata_port *ap, struct ata_device *adev)
319 336
320static void sis_old_set_dmamode (struct ata_port *ap, struct ata_device *adev) 337static void sis_old_set_dmamode (struct ata_port *ap, struct ata_device *adev)
321{ 338{
322 struct pci_dev *pdev = to_pci_dev(ap->host->dev); 339 struct pci_dev *pdev = to_pci_dev(ap->host->dev);
323 int speed = adev->dma_mode - XFER_MW_DMA_0; 340 int speed = adev->dma_mode - XFER_MW_DMA_0;
324 int drive_pci = sis_old_port_base(adev); 341 int drive_pci = sis_old_port_base(adev);
325 u16 timing; 342 u16 timing;
326 343
327 const u16 mwdma_bits[] = { 0x008, 0x302, 0x301 }; 344 static const u16 mwdma_bits[] = { 0x008, 0x302, 0x301 };
328 const u16 udma_bits[] = { 0xE000, 0xC000, 0xA000 }; 345 static const u16 udma_bits[] = { 0xE000, 0xC000, 0xA000 };
329 346
330 pci_read_config_word(pdev, drive_pci, &timing); 347 pci_read_config_word(pdev, drive_pci, &timing);
331 348
@@ -358,14 +375,14 @@ static void sis_old_set_dmamode (struct ata_port *ap, struct ata_device *adev)
358 375
359static void sis_66_set_dmamode (struct ata_port *ap, struct ata_device *adev) 376static void sis_66_set_dmamode (struct ata_port *ap, struct ata_device *adev)
360{ 377{
361 struct pci_dev *pdev = to_pci_dev(ap->host->dev); 378 struct pci_dev *pdev = to_pci_dev(ap->host->dev);
362 int speed = adev->dma_mode - XFER_MW_DMA_0; 379 int speed = adev->dma_mode - XFER_MW_DMA_0;
363 int drive_pci = sis_old_port_base(adev); 380 int drive_pci = sis_old_port_base(adev);
364 u16 timing; 381 u16 timing;
365 382
366 /* MWDMA 0-2 and UDMA 0-5 */ 383 /* MWDMA 0-2 and UDMA 0-5 */
367 const u16 mwdma_bits[] = { 0x008, 0x302, 0x301 }; 384 static const u16 mwdma_bits[] = { 0x008, 0x302, 0x301 };
368 const u16 udma_bits[] = { 0xF000, 0xD000, 0xB000, 0xA000, 0x9000, 0x8000 }; 385 static const u16 udma_bits[] = { 0xF000, 0xD000, 0xB000, 0xA000, 0x9000, 0x8000 };
369 386
370 pci_read_config_word(pdev, drive_pci, &timing); 387 pci_read_config_word(pdev, drive_pci, &timing);
371 388
@@ -397,12 +414,12 @@ static void sis_66_set_dmamode (struct ata_port *ap, struct ata_device *adev)
397 414
398static void sis_100_set_dmamode (struct ata_port *ap, struct ata_device *adev) 415static void sis_100_set_dmamode (struct ata_port *ap, struct ata_device *adev)
399{ 416{
400 struct pci_dev *pdev = to_pci_dev(ap->host->dev); 417 struct pci_dev *pdev = to_pci_dev(ap->host->dev);
401 int speed = adev->dma_mode - XFER_MW_DMA_0; 418 int speed = adev->dma_mode - XFER_MW_DMA_0;
402 int drive_pci = sis_old_port_base(adev); 419 int drive_pci = sis_old_port_base(adev);
403 u8 timing; 420 u8 timing;
404 421
405 const u8 udma_bits[] = { 0x8B, 0x87, 0x85, 0x83, 0x82, 0x81}; 422 static const u8 udma_bits[] = { 0x8B, 0x87, 0x85, 0x83, 0x82, 0x81};
406 423
407 pci_read_config_byte(pdev, drive_pci + 1, &timing); 424 pci_read_config_byte(pdev, drive_pci + 1, &timing);
408 425
@@ -431,7 +448,7 @@ static void sis_100_set_dmamode (struct ata_port *ap, struct ata_device *adev)
431 448
432static void sis_133_early_set_dmamode (struct ata_port *ap, struct ata_device *adev) 449static void sis_133_early_set_dmamode (struct ata_port *ap, struct ata_device *adev)
433{ 450{
434 struct pci_dev *pdev = to_pci_dev(ap->host->dev); 451 struct pci_dev *pdev = to_pci_dev(ap->host->dev);
435 int speed = adev->dma_mode - XFER_MW_DMA_0; 452 int speed = adev->dma_mode - XFER_MW_DMA_0;
436 int drive_pci = sis_old_port_base(adev); 453 int drive_pci = sis_old_port_base(adev);
437 u8 timing; 454 u8 timing;
@@ -464,32 +481,34 @@ static void sis_133_early_set_dmamode (struct ata_port *ap, struct ata_device *a
464 481
465static void sis_133_set_dmamode (struct ata_port *ap, struct ata_device *adev) 482static void sis_133_set_dmamode (struct ata_port *ap, struct ata_device *adev)
466{ 483{
467 struct pci_dev *pdev = to_pci_dev(ap->host->dev); 484 struct pci_dev *pdev = to_pci_dev(ap->host->dev);
468 int speed = adev->dma_mode - XFER_MW_DMA_0; 485 int port;
469 int port = 0x40;
470 u32 t1; 486 u32 t1;
471 u32 reg54;
472
473 /* bits 4- cycle time 8 - cvs time */
474 static const u32 timing_u100[] = { 0x6B0, 0x470, 0x350, 0x140, 0x120, 0x110, 0x000 };
475 static const u32 timing_u133[] = { 0x9F0, 0x6A0, 0x470, 0x250, 0x230, 0x220, 0x210 };
476
477 /* If bit 14 is set then the registers are mapped at 0x70 not 0x40 */
478 pci_read_config_dword(pdev, 0x54, &reg54);
479 if (reg54 & 0x40000000)
480 port = 0x70;
481 port += (8 * ap->port_no) + (4 * adev->devno);
482 487
488 port = sis_port_base(adev);
483 pci_read_config_dword(pdev, port, &t1); 489 pci_read_config_dword(pdev, port, &t1);
484 490
485 if (adev->dma_mode < XFER_UDMA_0) { 491 if (adev->dma_mode < XFER_UDMA_0) {
492 /* Recovery << 24 | Act << 16 | Ini << 12, like PIO modes */
493 static const u32 timing_u100[] = { 0x19154000, 0x06072000, 0x04062000 };
494 static const u32 timing_u133[] = { 0x221C6000, 0x0C0A3000, 0x05093000 };
495 int speed = adev->dma_mode - XFER_MW_DMA_0;
496
497 t1 &= 0xC0C00FFF;
498 /* disable UDMA */
486 t1 &= ~0x00000004; 499 t1 &= ~0x00000004;
487 /* FIXME: need data sheet to add MWDMA here. Also lacking on 500 if (t1 & 0x08)
488 ide/pci driver */ 501 t1 |= timing_u133[speed];
502 else
503 t1 |= timing_u100[speed];
489 } else { 504 } else {
490 speed = adev->dma_mode - XFER_UDMA_0; 505 /* bits 4- cycle time 8 - cvs time */
491 /* if & 8 no UDMA133 - need info for ... */ 506 static const u32 timing_u100[] = { 0x6B0, 0x470, 0x350, 0x140, 0x120, 0x110, 0x000 };
507 static const u32 timing_u133[] = { 0x9F0, 0x6A0, 0x470, 0x250, 0x230, 0x220, 0x210 };
508 int speed = adev->dma_mode - XFER_UDMA_0;
509
492 t1 &= ~0x00000FF0; 510 t1 &= ~0x00000FF0;
511 /* enable UDMA */
493 t1 |= 0x00000004; 512 t1 |= 0x00000004;
494 if (t1 & 0x08) 513 if (t1 & 0x08)
495 t1 |= timing_u133[speed]; 514 t1 |= timing_u133[speed];
@@ -499,6 +518,27 @@ static void sis_133_set_dmamode (struct ata_port *ap, struct ata_device *adev)
499 pci_write_config_dword(pdev, port, t1); 518 pci_write_config_dword(pdev, port, t1);
500} 519}
501 520
521/**
522 * sis_133_mode_filter - mode selection filter
523 * @adev: ATA device
524 *
525 * Block UDMA6 on devices that do not support it.
526 */
527
528static unsigned long sis_133_mode_filter(struct ata_device *adev, unsigned long mask)
529{
530 struct ata_port *ap = adev->link->ap;
531 struct pci_dev *pdev = to_pci_dev(ap->host->dev);
532 int port = sis_port_base(adev);
533 u32 t1;
534
535 pci_read_config_dword(pdev, port, &t1);
536 /* if ATA133 is disabled, mask it out */
537 if (!(t1 & 0x08))
538 mask &= ~(0xC0 << ATA_SHIFT_UDMA);
539 return mask;
540}
541
502static struct scsi_host_template sis_sht = { 542static struct scsi_host_template sis_sht = {
503 ATA_BMDMA_SHT(DRV_NAME), 543 ATA_BMDMA_SHT(DRV_NAME),
504}; 544};
@@ -520,6 +560,7 @@ static struct ata_port_operations sis_133_ops = {
520 .set_piomode = sis_133_set_piomode, 560 .set_piomode = sis_133_set_piomode,
521 .set_dmamode = sis_133_set_dmamode, 561 .set_dmamode = sis_133_set_dmamode,
522 .cable_detect = sis_133_cable_detect, 562 .cable_detect = sis_133_cable_detect,
563 .mode_filter = sis_133_mode_filter,
523}; 564};
524 565
525static struct ata_port_operations sis_133_early_ops = { 566static struct ata_port_operations sis_133_early_ops = {
@@ -588,7 +629,7 @@ static const struct ata_port_info sis_info100_early = {
588static const struct ata_port_info sis_info133 = { 629static const struct ata_port_info sis_info133 = {
589 .flags = ATA_FLAG_SLAVE_POSS, 630 .flags = ATA_FLAG_SLAVE_POSS,
590 .pio_mask = ATA_PIO4, 631 .pio_mask = ATA_PIO4,
591 /* No MWDMA */ 632 .mwdma_mask = ATA_MWDMA2,
592 .udma_mask = ATA_UDMA6, 633 .udma_mask = ATA_UDMA6,
593 .port_ops = &sis_133_ops, 634 .port_ops = &sis_133_ops,
594}; 635};
@@ -669,7 +710,7 @@ static void sis_fixup(struct pci_dev *pdev, struct sis_chipset *sis)
669 * @pdev: PCI device to register 710 * @pdev: PCI device to register
670 * @ent: Entry in sis_pci_tbl matching with @pdev 711 * @ent: Entry in sis_pci_tbl matching with @pdev
671 * 712 *
672 * Called from kernel PCI layer. We probe for combined mode (sigh), 713 * Called from kernel PCI layer. We probe for combined mode (sigh),
673 * and then hand over control to libata, for it to do the rest. 714 * and then hand over control to libata, for it to do the rest.
674 * 715 *
675 * LOCKING: 716 * LOCKING:
@@ -769,17 +810,20 @@ static int sis_init_one (struct pci_dev *pdev, const struct pci_device_id *ent)
769 810
770 switch(trueid) { 811 switch(trueid) {
771 case 0x5518: /* SIS 962/963 */ 812 case 0x5518: /* SIS 962/963 */
813 dev_info(&pdev->dev,
814 "SiS 962/963 MuTIOL IDE UDMA133 controller\n");
772 chipset = &sis133; 815 chipset = &sis133;
773 if ((idemisc & 0x40000000) == 0) { 816 if ((idemisc & 0x40000000) == 0) {
774 pci_write_config_dword(pdev, 0x54, idemisc | 0x40000000); 817 pci_write_config_dword(pdev, 0x54, idemisc | 0x40000000);
775 printk(KERN_INFO "SIS5513: Switching to 5513 register mapping\n"); 818 dev_info(&pdev->dev,
819 "Switching to 5513 register mapping\n");
776 } 820 }
777 break; 821 break;
778 case 0x0180: /* SIS 965/965L */ 822 case 0x0180: /* SIS 965/965L */
779 chipset = &sis133; 823 chipset = &sis133;
780 break; 824 break;
781 case 0x1180: /* SIS 966/966L */ 825 case 0x1180: /* SIS 966/966L */
782 chipset = &sis133; 826 chipset = &sis133;
783 break; 827 break;
784 } 828 }
785 } 829 }
diff --git a/drivers/ata/pata_sl82c105.c b/drivers/ata/pata_sl82c105.c
index c06ce8ced566..24cf200dd1c9 100644
--- a/drivers/ata/pata_sl82c105.c
+++ b/drivers/ata/pata_sl82c105.c
@@ -1,6 +1,7 @@
1/* 1/*
2 * pata_sl82c105.c - SL82C105 PATA for new ATA layer 2 * pata_sl82c105.c - SL82C105 PATA for new ATA layer
3 * (C) 2005 Red Hat Inc 3 * (C) 2005 Red Hat Inc
4 * (C) 2011 Bartlomiej Zolnierkiewicz
4 * 5 *
5 * Based in part on linux/drivers/ide/pci/sl82c105.c 6 * Based in part on linux/drivers/ide/pci/sl82c105.c
6 * SL82C105/Winbond 553 IDE driver 7 * SL82C105/Winbond 553 IDE driver
@@ -289,6 +290,14 @@ static int sl82c105_bridge_revision(struct pci_dev *pdev)
289 return bridge->revision; 290 return bridge->revision;
290} 291}
291 292
293static void sl82c105_fixup(struct pci_dev *pdev)
294{
295 u32 val;
296
297 pci_read_config_dword(pdev, 0x40, &val);
298 val |= CTRL_P0EN | CTRL_P0F16 | CTRL_P1F16;
299 pci_write_config_dword(pdev, 0x40, val);
300}
292 301
293static int sl82c105_init_one(struct pci_dev *dev, const struct pci_device_id *id) 302static int sl82c105_init_one(struct pci_dev *dev, const struct pci_device_id *id)
294{ 303{
@@ -306,7 +315,6 @@ static int sl82c105_init_one(struct pci_dev *dev, const struct pci_device_id *id
306 /* for now use only the first port */ 315 /* for now use only the first port */
307 const struct ata_port_info *ppi[] = { &info_early, 316 const struct ata_port_info *ppi[] = { &info_early,
308 NULL }; 317 NULL };
309 u32 val;
310 int rev; 318 int rev;
311 int rc; 319 int rc;
312 320
@@ -325,13 +333,28 @@ static int sl82c105_init_one(struct pci_dev *dev, const struct pci_device_id *id
325 else 333 else
326 ppi[0] = &info_dma; 334 ppi[0] = &info_dma;
327 335
328 pci_read_config_dword(dev, 0x40, &val); 336 sl82c105_fixup(dev);
329 val |= CTRL_P0EN | CTRL_P0F16 | CTRL_P1F16;
330 pci_write_config_dword(dev, 0x40, val);
331 337
332 return ata_pci_bmdma_init_one(dev, ppi, &sl82c105_sht, NULL, 0); 338 return ata_pci_bmdma_init_one(dev, ppi, &sl82c105_sht, NULL, 0);
333} 339}
334 340
341#ifdef CONFIG_PM
342static int sl82c105_reinit_one(struct pci_dev *pdev)
343{
344 struct ata_host *host = dev_get_drvdata(&pdev->dev);
345 int rc;
346
347 rc = ata_pci_device_do_resume(pdev);
348 if (rc)
349 return rc;
350
351 sl82c105_fixup(pdev);
352
353 ata_host_resume(host);
354 return 0;
355}
356#endif
357
335static const struct pci_device_id sl82c105[] = { 358static const struct pci_device_id sl82c105[] = {
336 { PCI_VDEVICE(WINBOND, PCI_DEVICE_ID_WINBOND_82C105), }, 359 { PCI_VDEVICE(WINBOND, PCI_DEVICE_ID_WINBOND_82C105), },
337 360
@@ -342,7 +365,11 @@ static struct pci_driver sl82c105_pci_driver = {
342 .name = DRV_NAME, 365 .name = DRV_NAME,
343 .id_table = sl82c105, 366 .id_table = sl82c105,
344 .probe = sl82c105_init_one, 367 .probe = sl82c105_init_one,
345 .remove = ata_pci_remove_one 368 .remove = ata_pci_remove_one,
369#ifdef CONFIG_PM
370 .suspend = ata_pci_device_suspend,
371 .resume = sl82c105_reinit_one,
372#endif
346}; 373};
347 374
348static int __init sl82c105_init(void) 375static int __init sl82c105_init(void)
diff --git a/drivers/ata/pata_via.c b/drivers/ata/pata_via.c
index 8e9f5048a10a..255f336cd7ea 100644
--- a/drivers/ata/pata_via.c
+++ b/drivers/ata/pata_via.c
@@ -509,6 +509,27 @@ static void via_config_fifo(struct pci_dev *pdev, unsigned int flags)
509 } 509 }
510} 510}
511 511
512static void via_fixup(struct pci_dev *pdev, const struct via_isa_bridge *config)
513{
514 u32 timing;
515
516 /* Initialise the FIFO for the enabled channels. */
517 via_config_fifo(pdev, config->flags);
518
519 if (config->udma_mask == ATA_UDMA4) {
520 /* The 66 MHz devices require we enable the clock */
521 pci_read_config_dword(pdev, 0x50, &timing);
522 timing |= 0x80008;
523 pci_write_config_dword(pdev, 0x50, timing);
524 }
525 if (config->flags & VIA_BAD_CLK66) {
526 /* Disable the 66MHz clock on problem devices */
527 pci_read_config_dword(pdev, 0x50, &timing);
528 timing &= ~0x80008;
529 pci_write_config_dword(pdev, 0x50, timing);
530 }
531}
532
512/** 533/**
513 * via_init_one - discovery callback 534 * via_init_one - discovery callback
514 * @pdev: PCI device 535 * @pdev: PCI device
@@ -570,7 +591,6 @@ static int via_init_one(struct pci_dev *pdev, const struct pci_device_id *id)
570 struct pci_dev *isa; 591 struct pci_dev *isa;
571 const struct via_isa_bridge *config; 592 const struct via_isa_bridge *config;
572 u8 enable; 593 u8 enable;
573 u32 timing;
574 unsigned long flags = id->driver_data; 594 unsigned long flags = id->driver_data;
575 int rc; 595 int rc;
576 596
@@ -609,9 +629,6 @@ static int via_init_one(struct pci_dev *pdev, const struct pci_device_id *id)
609 return -ENODEV; 629 return -ENODEV;
610 } 630 }
611 631
612 /* Initialise the FIFO for the enabled channels. */
613 via_config_fifo(pdev, config->flags);
614
615 /* Clock set up */ 632 /* Clock set up */
616 switch (config->udma_mask) { 633 switch (config->udma_mask) {
617 case 0x00: 634 case 0x00:
@@ -637,12 +654,7 @@ static int via_init_one(struct pci_dev *pdev, const struct pci_device_id *id)
637 return -ENODEV; 654 return -ENODEV;
638 } 655 }
639 656
640 if (config->flags & VIA_BAD_CLK66) { 657 via_fixup(pdev, config);
641 /* Disable the 66MHz clock on problem devices */
642 pci_read_config_dword(pdev, 0x50, &timing);
643 timing &= ~0x80008;
644 pci_write_config_dword(pdev, 0x50, timing);
645 }
646 658
647 /* We have established the device type, now fire it up */ 659 /* We have established the device type, now fire it up */
648 return ata_pci_bmdma_init_one(pdev, ppi, &via_sht, (void *)config, 0); 660 return ata_pci_bmdma_init_one(pdev, ppi, &via_sht, (void *)config, 0);
@@ -661,29 +673,14 @@ static int via_init_one(struct pci_dev *pdev, const struct pci_device_id *id)
661 673
662static int via_reinit_one(struct pci_dev *pdev) 674static int via_reinit_one(struct pci_dev *pdev)
663{ 675{
664 u32 timing;
665 struct ata_host *host = dev_get_drvdata(&pdev->dev); 676 struct ata_host *host = dev_get_drvdata(&pdev->dev);
666 const struct via_isa_bridge *config = host->private_data;
667 int rc; 677 int rc;
668 678
669 rc = ata_pci_device_do_resume(pdev); 679 rc = ata_pci_device_do_resume(pdev);
670 if (rc) 680 if (rc)
671 return rc; 681 return rc;
672 682
673 via_config_fifo(pdev, config->flags); 683 via_fixup(pdev, host->private_data);
674
675 if (config->udma_mask == ATA_UDMA4) {
676 /* The 66 MHz devices require we enable the clock */
677 pci_read_config_dword(pdev, 0x50, &timing);
678 timing |= 0x80008;
679 pci_write_config_dword(pdev, 0x50, timing);
680 }
681 if (config->flags & VIA_BAD_CLK66) {
682 /* Disable the 66MHz clock on problem devices */
683 pci_read_config_dword(pdev, 0x50, &timing);
684 timing &= ~0x80008;
685 pci_write_config_dword(pdev, 0x50, timing);
686 }
687 684
688 ata_host_resume(host); 685 ata_host_resume(host);
689 return 0; 686 return 0;
diff --git a/drivers/ata/sata_mv.c b/drivers/ata/sata_mv.c
index 4b6b2090784b..0b8b8b488ee8 100644
--- a/drivers/ata/sata_mv.c
+++ b/drivers/ata/sata_mv.c
@@ -4087,8 +4087,11 @@ static int mv_platform_probe(struct platform_device *pdev)
4087 dev_info(&pdev->dev, "slots %u ports %d\n", 4087 dev_info(&pdev->dev, "slots %u ports %d\n",
4088 (unsigned)MV_MAX_Q_DEPTH, host->n_ports); 4088 (unsigned)MV_MAX_Q_DEPTH, host->n_ports);
4089 4089
4090 return ata_host_activate(host, platform_get_irq(pdev, 0), mv_interrupt, 4090 rc = ata_host_activate(host, platform_get_irq(pdev, 0), mv_interrupt,
4091 IRQF_SHARED, &mv6_sht); 4091 IRQF_SHARED, &mv6_sht);
4092 if (!rc)
4093 return 0;
4094
4092err: 4095err:
4093#if defined(CONFIG_HAVE_CLK) 4096#if defined(CONFIG_HAVE_CLK)
4094 if (!IS_ERR(hpriv->clk)) { 4097 if (!IS_ERR(hpriv->clk)) {
@@ -4110,8 +4113,7 @@ err:
4110 */ 4113 */
4111static int __devexit mv_platform_remove(struct platform_device *pdev) 4114static int __devexit mv_platform_remove(struct platform_device *pdev)
4112{ 4115{
4113 struct device *dev = &pdev->dev; 4116 struct ata_host *host = platform_get_drvdata(pdev);
4114 struct ata_host *host = dev_get_drvdata(dev);
4115#if defined(CONFIG_HAVE_CLK) 4117#if defined(CONFIG_HAVE_CLK)
4116 struct mv_host_priv *hpriv = host->private_data; 4118 struct mv_host_priv *hpriv = host->private_data;
4117#endif 4119#endif
@@ -4129,7 +4131,7 @@ static int __devexit mv_platform_remove(struct platform_device *pdev)
4129#ifdef CONFIG_PM 4131#ifdef CONFIG_PM
4130static int mv_platform_suspend(struct platform_device *pdev, pm_message_t state) 4132static int mv_platform_suspend(struct platform_device *pdev, pm_message_t state)
4131{ 4133{
4132 struct ata_host *host = dev_get_drvdata(&pdev->dev); 4134 struct ata_host *host = platform_get_drvdata(pdev);
4133 if (host) 4135 if (host)
4134 return ata_host_suspend(host, state); 4136 return ata_host_suspend(host, state);
4135 else 4137 else
@@ -4138,7 +4140,7 @@ static int mv_platform_suspend(struct platform_device *pdev, pm_message_t state)
4138 4140
4139static int mv_platform_resume(struct platform_device *pdev) 4141static int mv_platform_resume(struct platform_device *pdev)
4140{ 4142{
4141 struct ata_host *host = dev_get_drvdata(&pdev->dev); 4143 struct ata_host *host = platform_get_drvdata(pdev);
4142 int ret; 4144 int ret;
4143 4145
4144 if (host) { 4146 if (host) {
@@ -4353,7 +4355,7 @@ static int mv_pci_init_one(struct pci_dev *pdev,
4353#ifdef CONFIG_PM 4355#ifdef CONFIG_PM
4354static int mv_pci_device_resume(struct pci_dev *pdev) 4356static int mv_pci_device_resume(struct pci_dev *pdev)
4355{ 4357{
4356 struct ata_host *host = dev_get_drvdata(&pdev->dev); 4358 struct ata_host *host = pci_get_drvdata(pdev);
4357 int rc; 4359 int rc;
4358 4360
4359 rc = ata_pci_device_do_resume(pdev); 4361 rc = ata_pci_device_do_resume(pdev);
diff --git a/drivers/ata/sata_sil24.c b/drivers/ata/sata_sil24.c
index 55470f337e51..1e9140626a83 100644
--- a/drivers/ata/sata_sil24.c
+++ b/drivers/ata/sata_sil24.c
@@ -268,7 +268,7 @@ union sil24_cmd_block {
268 struct sil24_atapi_block atapi; 268 struct sil24_atapi_block atapi;
269}; 269};
270 270
271static struct sil24_cerr_info { 271static const struct sil24_cerr_info {
272 unsigned int err_mask, action; 272 unsigned int err_mask, action;
273 const char *desc; 273 const char *desc;
274} sil24_cerr_db[] = { 274} sil24_cerr_db[] = {
@@ -1019,7 +1019,7 @@ static void sil24_error_intr(struct ata_port *ap)
1019 1019
1020 /* deal with command error */ 1020 /* deal with command error */
1021 if (irq_stat & PORT_IRQ_ERROR) { 1021 if (irq_stat & PORT_IRQ_ERROR) {
1022 struct sil24_cerr_info *ci = NULL; 1022 const struct sil24_cerr_info *ci = NULL;
1023 unsigned int err_mask = 0, action = 0; 1023 unsigned int err_mask = 0, action = 0;
1024 u32 context, cerr; 1024 u32 context, cerr;
1025 int pmp; 1025 int pmp;
diff --git a/drivers/ata/sata_sis.c b/drivers/ata/sata_sis.c
index 447d9c05fb5a..95ec435f0eb4 100644
--- a/drivers/ata/sata_sis.c
+++ b/drivers/ata/sata_sis.c
@@ -104,7 +104,7 @@ static const struct ata_port_info sis_port_info = {
104}; 104};
105 105
106MODULE_AUTHOR("Uwe Koziolek"); 106MODULE_AUTHOR("Uwe Koziolek");
107MODULE_DESCRIPTION("low-level driver for Silicon Integratad Systems SATA controller"); 107MODULE_DESCRIPTION("low-level driver for Silicon Integrated Systems SATA controller");
108MODULE_LICENSE("GPL"); 108MODULE_LICENSE("GPL");
109MODULE_DEVICE_TABLE(pci, sis_pci_tbl); 109MODULE_DEVICE_TABLE(pci, sis_pci_tbl);
110MODULE_VERSION(DRV_VERSION); 110MODULE_VERSION(DRV_VERSION);