scsi: hisi_sas: Change frame type for SET MAX commands
authorchenxiang <chenxiang66@hisilicon.com>
Thu, 28 Dec 2017 10:20:47 +0000 (18:20 +0800)
committerMartin K. Petersen <martin.petersen@oracle.com>
Thu, 11 Jan 2018 04:25:08 +0000 (23:25 -0500)
According to ATA protocol, SET MAX commands belong to different frame
types. So judge features field of SET MAX commands to decide which
frame type they belongs to.

Signed-off-by: Xiang Chen <chenxiang66@hisilicon.com>
Signed-off-by: John Garry <john.garry@huawei.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/scsi/hisi_sas/hisi_sas.h
drivers/scsi/hisi_sas/hisi_sas_main.c
drivers/scsi/hisi_sas/hisi_sas_v2_hw.c
drivers/scsi/hisi_sas/hisi_sas_v3_hw.c

index cc050299cc0b62a53130072e52c2e33601dbd5cc..4000de429430238060fd390b0b8c4aac39eeeb0a 100644 (file)
@@ -441,7 +441,8 @@ extern void hisi_sas_stop_phys(struct hisi_hba *hisi_hba);
 extern void hisi_sas_init_add(struct hisi_hba *hisi_hba);
 extern int hisi_sas_alloc(struct hisi_hba *hisi_hba, struct Scsi_Host *shost);
 extern void hisi_sas_free(struct hisi_hba *hisi_hba);
-extern u8 hisi_sas_get_ata_protocol(u8 cmd, int direction);
+extern u8 hisi_sas_get_ata_protocol(struct host_to_dev_fis *fis,
+                               int direction);
 extern struct hisi_sas_port *to_hisi_sas_port(struct asd_sas_port *sas_port);
 extern void hisi_sas_sata_done(struct sas_task *task,
                            struct hisi_sas_slot *slot);
index 819b1d0ded8911377ac986a78cd0655933c809dc..360ecefba10ac9e2adef715c011286e760105030 100644 (file)
@@ -25,9 +25,9 @@ static int hisi_sas_softreset_ata_disk(struct domain_device *device);
 static int hisi_sas_control_phy(struct asd_sas_phy *sas_phy, enum phy_func func,
                                void *funcdata);
 
-u8 hisi_sas_get_ata_protocol(u8 cmd, int direction)
+u8 hisi_sas_get_ata_protocol(struct host_to_dev_fis *fis, int direction)
 {
-       switch (cmd) {
+       switch (fis->command) {
        case ATA_CMD_FPDMA_WRITE:
        case ATA_CMD_FPDMA_READ:
        case ATA_CMD_FPDMA_RECV:
@@ -79,10 +79,26 @@ u8 hisi_sas_get_ata_protocol(u8 cmd, int direction)
        case ATA_CMD_ZAC_MGMT_OUT:
        return HISI_SAS_SATA_PROTOCOL_NONDATA;
        default:
+       {
+               if (fis->command == ATA_CMD_SET_MAX) {
+                       switch (fis->features) {
+                       case ATA_SET_MAX_PASSWD:
+                       case ATA_SET_MAX_LOCK:
+                       return HISI_SAS_SATA_PROTOCOL_PIO;
+
+                       case ATA_SET_MAX_PASSWD_DMA:
+                       case ATA_SET_MAX_UNLOCK_DMA:
+                       return HISI_SAS_SATA_PROTOCOL_DMA;
+
+                       default:
+                       return HISI_SAS_SATA_PROTOCOL_NONDATA;
+                       }
+               }
                if (direction == DMA_NONE)
                        return HISI_SAS_SATA_PROTOCOL_NONDATA;
                return HISI_SAS_SATA_PROTOCOL_PIO;
        }
+       }
 }
 EXPORT_SYMBOL_GPL(hisi_sas_get_ata_protocol);
 
index b8fe08d9b1ce91c9b8b79af323605bc5f4424767..ebee2e4632457704d506f5519068bd8b6896ce50 100644 (file)
@@ -2539,7 +2539,7 @@ static int prep_ata_v2_hw(struct hisi_hba *hisi_hba,
                dw1 |= 1 << CMD_HDR_RESET_OFF;
 
        dw1 |= (hisi_sas_get_ata_protocol(
-               task->ata_task.fis.command, task->data_dir))
+               &task->ata_task.fis, task->data_dir))
                << CMD_HDR_FRAME_TYPE_OFF;
        dw1 |= sas_dev->device_id << CMD_HDR_DEV_ID_OFF;
        hdr->dw1 = cpu_to_le32(dw1);
index 6a408d2e92f53dacbf027de9166f65b73852b17b..a1f18689729a4b965b546d4b445305a6e4fddb02 100644 (file)
@@ -1047,7 +1047,7 @@ static int prep_ata_v3_hw(struct hisi_hba *hisi_hba,
                dw1 |= 1 << CMD_HDR_RESET_OFF;
 
        dw1 |= (hisi_sas_get_ata_protocol(
-               task->ata_task.fis.command, task->data_dir))
+               &task->ata_task.fis, task->data_dir))
                << CMD_HDR_FRAME_TYPE_OFF;
        dw1 |= sas_dev->device_id << CMD_HDR_DEV_ID_OFF;