diff --git a/drivers/scsi/hisi_sas/hisi_sas_v3_hw.c b/drivers/scsi/hisi_sas/hisi_sas_v3_hw.c
index cb0940f81de1e837f579a04b4a456835b2621491..35d579121b286d82b8422d0df7a83b0223cdecc1 100644
--- a/drivers/scsi/hisi_sas/hisi_sas_v3_hw.c
+++ b/drivers/scsi/hisi_sas/hisi_sas_v3_hw.c
@@ -413,6 +413,8 @@
 #define CMPLT_HDR_DEV_ID_OFF		16
 #define CMPLT_HDR_DEV_ID_MSK		(0xffff << CMPLT_HDR_DEV_ID_OFF)
 /* dw3 */
+/* ERR_CODE */
+#define SATA_DISK_IN_ERROR_STATUS	BIT(8)
 #define COMLT_HDR_SATA_DISK_ERR_OFF	16
 #define CMPLT_HDR_SATA_DISK_ERR_MSK	(0x1 << COMLT_HDR_SATA_DISK_ERR_OFF)
 #define CMPLT_HDR_IO_IN_TARGET_OFF	17
@@ -2275,7 +2277,8 @@ slot_err_v3_hw(struct hisi_hba *hisi_hba, struct sas_task *task,
 		if ((dw0 & CMPLT_HDR_RSPNS_XFRD_MSK) &&
 			(sipc_rx_err_type & RX_FIS_STATUS_ERR_MSK)) {
 			ts->stat = SAS_PROTO_RESPONSE;
-		} else if (dw3 & CMPLT_HDR_IO_IN_TARGET_MSK) {
+		} else if ((dw3 & CMPLT_HDR_IO_IN_TARGET_MSK) ||
+			(dw3 & SATA_DISK_IN_ERROR_STATUS)) {
 			ts->stat = SAS_PHY_DOWN;
 			slot->abort = 1;
 		} else if (dma_rx_err_type & RX_DATA_LEN_UNDERFLOW_MSK) {