aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/ata/pata_hpt37x.c89
1 files changed, 43 insertions, 46 deletions
diff --git a/drivers/ata/pata_hpt37x.c b/drivers/ata/pata_hpt37x.c
index 6003a34d614e..29d8adc52733 100644
--- a/drivers/ata/pata_hpt37x.c
+++ b/drivers/ata/pata_hpt37x.c
@@ -24,7 +24,7 @@
24#include <linux/libata.h> 24#include <linux/libata.h>
25 25
26#define DRV_NAME "pata_hpt37x" 26#define DRV_NAME "pata_hpt37x"
27#define DRV_VERSION "0.6.20" 27#define DRV_VERSION "0.6.21"
28 28
29struct hpt_clock { 29struct hpt_clock {
30 u8 xfer_speed; 30 u8 xfer_speed;
@@ -838,7 +838,8 @@ static int hpt37x_init_one(struct pci_dev *dev, const struct pci_device_id *id)
838 if (rc) 838 if (rc)
839 return rc; 839 return rc;
840 840
841 if (dev->device == PCI_DEVICE_ID_TTI_HPT366) { 841 switch (dev->device) {
842 case PCI_DEVICE_ID_TTI_HPT366:
842 /* May be a later chip in disguise. Check */ 843 /* May be a later chip in disguise. Check */
843 /* Older chips are in the HPT366 driver. Ignore them */ 844 /* Older chips are in the HPT366 driver. Ignore them */
844 if (rev < 3) 845 if (rev < 3)
@@ -867,50 +868,46 @@ static int hpt37x_init_one(struct pci_dev *dev, const struct pci_device_id *id)
867 "please report (%d).\n", rev); 868 "please report (%d).\n", rev);
868 return -ENODEV; 869 return -ENODEV;
869 } 870 }
870 } else { 871 break;
871 switch (dev->device) { 872 case PCI_DEVICE_ID_TTI_HPT372:
872 case PCI_DEVICE_ID_TTI_HPT372: 873 /* 372N if rev >= 2 */
873 /* 372N if rev >= 2 */ 874 if (rev >= 2)
874 if (rev >= 2) 875 return -ENODEV;
875 return -ENODEV; 876 ppi[0] = &info_hpt372;
876 ppi[0] = &info_hpt372; 877 chip_table = &hpt372a;
877 chip_table = &hpt372a; 878 break;
878 break; 879 case PCI_DEVICE_ID_TTI_HPT302:
879 case PCI_DEVICE_ID_TTI_HPT302: 880 /* 302N if rev > 1 */
880 /* 302N if rev > 1 */ 881 if (rev > 1)
881 if (rev > 1) 882 return -ENODEV;
882 return -ENODEV; 883 ppi[0] = &info_hpt302;
883 ppi[0] = &info_hpt302; 884 /* Check this */
884 /* Check this */ 885 chip_table = &hpt302;
885 chip_table = &hpt302; 886 break;
886 break; 887 case PCI_DEVICE_ID_TTI_HPT371:
887 case PCI_DEVICE_ID_TTI_HPT371: 888 if (rev > 1)
888 if (rev > 1) 889 return -ENODEV;
889 return -ENODEV; 890 ppi[0] = &info_hpt302;
890 ppi[0] = &info_hpt302; 891 chip_table = &hpt371;
891 chip_table = &hpt371; 892 /*
892 /* 893 * Single channel device, master is not present but the BIOS
893 * Single channel device, master is not present 894 * (or us for non x86) must mark it absent
894 * but the BIOS (or us for non x86) must mark it 895 */
895 * absent 896 pci_read_config_byte(dev, 0x50, &mcr1);
896 */ 897 mcr1 &= ~0x04;
897 pci_read_config_byte(dev, 0x50, &mcr1); 898 pci_write_config_byte(dev, 0x50, mcr1);
898 mcr1 &= ~0x04; 899 break;
899 pci_write_config_byte(dev, 0x50, mcr1); 900 case PCI_DEVICE_ID_TTI_HPT374:
900 break; 901 chip_table = &hpt374;
901 case PCI_DEVICE_ID_TTI_HPT374: 902 if (!(PCI_FUNC(dev->devfn) & 1))
902 chip_table = &hpt374; 903 *ppi = &info_hpt374_fn0;
903 if (!(PCI_FUNC(dev->devfn) & 1)) 904 else
904 *ppi = &info_hpt374_fn0; 905 *ppi = &info_hpt374_fn1;
905 else 906 break;
906 *ppi = &info_hpt374_fn1; 907 default:
907 break; 908 pr_err(DRV_NAME ": PCI table is bogus, please report (%d).\n",
908 default: 909 dev->device);
909 pr_err(DRV_NAME 910 return -ENODEV;
910 ": PCI table is bogus, please report (%d).\n",
911 dev->device);
912 return -ENODEV;
913 }
914 } 911 }
915 /* Ok so this is a chip we support */ 912 /* Ok so this is a chip we support */
916 913