[SCSI] pm80xx: Device id changes to support series 8 controllers.
authorAnand Kumar Santhanam <AnandKumar.Santhanam@pmcs.com>
Tue, 3 Sep 2013 09:39:42 +0000 (15:09 +0530)
committerJames Bottomley <JBottomley@Parallels.com>
Fri, 25 Oct 2013 08:58:13 +0000 (09:58 +0100)
Updated pci id table with device, vendor, subdevice and subvendor ids
for 8074, 8076, 8077 SAS/SATA 12G controllers. Added 12G related macros.

Signed-off-by: Anandkumar.Santhanam@pmcs.com
Reviewed-by: Jack Wang <jinpu.wang@profitbricks.com>
Signed-off-by: James Bottomley <JBottomley@Parallels.com>
drivers/scsi/pm8001/pm8001_defs.h
drivers/scsi/pm8001/pm8001_init.c
drivers/scsi/pm8001/pm8001_sas.h
drivers/scsi/pm8001/pm80xx_hwi.c
drivers/scsi/pm8001/pm80xx_hwi.h

index 479c5a7a863a8aa8fded8e4164b8377d3658089d..4bb304d379da2ca5471781b603dbbc9841de62fc 100644 (file)
@@ -46,7 +46,10 @@ enum chip_flavors {
        chip_8008,
        chip_8009,
        chip_8018,
-       chip_8019
+       chip_8019,
+       chip_8074,
+       chip_8076,
+       chip_8077
 };
 
 enum phy_speed {
index f7c189606b8479b3626bcbfe621dbb953e5ee02e..93e2d9e9d2b3cdb37a3e02632f36f525a9c8dc67 100644 (file)
@@ -54,6 +54,9 @@ static const struct pm8001_chip_info pm8001_chips[] = {
        [chip_8009] = {1,  8, &pm8001_80xx_dispatch,},
        [chip_8018] = {0,  16, &pm8001_80xx_dispatch,},
        [chip_8019] = {1,  16, &pm8001_80xx_dispatch,},
+       [chip_8074] = {0,  8, &pm8001_80xx_dispatch,},
+       [chip_8076] = {0,  16, &pm8001_80xx_dispatch,},
+       [chip_8077] = {0,  16, &pm8001_80xx_dispatch,},
 };
 static int pm8001_id;
 
@@ -1037,6 +1040,12 @@ static struct pci_device_id pm8001_pci_table[] = {
        { PCI_VDEVICE(ADAPTEC2, 0x8009), chip_8009 },
        { PCI_VDEVICE(PMC_Sierra, 0x8019), chip_8019 },
        { PCI_VDEVICE(ADAPTEC2, 0x8019), chip_8019 },
+       { PCI_VDEVICE(PMC_Sierra, 0x8074), chip_8074 },
+       { PCI_VDEVICE(ADAPTEC2, 0x8074), chip_8074 },
+       { PCI_VDEVICE(PMC_Sierra, 0x8076), chip_8076 },
+       { PCI_VDEVICE(ADAPTEC2, 0x8076), chip_8076 },
+       { PCI_VDEVICE(PMC_Sierra, 0x8077), chip_8077 },
+       { PCI_VDEVICE(ADAPTEC2, 0x8077), chip_8077 },
        { PCI_VENDOR_ID_ADAPTEC2, 0x8081,
                PCI_VENDOR_ID_ADAPTEC2, 0x0400, 0, 0, chip_8001 },
        { PCI_VENDOR_ID_ADAPTEC2, 0x8081,
@@ -1057,6 +1066,24 @@ static struct pci_device_id pm8001_pci_table[] = {
                PCI_VENDOR_ID_ADAPTEC2, 0x0016, 0, 0, chip_8019 },
        { PCI_VENDOR_ID_ADAPTEC2, 0x8089,
                PCI_VENDOR_ID_ADAPTEC2, 0x1600, 0, 0, chip_8019 },
+       { PCI_VENDOR_ID_ADAPTEC2, 0x8074,
+               PCI_VENDOR_ID_ADAPTEC2, 0x0800, 0, 0, chip_8074 },
+       { PCI_VENDOR_ID_ADAPTEC2, 0x8076,
+               PCI_VENDOR_ID_ADAPTEC2, 0x1600, 0, 0, chip_8076 },
+       { PCI_VENDOR_ID_ADAPTEC2, 0x8077,
+               PCI_VENDOR_ID_ADAPTEC2, 0x1600, 0, 0, chip_8077 },
+       { PCI_VENDOR_ID_ADAPTEC2, 0x8074,
+               PCI_VENDOR_ID_ADAPTEC2, 0x0008, 0, 0, chip_8074 },
+       { PCI_VENDOR_ID_ADAPTEC2, 0x8076,
+               PCI_VENDOR_ID_ADAPTEC2, 0x0016, 0, 0, chip_8076 },
+       { PCI_VENDOR_ID_ADAPTEC2, 0x8077,
+               PCI_VENDOR_ID_ADAPTEC2, 0x0016, 0, 0, chip_8077 },
+       { PCI_VENDOR_ID_ADAPTEC2, 0x8076,
+               PCI_VENDOR_ID_ADAPTEC2, 0x0808, 0, 0, chip_8076 },
+       { PCI_VENDOR_ID_ADAPTEC2, 0x8077,
+               PCI_VENDOR_ID_ADAPTEC2, 0x0808, 0, 0, chip_8077 },
+       { PCI_VENDOR_ID_ADAPTEC2, 0x8074,
+               PCI_VENDOR_ID_ADAPTEC2, 0x0404, 0, 0, chip_8074 },
        {} /* terminate list */
 };
 
@@ -1108,8 +1135,11 @@ module_init(pm8001_init);
 module_exit(pm8001_exit);
 
 MODULE_AUTHOR("Jack Wang <jack_wang@usish.com>");
+MODULE_AUTHOR("Anand Kumar Santhanam <AnandKumar.Santhanam@pmcs.com>");
+MODULE_AUTHOR("Sangeetha Gnanasekaran <Sangeetha.Gnanasekaran@pmcs.com>");
 MODULE_DESCRIPTION(
-               "PMC-Sierra PM8001/8081/8088/8089 SAS/SATA controller driver");
+               "PMC-Sierra PM8001/8081/8088/8089/8074/8076/8077 "
+               "SAS/SATA controller driver");
 MODULE_VERSION(DRV_VERSION);
 MODULE_LICENSE("GPL");
 MODULE_DEVICE_TABLE(pci, pm8001_pci_table);
index 570819464d90b40568477eac1e4c283ae10c3169..68e1147e3cecf77ca39d72dbef84c8f6db740b03 100644 (file)
@@ -104,6 +104,9 @@ do {                                                \
 
 
 #define DEV_IS_EXPANDER(type)  ((type == SAS_EDGE_EXPANDER_DEVICE) || (type == SAS_FANOUT_EXPANDER_DEVICE))
+#define IS_SPCV_12G(dev)       ((dev->device == 0X8074)                \
+                               || (dev->device == 0X8076)              \
+                               || (dev->device == 0X8077))
 
 #define PM8001_NAME_LENGTH             32/* generic length of strings */
 extern struct list_head hba_list;
index 9f91030211e84e4edb8479e84ef26c8dabe509a0..6f836d18f26918ad8425c35a92c3eb5577f73473 100644 (file)
@@ -430,7 +430,11 @@ static int mpi_init_check(struct pm8001_hba_info *pm8001_ha)
        table is updated */
        pm8001_cw32(pm8001_ha, 0, MSGU_IBDB_SET, SPCv_MSGU_CFG_TABLE_UPDATE);
        /* wait until Inbound DoorBell Clear Register toggled */
-       max_wait_count = 2 * 1000 * 1000;/* 2 sec for spcv/ve */
+       if (IS_SPCV_12G(pm8001_ha->pdev)) {
+               max_wait_count = 4 * 1000 * 1000;/* 4 sec */
+       } else {
+               max_wait_count = 2 * 1000 * 1000;/* 2 sec */
+       }
        do {
                udelay(1);
                value = pm8001_cr32(pm8001_ha, 0, MSGU_IBDB_SET);
@@ -913,7 +917,11 @@ static int mpi_uninit_check(struct pm8001_hba_info *pm8001_ha)
        pm8001_cw32(pm8001_ha, 0, MSGU_IBDB_SET, SPCv_MSGU_CFG_TABLE_RESET);
 
        /* wait until Inbound DoorBell Clear Register toggled */
-       max_wait_count = 2 * 1000 * 1000;       /* 2 sec for spcv/ve */
+       if (IS_SPCV_12G(pm8001_ha->pdev)) {
+               max_wait_count = 4 * 1000 * 1000;/* 4 sec */
+       } else {
+               max_wait_count = 2 * 1000 * 1000;/* 2 sec */
+       }
        do {
                udelay(1);
                value = pm8001_cr32(pm8001_ha, 0, MSGU_IBDB_SET);
@@ -3941,9 +3949,16 @@ pm80xx_chip_phy_start_req(struct pm8001_hba_info *pm8001_ha, u8 phy_id)
         ** [14]        0b disable spin up hold; 1b enable spin up hold
         ** [15] ob no change in current PHY analig setup 1b enable using SPAST
         */
-       payload.ase_sh_lm_slr_phyid = cpu_to_le32(SPINHOLD_DISABLE |
-                       LINKMODE_AUTO | LINKRATE_15 |
-                       LINKRATE_30 | LINKRATE_60 | phy_id);
+       if (!IS_SPCV_12G(pm8001_ha->pdev))
+               payload.ase_sh_lm_slr_phyid = cpu_to_le32(SPINHOLD_DISABLE |
+                               LINKMODE_AUTO | LINKRATE_15 |
+                               LINKRATE_30 | LINKRATE_60 | phy_id);
+       else
+               payload.ase_sh_lm_slr_phyid = cpu_to_le32(SPINHOLD_DISABLE |
+                               LINKMODE_AUTO | LINKRATE_15 |
+                               LINKRATE_30 | LINKRATE_60 | LINKRATE_120 |
+                               phy_id);
+
        /* SSC Disable and SAS Analog ST configuration */
        /**
        payload.ase_sh_lm_slr_phyid =
index 2b760ba75d7bcca5ae008a30621b925414922f44..9a9116d435660216683162d92fdf38f6b2b212d8 100644 (file)
 #define LINKRATE_15                    (0x01 << 8)
 #define LINKRATE_30                    (0x02 << 8)
 #define LINKRATE_60                    (0x06 << 8)
+#define LINKRATE_120                   (0x08 << 8)
 
 /* Thermal related */
 #define        THERMAL_ENABLE                  0x1
@@ -1223,10 +1224,10 @@ typedef struct SASProtocolTimerConfig SASProtocolTimerConfig_t;
 
 /* MSGU CONFIGURATION TABLE*/
 
-#define SPCv_MSGU_CFG_TABLE_UPDATE             0x01
-#define SPCv_MSGU_CFG_TABLE_RESET              0x02
-#define SPCv_MSGU_CFG_TABLE_FREEZE             0x04
-#define SPCv_MSGU_CFG_TABLE_UNFREEZE           0x08
+#define SPCv_MSGU_CFG_TABLE_UPDATE             0x001
+#define SPCv_MSGU_CFG_TABLE_RESET              0x002
+#define SPCv_MSGU_CFG_TABLE_FREEZE             0x004
+#define SPCv_MSGU_CFG_TABLE_UNFREEZE           0x008
 #define MSGU_IBDB_SET                          0x00
 #define MSGU_HOST_INT_STATUS                   0x08
 #define MSGU_HOST_INT_MASK                     0x0C