]> git.proxmox.com Git - mirror_ubuntu-jammy-kernel.git/commitdiff
scsi: hisi_sas: Retry 3 times TMF IO for SAS disks when init device
authorXiang Chen <chenxiang66@hisilicon.com>
Fri, 6 Sep 2019 12:55:29 +0000 (20:55 +0800)
committerMartin K. Petersen <martin.petersen@oracle.com>
Wed, 11 Sep 2019 02:28:56 +0000 (22:28 -0400)
When init device for SAS disks, it will send TMF IO to clear disks. At that
time TMF IO is broken by some operations such as injecting controller reset
from HW RAs event, the TMF IO will be timeout, and at last device will be
gone. Print is as followed:

hisi_sas_v3_hw 0000:74:02.0: dev[240:1] found
...
hisi_sas_v3_hw 0000:74:02.0: controller resetting...
hisi_sas_v3_hw 0000:74:02.0: phyup: phy7 link_rate=10(sata)
hisi_sas_v3_hw 0000:74:02.0: phyup: phy0 link_rate=9(sata)
hisi_sas_v3_hw 0000:74:02.0: phyup: phy1 link_rate=9(sata)
hisi_sas_v3_hw 0000:74:02.0: phyup: phy2 link_rate=9(sata)
hisi_sas_v3_hw 0000:74:02.0: phyup: phy3 link_rate=9(sata)
hisi_sas_v3_hw 0000:74:02.0: phyup: phy6 link_rate=10(sata)
hisi_sas_v3_hw 0000:74:02.0: phyup: phy5 link_rate=11
hisi_sas_v3_hw 0000:74:02.0: phyup: phy4 link_rate=11
hisi_sas_v3_hw 0000:74:02.0: controller reset complete
hisi_sas_v3_hw 0000:74:02.0: abort tmf: TMF task timeout and not done
hisi_sas_v3_hw 0000:74:02.0: dev[240:1] is gone
sas: driver on host 0000:74:02.0 cannot handle device 5000c500a75a860d,
error:5

To improve the reliability, retry TMF IO max of 3 times for SAS disks which
is the same as softreset does.

Link: https://lore.kernel.org/r/1567774537-20003-6-git-send-email-john.garry@huawei.com
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_main.c

index a3691154e13c4cec8b830c687531d699f5d66cd0..6392869a4e414d30ead4c38d844ee558dee6f4cf 100644 (file)
@@ -698,13 +698,13 @@ static struct hisi_sas_device *hisi_sas_alloc_dev(struct domain_device *device)
        return sas_dev;
 }
 
-#define HISI_SAS_SRST_ATA_DISK_CNT 3
+#define HISI_SAS_DISK_RECOVER_CNT 3
 static int hisi_sas_init_device(struct domain_device *device)
 {
        int rc = TMF_RESP_FUNC_COMPLETE;
        struct scsi_lun lun;
        struct hisi_sas_tmf_task tmf_task;
-       int retry = HISI_SAS_SRST_ATA_DISK_CNT;
+       int retry = HISI_SAS_DISK_RECOVER_CNT;
        struct hisi_hba *hisi_hba = dev_to_hisi_hba(device);
        struct device *dev = hisi_hba->dev;
        struct sas_phy *local_phy;
@@ -714,10 +714,14 @@ static int hisi_sas_init_device(struct domain_device *device)
                int_to_scsilun(0, &lun);
 
                tmf_task.tmf = TMF_CLEAR_TASK_SET;
-               rc = hisi_sas_debug_issue_ssp_tmf(device, lun.scsi_lun,
-                                                 &tmf_task);
-               if (rc == TMF_RESP_FUNC_COMPLETE)
-                       hisi_sas_release_task(hisi_hba, device);
+               while (retry-- > 0) {
+                       rc = hisi_sas_debug_issue_ssp_tmf(device, lun.scsi_lun,
+                                                         &tmf_task);
+                       if (rc == TMF_RESP_FUNC_COMPLETE) {
+                               hisi_sas_release_task(hisi_hba, device);
+                               break;
+                       }
+               }
                break;
        case SAS_SATA_DEV:
        case SAS_SATA_PM: