FIELD_PREP(MT_TIMEOUT_VAL_CCA, 48);
        u32 ofdm = FIELD_PREP(MT_TIMEOUT_VAL_PLCP, 60) |
                   FIELD_PREP(MT_TIMEOUT_VAL_CCA, 28);
-       int sifs, offset;
+       int offset;
        bool is_5ghz = phy->mt76->chandef.chan->band == NL80211_BAND_5GHZ;
 
        if (!test_bit(MT76_STATE_RUNNING, &phy->mt76->state))
                return;
 
-       if (is_5ghz)
-               sifs = 16;
-       else
-               sifs = 10;
-
        if (ext_phy) {
                coverage_class = max_t(s16, dev->phy.coverage_class,
                                       coverage_class);
        mt76_wr(dev, MT_TMAC_CDTR(ext_phy), cck + reg_offset);
        mt76_wr(dev, MT_TMAC_ODTR(ext_phy), ofdm + reg_offset);
        mt76_wr(dev, MT_TMAC_ICR0(ext_phy),
-               FIELD_PREP(MT_IFS_EIFS, 360) |
+               FIELD_PREP(MT_IFS_EIFS_OFDM, is_5ghz ? 84 : 78) |
                FIELD_PREP(MT_IFS_RIFS, 2) |
-               FIELD_PREP(MT_IFS_SIFS, sifs) |
+               FIELD_PREP(MT_IFS_SIFS, 10) |
                FIELD_PREP(MT_IFS_SLOT, phy->slottime));
 
+       mt76_wr(dev, MT_TMAC_ICR1(ext_phy),
+               FIELD_PREP(MT_IFS_EIFS_CCK, 314));
+
        if (phy->slottime < 20 || is_5ghz)
                val = MT7915_CFEND_RATE_DEFAULT;
        else
 
 #define MT_TMAC_TRCR0_I2T_CHK          GENMASK(24, 16)
 
 #define MT_TMAC_ICR0(_band)            MT_WF_TMAC(_band, 0x0a4)
-#define MT_IFS_EIFS                    GENMASK(8, 0)
+#define MT_IFS_EIFS_OFDM                       GENMASK(8, 0)
 #define MT_IFS_RIFS                    GENMASK(14, 10)
 #define MT_IFS_SIFS                    GENMASK(22, 16)
 #define MT_IFS_SLOT                    GENMASK(30, 24)
 
+#define MT_TMAC_ICR1(_band)            MT_WF_TMAC(_band, 0x0b4)
+#define MT_IFS_EIFS_CCK                        GENMASK(8, 0)
+
 #define MT_TMAC_CTCR0(_band)                   MT_WF_TMAC(_band, 0x0f4)
 #define MT_TMAC_CTCR0_INS_DDLMT_REFTIME                GENMASK(5, 0)
 #define MT_TMAC_CTCR0_INS_DDLMT_EN             BIT(17)