Re: [PATCH 09/19] drm/gma500: Unify *_intel_lvds_mode_fixup()

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, Jun 14, 2022 at 9:23 AM Thomas Zimmermann <tzimmermann@xxxxxxx> wrote:
>
> Hi
>
> Am 13.06.22 um 14:34 schrieb Patrik Jakobsson:
> > These functions mostly do the same thing so unify them. Change a check
> > of !IS_MRST() to IS_PSB() to not change the behaviour for CDV.
> >
> > Signed-off-by: Patrik Jakobsson <patrik.r.jakobsson@xxxxxxxxx>
> > ---
> >   drivers/gpu/drm/gma500/cdv_intel_lvds.c | 51 +------------------
> >   drivers/gpu/drm/gma500/gma_lvds.c       | 59 ++++++++++++++++++++++
> >   drivers/gpu/drm/gma500/gma_lvds.h       |  3 ++
> >   drivers/gpu/drm/gma500/oaktrail_lvds.c  |  2 +-
> >   drivers/gpu/drm/gma500/psb_intel_lvds.c | 65 +------------------------
> >   5 files changed, 65 insertions(+), 115 deletions(-)
> >
> > diff --git a/drivers/gpu/drm/gma500/cdv_intel_lvds.c b/drivers/gpu/drm/gma500/cdv_intel_lvds.c
> > index 61dc65964e21..65532308f1e7 100644
> > --- a/drivers/gpu/drm/gma500/cdv_intel_lvds.c
> > +++ b/drivers/gpu/drm/gma500/cdv_intel_lvds.c
> > @@ -39,55 +39,6 @@
> >   #define PSB_BACKLIGHT_PWM_CTL_SHIFT (16)
> >   #define PSB_BACKLIGHT_PWM_POLARITY_BIT_CLEAR (0xFFFE)
> >
> > -static bool cdv_intel_lvds_mode_fixup(struct drm_encoder *encoder,
> > -                               const struct drm_display_mode *mode,
> > -                               struct drm_display_mode *adjusted_mode)
> > -{
> > -     struct drm_device *dev = encoder->dev;
> > -     struct drm_psb_private *dev_priv = to_drm_psb_private(dev);
> > -     struct psb_intel_mode_device *mode_dev = &dev_priv->mode_dev;
> > -     struct drm_encoder *tmp_encoder;
> > -     struct drm_display_mode *panel_fixed_mode = mode_dev->panel_fixed_mode;
> > -
> > -     /* Should never happen!! */
> > -     list_for_each_entry(tmp_encoder, &dev->mode_config.encoder_list,
> > -                         head) {
> > -             if (tmp_encoder != encoder
> > -                 && tmp_encoder->crtc == encoder->crtc) {
> > -                     pr_err("Can't enable LVDS and another encoder on the same pipe\n");
> > -                     return false;
> > -             }
> > -     }
> > -
> > -     /*
> > -      * If we have timings from the BIOS for the panel, put them in
> > -      * to the adjusted mode.  The CRTC will be set up for this mode,
> > -      * with the panel scaling set up to source from the H/VDisplay
> > -      * of the original mode.
> > -      */
> > -     if (panel_fixed_mode != NULL) {
> > -             adjusted_mode->hdisplay = panel_fixed_mode->hdisplay;
> > -             adjusted_mode->hsync_start = panel_fixed_mode->hsync_start;
> > -             adjusted_mode->hsync_end = panel_fixed_mode->hsync_end;
> > -             adjusted_mode->htotal = panel_fixed_mode->htotal;
> > -             adjusted_mode->vdisplay = panel_fixed_mode->vdisplay;
> > -             adjusted_mode->vsync_start = panel_fixed_mode->vsync_start;
> > -             adjusted_mode->vsync_end = panel_fixed_mode->vsync_end;
> > -             adjusted_mode->vtotal = panel_fixed_mode->vtotal;
> > -             adjusted_mode->clock = panel_fixed_mode->clock;
> > -             drm_mode_set_crtcinfo(adjusted_mode,
> > -                                   CRTC_INTERLACE_HALVE_V);
> > -     }
> > -
> > -     /*
> > -      * XXX: It would be nice to support lower refresh rates on the
> > -      * panels to reduce power consumption, and perhaps match the
> > -      * user's requested refresh rate.
> > -      */
> > -
> > -     return true;
> > -}
> > -
> >   static void cdv_intel_lvds_prepare(struct drm_encoder *encoder)
> >   {
> >       struct drm_device *dev = encoder->dev;
> > @@ -255,7 +206,7 @@ static int cdv_intel_lvds_set_property(struct drm_connector *connector,
> >   static const struct drm_encoder_helper_funcs
> >                                       cdv_intel_lvds_helper_funcs = {
> >       .dpms = gma_lvds_encoder_dpms,
> > -     .mode_fixup = cdv_intel_lvds_mode_fixup,
> > +     .mode_fixup = gma_lvds_mode_fixup,
> >       .prepare = cdv_intel_lvds_prepare,
> >       .mode_set = cdv_intel_lvds_mode_set,
> >       .commit = cdv_intel_lvds_commit,
> > diff --git a/drivers/gpu/drm/gma500/gma_lvds.c b/drivers/gpu/drm/gma500/gma_lvds.c
> > index 19679ee36062..32ecf5835828 100644
> > --- a/drivers/gpu/drm/gma500/gma_lvds.c
> > +++ b/drivers/gpu/drm/gma500/gma_lvds.c
> > @@ -209,3 +209,62 @@ void gma_lvds_restore(struct drm_connector *connector)
> >       }
> >   }
> >
> > +bool gma_lvds_mode_fixup(struct drm_encoder *encoder,
> > +                      const struct drm_display_mode *mode,
> > +                      struct drm_display_mode *adjusted_mode)
> > +{
> > +     struct drm_device *dev = encoder->dev;
> > +     struct drm_psb_private *dev_priv = to_drm_psb_private(dev);
> > +     struct psb_intel_mode_device *mode_dev = &dev_priv->mode_dev;
> > +     struct gma_crtc *gma_crtc = to_gma_crtc(encoder->crtc);
> > +     struct drm_encoder *tmp_encoder;
> > +     struct drm_display_mode *panel_fixed_mode = mode_dev->panel_fixed_mode;
> > +
> > +     /* PSB requires the LVDS is on pipe B, MRST has only one pipe anyway */
> > +     if (IS_PSB(dev) && gma_crtc->pipe == 0) {
> > +             pr_err("Can't support LVDS on pipe A\n");
> > +             return false;
> > +     }
> > +     if (IS_MRST(dev) && gma_crtc->pipe != 0) {
> > +             pr_err("Must use PIPE A\n");
> > +             return false;
> > +     }
>
> In my experience, per-model branching is horrible for maintenance.
>
> I suggest to keep a _lvds_mode_fixup function for each model, each wit
> the rsp model. The rest of gma_lvds_mode_fixup() can than be a shared
> helper for all those model-specific functions.

Hi Thomas, thanks for having a look.

I wasn't sure if I wanted to refactor the code in this series or not
so I ended up just doing the unification. I fully agree that the
IS_*() checks are horrible and need fixing in most cases. And as Sam
mentioned in 1/19 there are ways to clean up the code as well.

For the above code the even better way to do it is to use the device's
lvds_mask. That way the code can be device-independent and all chips
can use it.

I can respin this series with refactoring/cleanup included or I can
send out a v2 with the initialized macro and send the
refactoring/cleanup as a separate series.

Which do you prefer?

-Patrik

>
> > +     /* Should never happen!! */
> > +     list_for_each_entry(tmp_encoder, &dev->mode_config.encoder_list,
> > +                         head) {
> > +             if (tmp_encoder != encoder
> > +                 && tmp_encoder->crtc == encoder->crtc) {
> > +                     pr_err("Can't enable LVDS and another encoder on the same pipe\n");
> > +                     return false;
> > +             }
> > +     }
> > +
> > +     /*
> > +      * If we have timings from the BIOS for the panel, put them in
> > +      * to the adjusted mode.  The CRTC will be set up for this mode,
> > +      * with the panel scaling set up to source from the H/VDisplay
> > +      * of the original mode.
> > +      */
> > +     if (panel_fixed_mode != NULL) {
> > +             adjusted_mode->hdisplay = panel_fixed_mode->hdisplay;
> > +             adjusted_mode->hsync_start = panel_fixed_mode->hsync_start;
> > +             adjusted_mode->hsync_end = panel_fixed_mode->hsync_end;
> > +             adjusted_mode->htotal = panel_fixed_mode->htotal;
> > +             adjusted_mode->vdisplay = panel_fixed_mode->vdisplay;
> > +             adjusted_mode->vsync_start = panel_fixed_mode->vsync_start;
> > +             adjusted_mode->vsync_end = panel_fixed_mode->vsync_end;
> > +             adjusted_mode->vtotal = panel_fixed_mode->vtotal;
> > +             adjusted_mode->clock = panel_fixed_mode->clock;
> > +             drm_mode_set_crtcinfo(adjusted_mode,
> > +                                   CRTC_INTERLACE_HALVE_V);
> > +     }
> > +
> > +     /*
> > +      * XXX: It would be nice to support lower refresh rates on the
> > +      * panels to reduce power consumption, and perhaps match the
> > +      * user's requested refresh rate.
> > +      */
> > +
> > +     return true;
> > +}
> > +
> > diff --git a/drivers/gpu/drm/gma500/gma_lvds.h b/drivers/gpu/drm/gma500/gma_lvds.h
> > index eee0da00a0cf..950ab7b88ad6 100644
> > --- a/drivers/gpu/drm/gma500/gma_lvds.h
> > +++ b/drivers/gpu/drm/gma500/gma_lvds.h
> > @@ -30,5 +30,8 @@ enum drm_mode_status gma_lvds_mode_valid(struct drm_connector *connector,
> >   void gma_lvds_encoder_dpms(struct drm_encoder *encoder, int mode);
> >   void gma_lvds_save(struct drm_connector *connector);
> >   void gma_lvds_restore(struct drm_connector *connector);
> > +bool gma_lvds_mode_fixup(struct drm_encoder *encoder,
> > +                      const struct drm_display_mode *mode,
> > +                      struct drm_display_mode *adjusted_mode);
> >
> >   #endif
> > diff --git a/drivers/gpu/drm/gma500/oaktrail_lvds.c b/drivers/gpu/drm/gma500/oaktrail_lvds.c
> > index 00ec4fea4c12..16699b0fbbc9 100644
> > --- a/drivers/gpu/drm/gma500/oaktrail_lvds.c
> > +++ b/drivers/gpu/drm/gma500/oaktrail_lvds.c
> > @@ -134,7 +134,7 @@ static void oaktrail_lvds_commit(struct drm_encoder *encoder)
> >
> >   static const struct drm_encoder_helper_funcs oaktrail_lvds_helper_funcs = {
> >       .dpms = gma_lvds_encoder_dpms,
> > -     .mode_fixup = psb_intel_lvds_mode_fixup,
> > +     .mode_fixup = gma_lvds_mode_fixup,
> >       .prepare = oaktrail_lvds_prepare,
> >       .mode_set = oaktrail_lvds_mode_set,
> >       .commit = oaktrail_lvds_commit,
> > diff --git a/drivers/gpu/drm/gma500/psb_intel_lvds.c b/drivers/gpu/drm/gma500/psb_intel_lvds.c
> > index 6e5abb670bff..317bd1fcfa2a 100644
> > --- a/drivers/gpu/drm/gma500/psb_intel_lvds.c
> > +++ b/drivers/gpu/drm/gma500/psb_intel_lvds.c
> > @@ -132,69 +132,6 @@ void psb_intel_lvds_set_brightness(struct drm_device *dev, int level)
> >               psb_lvds_pwm_set_brightness(dev, level);
> >   }
> >
> > -bool psb_intel_lvds_mode_fixup(struct drm_encoder *encoder,
> > -                               const struct drm_display_mode *mode,
> > -                               struct drm_display_mode *adjusted_mode)
> > -{
> > -     struct drm_device *dev = encoder->dev;
> > -     struct drm_psb_private *dev_priv = to_drm_psb_private(dev);
> > -     struct psb_intel_mode_device *mode_dev = &dev_priv->mode_dev;
> > -     struct gma_crtc *gma_crtc = to_gma_crtc(encoder->crtc);
> > -     struct drm_encoder *tmp_encoder;
> > -     struct drm_display_mode *panel_fixed_mode = mode_dev->panel_fixed_mode;
> > -     struct gma_encoder *gma_encoder = to_gma_encoder(encoder);
> > -
> > -     if (gma_encoder->type == INTEL_OUTPUT_MIPI2)
> > -             panel_fixed_mode = mode_dev->panel_fixed_mode2;
>
> What happened to this test? I cannot see it in the new helper.

We don't have MIPI support so I removed the test. I forgot to mention
it in this patch. Other patches should have a note about it when I
remove MIPI code.





>
> Best regards
> Thomas
>
> > -
> > -     /* PSB requires the LVDS is on pipe B, MRST has only one pipe anyway */
> > -     if (!IS_MRST(dev) && gma_crtc->pipe == 0) {
> > -             pr_err("Can't support LVDS on pipe A\n");
> > -             return false;
> > -     }
> > -     if (IS_MRST(dev) && gma_crtc->pipe != 0) {
> > -             pr_err("Must use PIPE A\n");
> > -             return false;
> > -     }
> > -     /* Should never happen!! */
> > -     list_for_each_entry(tmp_encoder, &dev->mode_config.encoder_list,
> > -                         head) {
> > -             if (tmp_encoder != encoder
> > -                 && tmp_encoder->crtc == encoder->crtc) {
> > -                     pr_err("Can't enable LVDS and another encoder on the same pipe\n");
> > -                     return false;
> > -             }
> > -     }
> > -
> > -     /*
> > -      * If we have timings from the BIOS for the panel, put them in
> > -      * to the adjusted mode.  The CRTC will be set up for this mode,
> > -      * with the panel scaling set up to source from the H/VDisplay
> > -      * of the original mode.
> > -      */
> > -     if (panel_fixed_mode != NULL) {
> > -             adjusted_mode->hdisplay = panel_fixed_mode->hdisplay;
> > -             adjusted_mode->hsync_start = panel_fixed_mode->hsync_start;
> > -             adjusted_mode->hsync_end = panel_fixed_mode->hsync_end;
> > -             adjusted_mode->htotal = panel_fixed_mode->htotal;
> > -             adjusted_mode->vdisplay = panel_fixed_mode->vdisplay;
> > -             adjusted_mode->vsync_start = panel_fixed_mode->vsync_start;
> > -             adjusted_mode->vsync_end = panel_fixed_mode->vsync_end;
> > -             adjusted_mode->vtotal = panel_fixed_mode->vtotal;
> > -             adjusted_mode->clock = panel_fixed_mode->clock;
> > -             drm_mode_set_crtcinfo(adjusted_mode,
> > -                                   CRTC_INTERLACE_HALVE_V);
> > -     }
> > -
> > -     /*
> > -      * XXX: It would be nice to support lower refresh rates on the
> > -      * panels to reduce power consumption, and perhaps match the
> > -      * user's requested refresh rate.
> > -      */
> > -
> > -     return true;
> > -}
> > -
> >   static void psb_intel_lvds_prepare(struct drm_encoder *encoder)
> >   {
> >       struct drm_device *dev = encoder->dev;
> > @@ -365,7 +302,7 @@ int psb_intel_lvds_set_property(struct drm_connector *connector,
> >
> >   static const struct drm_encoder_helper_funcs psb_intel_lvds_helper_funcs = {
> >       .dpms = gma_lvds_encoder_dpms,
> > -     .mode_fixup = psb_intel_lvds_mode_fixup,
> > +     .mode_fixup = gma_lvds_mode_fixup,
> >       .prepare = psb_intel_lvds_prepare,
> >       .mode_set = psb_intel_lvds_mode_set,
> >       .commit = psb_intel_lvds_commit,
>
> --
> Thomas Zimmermann
> Graphics Driver Developer
> SUSE Software Solutions Germany GmbH
> Maxfeldstr. 5, 90409 Nürnberg, Germany
> (HRB 36809, AG Nürnberg)
> Geschäftsführer: Ivo Totev




[Index of Archives]     [Linux DRI Users]     [Linux Intel Graphics]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [XFree86]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [XFree86]
  Powered by Linux