Commit 7c8601ae authored by Imre Deak's avatar Imre Deak

drm/i915: Fix fractional bpp handling in intel_link_bw_reduce_bpp()

Convert crtc_state->pipe_bpp to U6.4 format as expected by the rest of
the function.

Fixes: 59a266f0 ("drm/i915/display: Store compressed bpp in U6.4 format")
Cc: Ankit Nautiyal <ankit.k.nautiyal@intel.com>
Cc: Suraj Kandpal <suraj.kandpal@intel.com>
Cc: Sui Jingfeng <suijingfeng@loongson.cn>
Reviewed-by: default avatarAnkit Nautiyal <ankit.k.nautiyal@intel.com>
Signed-off-by: default avatarImre Deak <imre.deak@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20231114141012.603960-1-imre.deak@intel.com
parent ef75c25e
...@@ -55,11 +55,11 @@ int intel_link_bw_reduce_bpp(struct intel_atomic_state *state, ...@@ -55,11 +55,11 @@ int intel_link_bw_reduce_bpp(struct intel_atomic_state *state,
struct drm_i915_private *i915 = to_i915(state->base.dev); struct drm_i915_private *i915 = to_i915(state->base.dev);
enum pipe max_bpp_pipe = INVALID_PIPE; enum pipe max_bpp_pipe = INVALID_PIPE;
struct intel_crtc *crtc; struct intel_crtc *crtc;
int max_bpp = 0; int max_bpp_x16 = 0;
for_each_intel_crtc_in_pipe_mask(&i915->drm, crtc, pipe_mask) { for_each_intel_crtc_in_pipe_mask(&i915->drm, crtc, pipe_mask) {
struct intel_crtc_state *crtc_state; struct intel_crtc_state *crtc_state;
int link_bpp; int link_bpp_x16;
if (limits->bpp_limit_reached_pipes & BIT(crtc->pipe)) if (limits->bpp_limit_reached_pipes & BIT(crtc->pipe))
continue; continue;
...@@ -70,7 +70,7 @@ int intel_link_bw_reduce_bpp(struct intel_atomic_state *state, ...@@ -70,7 +70,7 @@ int intel_link_bw_reduce_bpp(struct intel_atomic_state *state,
return PTR_ERR(crtc_state); return PTR_ERR(crtc_state);
if (crtc_state->dsc.compression_enable) if (crtc_state->dsc.compression_enable)
link_bpp = crtc_state->dsc.compressed_bpp_x16; link_bpp_x16 = crtc_state->dsc.compressed_bpp_x16;
else else
/* /*
* TODO: for YUV420 the actual link bpp is only half * TODO: for YUV420 the actual link bpp is only half
...@@ -78,10 +78,10 @@ int intel_link_bw_reduce_bpp(struct intel_atomic_state *state, ...@@ -78,10 +78,10 @@ int intel_link_bw_reduce_bpp(struct intel_atomic_state *state,
* is based on the pipe bpp value, set the actual link bpp * is based on the pipe bpp value, set the actual link bpp
* limit here once the MST BW allocation is fixed. * limit here once the MST BW allocation is fixed.
*/ */
link_bpp = crtc_state->pipe_bpp; link_bpp_x16 = to_bpp_x16(crtc_state->pipe_bpp);
if (link_bpp > max_bpp) { if (link_bpp_x16 > max_bpp_x16) {
max_bpp = link_bpp; max_bpp_x16 = link_bpp_x16;
max_bpp_pipe = crtc->pipe; max_bpp_pipe = crtc->pipe;
} }
} }
...@@ -89,7 +89,7 @@ int intel_link_bw_reduce_bpp(struct intel_atomic_state *state, ...@@ -89,7 +89,7 @@ int intel_link_bw_reduce_bpp(struct intel_atomic_state *state,
if (max_bpp_pipe == INVALID_PIPE) if (max_bpp_pipe == INVALID_PIPE)
return -ENOSPC; return -ENOSPC;
limits->max_bpp_x16[max_bpp_pipe] = to_bpp_x16(max_bpp) - 1; limits->max_bpp_x16[max_bpp_pipe] = max_bpp_x16 - 1;
return intel_modeset_pipes_in_mask_early(state, reason, return intel_modeset_pipes_in_mask_early(state, reason,
BIT(max_bpp_pipe)); BIT(max_bpp_pipe));
......
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