|
@@ -127,6 +127,7 @@
|
|
|
#define PHY_CTRL_RESET_OFF 0
|
|
|
#define PHY_CTRL_RESET_MSK (0x1 << PHY_CTRL_RESET_OFF)
|
|
|
#define SL_CFG (PORT_BASE + 0x84)
|
|
|
+#define AIP_LIMIT (PORT_BASE + 0x90)
|
|
|
#define SL_CONTROL (PORT_BASE + 0x94)
|
|
|
#define SL_CONTROL_NOTIFY_EN_OFF 0
|
|
|
#define SL_CONTROL_NOTIFY_EN_MSK (0x1 << SL_CONTROL_NOTIFY_EN_OFF)
|
|
@@ -431,6 +432,7 @@ static void init_reg_v3_hw(struct hisi_hba *hisi_hba)
|
|
|
(u32)((1ULL << hisi_hba->queue_count) - 1));
|
|
|
hisi_sas_write32(hisi_hba, CFG_MAX_TAG, 0xfff0400);
|
|
|
hisi_sas_write32(hisi_hba, HGC_SAS_TXFAIL_RETRY_CTRL, 0x108);
|
|
|
+ hisi_sas_write32(hisi_hba, CFG_AGING_TIME, 0x1);
|
|
|
hisi_sas_write32(hisi_hba, INT_COAL_EN, 0x1);
|
|
|
hisi_sas_write32(hisi_hba, OQ_INT_COAL_TIME, 0x1);
|
|
|
hisi_sas_write32(hisi_hba, OQ_INT_COAL_CNT, 0x1);
|
|
@@ -495,6 +497,7 @@ static void init_reg_v3_hw(struct hisi_hba *hisi_hba)
|
|
|
|
|
|
/* used for 12G negotiate */
|
|
|
hisi_sas_phy_write32(hisi_hba, i, COARSETUNE_TIME, 0x1e);
|
|
|
+ hisi_sas_phy_write32(hisi_hba, i, AIP_LIMIT, 0x2ffff);
|
|
|
}
|
|
|
|
|
|
for (i = 0; i < hisi_hba->queue_count; i++) {
|