Commit d075bca4 authored by Imre Deak's avatar Imre Deak

drm/dp_mst: Swap the order of checking root vs. non-root port BW limitations

drm_dp_mst_atomic_check_mgr() should check for BW limitation starting
from sink ports continuing towards the root port, so that drivers can
use the @failing_port returned to resolve a BW overallocation in an
ideal way. For instance from streams A,B,C in a topology A,B going
through @failing_port and C not going through it, a BW overallocation of
A,B due to a limit of the port must be resolved first before considering
the limits of other ports closer to the root port. This way can avoid
reducing the BW of stream C unnecessarily due to a BW limit closer to the
root port.

Based on the above swap the order of the BW check for the root port and
the check for all the ports downstream of it (the latter going through
the topology already in the sink->root port direction).

Cc: Lyude Paul <lyude@redhat.com>
Cc: dri-devel@lists.freedesktop.org
Reviewed-by: default avatarLyude Paul <lyude@redhat.com>
Reviewed-by: default avatarStanislav Lisovskiy <stanislav.lisovskiy@intel.com>
Acked-by: default avatarMaxime Ripard <mripard@kernel.org>
Signed-off-by: default avatarImre Deak <imre.deak@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20231030155843.2251023-6-imre.deak@intel.com
parent 1cd0a5ea
...@@ -5469,9 +5469,13 @@ EXPORT_SYMBOL(drm_dp_mst_atomic_enable_dsc); ...@@ -5469,9 +5469,13 @@ EXPORT_SYMBOL(drm_dp_mst_atomic_enable_dsc);
* - %-ENOSPC, if the new state is invalid, because of BW limitation * - %-ENOSPC, if the new state is invalid, because of BW limitation
* @failing_port is set to: * @failing_port is set to:
* - The non-root port where a BW limit check failed * - The non-root port where a BW limit check failed
* with all the ports downstream of @failing_port passing
* the BW limit check.
* The returned port pointer is valid until at least * The returned port pointer is valid until at least
* one payload downstream of it exists. * one payload downstream of it exists.
* - %NULL if the BW limit check failed at the root port * - %NULL if the BW limit check failed at the root port
* with all the ports downstream of the root port passing
* the BW limit check.
* - %-EINVAL, if the new state is invalid, because the root port has * - %-EINVAL, if the new state is invalid, because the root port has
* too many payloads. * too many payloads.
*/ */
...@@ -5487,17 +5491,16 @@ int drm_dp_mst_atomic_check_mgr(struct drm_atomic_state *state, ...@@ -5487,17 +5491,16 @@ int drm_dp_mst_atomic_check_mgr(struct drm_atomic_state *state,
if (!mgr->mst_state) if (!mgr->mst_state)
return 0; return 0;
ret = drm_dp_mst_atomic_check_payload_alloc_limits(mgr, mst_state);
if (ret)
return ret;
mutex_lock(&mgr->lock); mutex_lock(&mgr->lock);
ret = drm_dp_mst_atomic_check_mstb_bw_limit(mgr->mst_primary, ret = drm_dp_mst_atomic_check_mstb_bw_limit(mgr->mst_primary,
mst_state, mst_state,
failing_port); failing_port);
mutex_unlock(&mgr->lock); mutex_unlock(&mgr->lock);
return ret < 0 ? ret : 0; if (ret < 0)
return ret;
return drm_dp_mst_atomic_check_payload_alloc_limits(mgr, mst_state);
} }
EXPORT_SYMBOL(drm_dp_mst_atomic_check_mgr); EXPORT_SYMBOL(drm_dp_mst_atomic_check_mgr);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment