]> www.infradead.org Git - nvme.git/commitdiff
drm/i915/dp: Check for HAS_DSC_3ENGINES while configuring DSC slices
authorAnkit Nautiyal <ankit.k.nautiyal@intel.com>
Mon, 14 Apr 2025 02:42:56 +0000 (08:12 +0530)
committerJani Nikula <jani.nikula@intel.com>
Tue, 15 Apr 2025 07:33:37 +0000 (10:33 +0300)
DSC 12 slices configuration is used for some specific cases with
Ultrajoiner. This can be supported only when each of the 4 joined pipes
have 3 DSC engines each.

Add the missing check for 3 DSC engines support before using 3 DSC
slices per pipe.

Fixes: be7f5fcdf4a0 ("drm/i915/dp: Enable 3 DSC engines for 12 slices")
Cc: Ankit Nautiyal <ankit.k.nautiyal@intel.com>
Cc: Suraj Kandpal <suraj.kandpal@intel.com>
Cc: <stable@vger.kernel.org> # v6.14+
Signed-off-by: Ankit Nautiyal <ankit.k.nautiyal@intel.com>
Reviewed-by: Suraj Kandpal <suraj.kandpal@intel.com>
Link: https://lore.kernel.org/r/20250414024256.2782702-3-ankit.k.nautiyal@intel.com
(cherry picked from commit da9b1c61e7f7b327dd70c5f073ba04d419a55ef8)
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
drivers/gpu/drm/i915/display/intel_dp.c

index 9476aaa9190056d8a4d2bba5aff906ec03965dc5..392c3653d0d73834c2062bf6bde47aa5344948d9 100644 (file)
@@ -1050,10 +1050,11 @@ u8 intel_dp_dsc_get_slice_count(const struct intel_connector *connector,
                u8 test_slice_count = valid_dsc_slicecount[i] * num_joined_pipes;
 
                /*
-                * 3 DSC Slices per pipe need 3 DSC engines,
-                * which is supported only with Ultrajoiner.
+                * 3 DSC Slices per pipe need 3 DSC engines, which is supported only
+                * with Ultrajoiner only for some platforms.
                 */
-               if (valid_dsc_slicecount[i] == 3 && num_joined_pipes != 4)
+               if (valid_dsc_slicecount[i] == 3 &&
+                   (!HAS_DSC_3ENGINES(display) || num_joined_pipes != 4))
                        continue;
 
                if (test_slice_count >