]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm: renesas: rz-du: Move mode_valid logic to per-SoC clock limits
authorLad Prabhakar <prabhakar.mahadev-lad.rj@bp.renesas.com>
Tue, 19 May 2026 16:08:24 +0000 (17:08 +0100)
committerBiju Das <biju.das.jz@bp.renesas.com>
Fri, 22 May 2026 06:31:36 +0000 (07:31 +0100)
Move pixel clock validation from a fixed encoder check to per SoC
constraints stored in rzg2l_du_device_info.

Pixel clock limits differ across SoCs in the RZ DU family and cannot be
expressed by a single shared rule. For example, RZ/G2UL and RZ/G2L limit
the DPAD0 pixel clock to a narrow window, while other SoCs such as
RZ/T2H require a wider operating range.

Add mode_clock_min and mode_clock_max fields to rzg2l_du_device_info to
describe the supported pixel clock range for each SoC. Update
rzg2l_du_encoder_mode_valid() to check these bounds when evaluating
DPAD0 outputs, returning MODE_CLOCK_LOW when the pixel clock falls
below mode_clock_min and MODE_CLOCK_HIGH when it exceeds mode_clock_max.

Populate the pixel clock limits for both the RZ/G2UL (R9A07G043U) and
RZ/G2L (R9A07G044) variants to a minimum of 20875 kHz and a maximum of
83500 kHz.

Signed-off-by: Lad Prabhakar <prabhakar.mahadev-lad.rj@bp.renesas.com>
Reviewed-by: Biju Das <biju.das.jz@bp.renesas.com>
Link: https://patch.msgid.link/20260519160825.4082566-5-prabhakar.mahadev-lad.rj@bp.renesas.com
Signed-off-by: Biju Das <biju.das.jz@bp.renesas.com>
drivers/gpu/drm/renesas/rz-du/rzg2l_du_drv.c
drivers/gpu/drm/renesas/rz-du/rzg2l_du_drv.h
drivers/gpu/drm/renesas/rz-du/rzg2l_du_encoder.c

index 0fef33a5a0890d765e9f705697651c62502c23bd..1e4b9f38c55bed4ceda71387e22ed17f0adf0b4b 100644 (file)
@@ -35,6 +35,8 @@ static const struct rzg2l_du_device_info rzg2l_du_r9a07g043u_info = {
                        .port = 0,
                },
        },
+       .mode_clock_min = 20875,
+       .mode_clock_max = 83500,
 };
 
 static const struct rzg2l_du_device_info rzg2l_du_r9a07g044_info = {
@@ -48,7 +50,9 @@ static const struct rzg2l_du_device_info rzg2l_du_r9a07g044_info = {
                        .possible_outputs = BIT(0),
                        .port = 1,
                }
-       }
+       },
+       .mode_clock_min = 20875,
+       .mode_clock_max = 83500,
 };
 
 static const struct rzg2l_du_device_info rzg2l_du_r9a09g057_info = {
index 58806c2a8f2bf9b2c99cefca45c3d414894749ac..885558eb9547fd9a252910e3893f182647a321a4 100644 (file)
@@ -44,10 +44,14 @@ struct rzg2l_du_output_routing {
  * struct rzg2l_du_device_info - DU model-specific information
  * @channels_mask: bit mask of available DU channels
  * @routes: array of CRTC to output routes, indexed by output (RZG2L_DU_OUTPUT_*)
+ * @mode_clock_min: minimum pixel clock in kHz
+ * @mode_clock_max: maximum pixel clock in kHz
  */
 struct rzg2l_du_device_info {
        unsigned int channels_mask;
        struct rzg2l_du_output_routing routes[RZG2L_DU_OUTPUT_MAX];
+       u32 mode_clock_min;
+       u32 mode_clock_max;
 };
 
 #define RZG2L_DU_MAX_CRTCS             1
index 0e567b57a4087e81bd9bc8254eea0073c5055720..f50d166b764f5c1bec3eb67085fba86ce67df059 100644 (file)
@@ -50,8 +50,15 @@ rzg2l_du_encoder_mode_valid(struct drm_encoder *encoder,
                            const struct drm_display_mode *mode)
 {
        struct rzg2l_du_encoder *renc = to_rzg2l_encoder(encoder);
+       struct rzg2l_du_device *rcdu = to_rzg2l_du_device(renc->base.dev);
+       const struct rzg2l_du_device_info *info = rcdu->info;
 
-       if (renc->output == RZG2L_DU_OUTPUT_DPAD0 && mode->clock > 83500)
+       if (renc->output != RZG2L_DU_OUTPUT_DPAD0)
+               return MODE_OK;
+
+       if (mode->clock < info->mode_clock_min)
+               return MODE_CLOCK_LOW;
+       if (mode->clock > info->mode_clock_max)
                return MODE_CLOCK_HIGH;
 
        return MODE_OK;