Use single for loops instead of two. Especially switching from a
for-loop to a do-while-loop with the same loop index is confusing, and
it's hard to figure out the end index. Define the end in terms of
lut_size; there's three more entries after the first 32.

Signed-off-by: Jani Nikula <[email protected]>
---
 drivers/gpu/drm/i915/display/intel_color.c | 26 ++++++++--------------
 1 file changed, 9 insertions(+), 17 deletions(-)

diff --git a/drivers/gpu/drm/i915/display/intel_color.c 
b/drivers/gpu/drm/i915/display/intel_color.c
index 48f09c73e513..5c09c5dd361e 100644
--- a/drivers/gpu/drm/i915/display/intel_color.c
+++ b/drivers/gpu/drm/i915/display/intel_color.c
@@ -4024,35 +4024,27 @@ xelpd_program_plane_post_csc_lut(struct intel_dsb *dsb,
        intel_de_write_dsb(display, dsb, 
PLANE_POST_CSC_GAMC_SEG0_INDEX_ENH(pipe, plane, 0),
                           PLANE_PAL_PREC_AUTO_INCREMENT);
        if (post_csc_lut) {
-               for (i = 0; i < lut_size; i++) {
-                       lut_val = 
drm_color_lut32_extract(post_csc_lut[i].green, 24);
+               for (i = 0; i < lut_size + 3; i++) {
+                       if (i < lut_size)
+                               lut_val = 
drm_color_lut32_extract(post_csc_lut[i].green, 24);
+                       /* else clamp to the last LUT value to prevent step 
discontinuity */
 
                        intel_de_write_dsb(display, dsb,
                                           PLANE_POST_CSC_GAMC_DATA_ENH(pipe, 
plane, 0),
                                           lut_val);
                }
-
-               /* Segment 2 - clamp to the last LUT value to prevent step 
discontinuity */
-               do {
-                       intel_de_write_dsb(display, dsb,
-                                          PLANE_POST_CSC_GAMC_DATA_ENH(pipe, 
plane, 0),
-                                          lut_val);
-               } while (i++ < 34);
        } else {
                /*TODO: Add for segment 0 */
-               for (i = 0; i < lut_size; i++) {
-                       lut_val = (i * ((1 << 24) - 1)) / (lut_size - 1);
+               for (i = 0; i < lut_size + 3; i++) {
+                       if (i < lut_size)
+                               lut_val = (i * ((1 << 24) - 1)) / (lut_size - 
1);
+                       else
+                               lut_val = 1 << 24;
 
                        intel_de_write_dsb(display, dsb,
                                           PLANE_POST_CSC_GAMC_DATA_ENH(pipe, 
plane, 0),
                                           lut_val);
                }
-
-               do {
-                       intel_de_write_dsb(display, dsb,
-                                          PLANE_POST_CSC_GAMC_DATA_ENH(pipe, 
plane, 0),
-                                          1 << 24);
-               } while (i++ < 34);
        }
 
        intel_de_write_dsb(display, dsb, PLANE_POST_CSC_GAMC_INDEX_ENH(pipe, 
plane, 0), 0);
-- 
2.47.3

Reply via email to