Skip to content

Commit 28e59c7

Browse files
committed
drm/i915/dp: Factor out compute_min_compressed_bpp_x16()
Factor out compute_min_compressed_bpp_x16() also used during mode validation in a follow-up change. Reviewed-by: Vinod Govindapillai <vinod.govindapillai@intel.com> Signed-off-by: Imre Deak <imre.deak@intel.com> Link: https://patch.msgid.link/20251222153547.713360-11-imre.deak@intel.com
1 parent 07b34db commit 28e59c7

1 file changed

Lines changed: 18 additions & 8 deletions

File tree

drivers/gpu/drm/i915/display/intel_dp.c

Lines changed: 18 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -2646,6 +2646,23 @@ dsc_throughput_quirk_max_bpp_x16(const struct intel_connector *connector,
26462646
return fxp_q4_from_int(12);
26472647
}
26482648

2649+
static int compute_min_compressed_bpp_x16(struct intel_connector *connector,
2650+
enum intel_output_format output_format)
2651+
{
2652+
int dsc_src_min_bpp, dsc_sink_min_bpp, dsc_min_bpp;
2653+
int min_bpp_x16;
2654+
2655+
dsc_src_min_bpp = intel_dp_dsc_min_src_compressed_bpp();
2656+
dsc_sink_min_bpp = intel_dp_dsc_sink_min_compressed_bpp(output_format);
2657+
dsc_min_bpp = max(dsc_src_min_bpp, dsc_sink_min_bpp);
2658+
2659+
min_bpp_x16 = fxp_q4_from_int(dsc_min_bpp);
2660+
2661+
min_bpp_x16 = align_min_compressed_bpp_x16(connector, min_bpp_x16);
2662+
2663+
return min_bpp_x16;
2664+
}
2665+
26492666
/*
26502667
* Calculate the output link min, max bpp values in limits based on the pipe bpp
26512668
* range, crtc_state and dsc mode. Return true on success.
@@ -2675,18 +2692,11 @@ intel_dp_compute_config_link_bpp_limits(struct intel_connector *connector,
26752692

26762693
limits->link.min_bpp_x16 = fxp_q4_from_int(limits->pipe.min_bpp);
26772694
} else {
2678-
int dsc_src_min_bpp, dsc_sink_min_bpp, dsc_min_bpp;
26792695
int dsc_src_max_bpp, dsc_sink_max_bpp, dsc_max_bpp;
26802696
int throughput_max_bpp_x16;
26812697
int joiner_max_bpp;
2682-
2683-
dsc_src_min_bpp = intel_dp_dsc_min_src_compressed_bpp();
2684-
dsc_sink_min_bpp = intel_dp_dsc_sink_min_compressed_bpp(crtc_state->output_format);
2685-
dsc_min_bpp = max(dsc_src_min_bpp, dsc_sink_min_bpp);
2686-
limits->link.min_bpp_x16 = fxp_q4_from_int(dsc_min_bpp);
2687-
26882698
limits->link.min_bpp_x16 =
2689-
align_min_compressed_bpp_x16(connector, limits->link.min_bpp_x16);
2699+
compute_min_compressed_bpp_x16(connector, crtc_state->output_format);
26902700

26912701
dsc_src_max_bpp = dsc_src_max_compressed_bpp(intel_dp);
26922702
joiner_max_bpp =

0 commit comments

Comments
 (0)