* empty which leads to allocate_mst_payload() has "0"
                                 * pbn_per_slot value leading to exception on dc_fixpt_div()
                                 */
-                               link->verified_link_cap = link->reported_link_cap;
+                               dp_verify_mst_link_cap(link);
+
                                if (prev_sink != NULL)
                                        dc_sink_release(prev_sink);
                                return false;
 
        if (link->link_enc->features.flags.bits.IS_HBR3_CAPABLE)
                max_link_cap.link_rate = LINK_RATE_HIGH3;
 
+       if (link->link_enc->funcs->get_max_link_cap)
+               link->link_enc->funcs->get_max_link_cap(link->link_enc, &max_link_cap);
+
        /* Lower link settings based on sink's link cap */
        if (link->reported_link_cap.lane_count < max_link_cap.lane_count)
                max_link_cap.lane_count =
        return success;
 }
 
+bool dp_verify_mst_link_cap(
+       struct dc_link *link)
+{
+       struct dc_link_settings max_link_cap = {0};
+
+       max_link_cap = get_max_link_cap(link);
+       link->verified_link_cap = get_common_supported_link_settings(
+               link->reported_link_cap,
+               max_link_cap);
+
+       return true;
+}
+
 static struct dc_link_settings get_common_supported_link_settings(
                struct dc_link_settings link_setting_a,
                struct dc_link_settings link_setting_b)
 
                type RDPCS_TX_FIFO_ERROR_MASK;\
                type RDPCS_DPALT_DISABLE_TOGGLE_MASK;\
                type RDPCS_DPALT_4LANE_TOGGLE_MASK;\
+               type RDPCS_PHY_DPALT_DP4;\
                type RDPCS_PHY_DPALT_DISABLE;\
                type RDPCS_PHY_DPALT_DISABLE_ACK;\
                type RDPCS_PHY_DP_MPLLB_V2I;\
 
        struct dc_link_settings *known_limit_link_setting,
        int attempts);
 
+bool dp_verify_mst_link_cap(
+       struct dc_link *link);
+
 bool dp_validate_mode_timing(
        struct dc_link *link,
        const struct dc_crtc_timing *timing);
 
        bool (*fec_is_active)(struct link_encoder *enc);
 #endif
        bool (*is_in_alt_mode) (struct link_encoder *enc);
+
+       void (*get_max_link_cap)(struct link_encoder *enc,
+               struct dc_link_settings *link_settings);
+
        enum signal_type (*get_dig_mode)(
                struct link_encoder *enc);
 };