RTW89_CHK_FW_FEATURE(NO_DEEP_PS, &rtwdev->fw))
                return RTW89_PS_MODE_NONE;
 
-       if (chip->ps_mode_supported & BIT(RTW89_PS_MODE_PWR_GATED))
+       if ((chip->ps_mode_supported & BIT(RTW89_PS_MODE_PWR_GATED)) &&
+           !RTW89_CHK_FW_FEATURE(NO_LPS_PG, &rtwdev->fw))
                return RTW89_PS_MODE_PWR_GATED;
 
        if (chip->ps_mode_supported & BIT(RTW89_PS_MODE_CLK_GATED))
        rtw89_core_ppdu_sts_init(rtwdev);
        rtw89_traffic_stats_init(rtwdev, &rtwdev->stats);
 
-       rtwdev->ps_mode = rtw89_update_ps_mode(rtwdev);
        rtwdev->hal.rx_fltr = DEFAULT_AX_RX_FLTR;
 
        INIT_WORK(&btc->eapol_notify_work, rtw89_btc_ntfy_eapol_packet_work);
        if (ret)
                return ret;
 
+       rtwdev->ps_mode = rtw89_update_ps_mode(rtwdev);
+
        return 0;
 }
 EXPORT_SYMBOL(rtw89_chip_info_setup);
 
        RTW89_FW_FEATURE_CRASH_TRIGGER,
        RTW89_FW_FEATURE_PACKET_DROP,
        RTW89_FW_FEATURE_NO_DEEP_PS,
+       RTW89_FW_FEATURE_NO_LPS_PG,
 };
 
 struct rtw89_fw_suit {
 
        __CFG_FW_FEAT(RTL8852A, ge, 0, 13, 35, 0, TX_WAKE),
        __CFG_FW_FEAT(RTL8852A, ge, 0, 13, 36, 0, CRASH_TRIGGER),
        __CFG_FW_FEAT(RTL8852A, ge, 0, 13, 38, 0, PACKET_DROP),
+       __CFG_FW_FEAT(RTL8852B, ge, 0, 29, 26, 0, NO_LPS_PG),
        __CFG_FW_FEAT(RTL8852C, ge, 0, 27, 20, 0, PACKET_DROP),
        __CFG_FW_FEAT(RTL8852C, le, 0, 27, 33, 0, NO_DEEP_PS),
        __CFG_FW_FEAT(RTL8852C, ge, 0, 27, 34, 0, TX_WAKE),