[PATCH 3/5] drm/i2c: adv7511: Refactor encoder slave functions

Rob Clark robdclark at gmail.com
Thu Dec 3 07:02:02 PST 2015


On Mon, Jul 27, 2015 at 4:59 AM, Laurent Pinchart
<laurent.pinchart at ideasonboard.com> wrote:
> Hi Archit,
>
> (CC'ing Boris Brezillon)
>
> Thank you for the patch.
>
> On Monday 27 July 2015 11:46:57 Archit Taneja wrote:
>> ADV7511 is represented as an i2c drm slave encoder device. ADV7533, on
>> the other hand, is going be a normal i2c client device creating bridge
>> and connector entities.
>
> Please, no. It's really time to stop piling hacks and fix the problem
> properly. There's no reason to have separate APIs for I2C slave encoders and
> DRM bridges. Those two APIs need to be merged, and then you'll find it much
> easier to implement ADV7533 support.

btw, what is the status here?  I'd kind of lost track of the
discussion, but I'm getting impatient that it is somehow taking
ridiculously long to get adv7533 support merged.  (It's good thing the
x86/desktop folks don't bikeshed so much..  I'd hate to wait a year
for my new laptop to be supported..)

Anyways, if needed, just copy/paste the adv7511/7533 code into a
separate bridge-only driver, and we'll use that.  Once the
i2c-slave-encoder users for adv7511 are converted over, we can delete
the original slave encoder driver.  That seems like a sane transition
plan to a bridge-only world.

BR,
-R

> Boris, I know you were experimenting with that, do you have anything to report
> ?
>
>> Move the code in encoder slave functions to generate helpers that are
>> agnostic to the drm object type. These helpers will later also be used
>> by bridge and connecter helper functions.
>>
>> Signed-off-by: Archit Taneja <architt at codeaurora.org>
>> ---
>>  drivers/gpu/drm/i2c/adv7511.c | 80 +++++++++++++++++++++++++++------------
>>  1 file changed, 57 insertions(+), 23 deletions(-)
>>
>> diff --git a/drivers/gpu/drm/i2c/adv7511.c b/drivers/gpu/drm/i2c/adv7511.c
>> index 63a3d20..46fb24d 100644
>> --- a/drivers/gpu/drm/i2c/adv7511.c
>> +++ b/drivers/gpu/drm/i2c/adv7511.c
>> @@ -612,13 +612,11 @@ static int adv7511_get_edid_block(void *data, u8 *buf,
>> unsigned int block, }
>>
>>  /*
>> ---------------------------------------------------------------------------
>> -- - * Encoder operations
>> + * ADV75xx helpers
>>   */
>> -
>> -static int adv7511_get_modes(struct drm_encoder *encoder,
>> -                          struct drm_connector *connector)
>> +static int adv7511_get_modes(struct adv7511 *adv7511,
>> +             struct drm_connector *connector)
>>  {
>> -     struct adv7511 *adv7511 = encoder_to_adv7511(encoder);
>>       struct edid *edid;
>>       unsigned int count;
>>
>> @@ -656,21 +654,10 @@ static int adv7511_get_modes(struct drm_encoder
>> *encoder, return count;
>>  }
>>
>> -static void adv7511_encoder_dpms(struct drm_encoder *encoder, int mode)
>> -{
>> -     struct adv7511 *adv7511 = encoder_to_adv7511(encoder);
>> -
>> -     if (mode == DRM_MODE_DPMS_ON)
>> -             adv7511_power_on(adv7511);
>> -     else
>> -             adv7511_power_off(adv7511);
>> -}
>> -
>>  static enum drm_connector_status
>> -adv7511_encoder_detect(struct drm_encoder *encoder,
>> +adv7511_detect(struct adv7511 *adv7511,
>>                      struct drm_connector *connector)
>>  {
>> -     struct adv7511 *adv7511 = encoder_to_adv7511(encoder);
>>       enum drm_connector_status status;
>>       unsigned int val;
>>       bool hpd;
>> @@ -694,7 +681,7 @@ adv7511_encoder_detect(struct drm_encoder *encoder,
>>       if (status == connector_status_connected && hpd && adv7511->powered) {
>>               regcache_mark_dirty(adv7511->regmap);
>>               adv7511_power_on(adv7511);
>> -             adv7511_get_modes(encoder, connector);
>> +             adv7511_get_modes(adv7511, connector);
>>               if (adv7511->status == connector_status_connected)
>>                       status = connector_status_disconnected;
>>       } else {
>> @@ -708,8 +695,8 @@ adv7511_encoder_detect(struct drm_encoder *encoder,
>>       return status;
>>  }
>>
>> -static int adv7511_encoder_mode_valid(struct drm_encoder *encoder,
>> -                                   struct drm_display_mode *mode)
>> +static int adv7511_mode_valid(struct adv7511 *adv7511,
>> +                                  const struct drm_display_mode *mode)
>>  {
>>       if (mode->clock > 165000)
>>               return MODE_CLOCK_HIGH;
>> @@ -717,11 +704,10 @@ static int adv7511_encoder_mode_valid(struct
>> drm_encoder *encoder, return MODE_OK;
>>  }
>>
>> -static void adv7511_encoder_mode_set(struct drm_encoder *encoder,
>> +static void adv7511_mode_set(struct adv7511 *adv7511,
>>                                    struct drm_display_mode *mode,
>>                                    struct drm_display_mode *adj_mode)
>>  {
>> -     struct adv7511 *adv7511 = encoder_to_adv7511(encoder);
>>       unsigned int low_refresh_rate;
>>       unsigned int hsync_polarity = 0;
>>       unsigned int vsync_polarity = 0;
>> @@ -812,12 +798,60 @@ static void adv7511_encoder_mode_set(struct
>> drm_encoder *encoder, adv7511->f_tmds = mode->clock;
>>  }
>>
>> +/*
>> ---------------------------------------------------------------------------
>> -- + * Encoder operations
>> + */
>> +
>> +static int adv7511_encoder_get_modes(struct drm_encoder *encoder,
>> +                          struct drm_connector *connector)
>> +{
>> +     struct adv7511 *adv7511 = encoder_to_adv7511(encoder);
>> +
>> +     return adv7511_get_modes(adv7511, connector);
>> +}
>> +
>> +static void adv7511_encoder_dpms(struct drm_encoder *encoder, int mode)
>> +{
>> +     struct adv7511 *adv7511 = encoder_to_adv7511(encoder);
>> +
>> +     if (mode == DRM_MODE_DPMS_ON)
>> +             adv7511_power_on(adv7511);
>> +     else
>> +             adv7511_power_off(adv7511);
>> +}
>> +
>> +static enum drm_connector_status
>> +adv7511_encoder_detect(struct drm_encoder *encoder,
>> +                    struct drm_connector *connector)
>> +{
>> +     struct adv7511 *adv7511 = encoder_to_adv7511(encoder);
>> +
>> +     return adv7511_detect(adv7511, connector);
>> +}
>> +
>> +static int adv7511_encoder_mode_valid(struct drm_encoder *encoder,
>> +                                   struct drm_display_mode *mode)
>> +{
>> +     struct adv7511 *adv7511 = encoder_to_adv7511(encoder);
>> +
>> +     return adv7511_mode_valid(adv7511, mode);
>> +}
>> +
>> +static void adv7511_encoder_mode_set(struct drm_encoder *encoder,
>> +                                  struct drm_display_mode *mode,
>> +                                  struct drm_display_mode *adj_mode)
>> +{
>> +     struct adv7511 *adv7511 = encoder_to_adv7511(encoder);
>> +
>> +     adv7511_mode_set(adv7511, mode, adj_mode);
>> +}
>> +
>>  static struct drm_encoder_slave_funcs adv7511_encoder_funcs = {
>>       .dpms = adv7511_encoder_dpms,
>>       .mode_valid = adv7511_encoder_mode_valid,
>>       .mode_set = adv7511_encoder_mode_set,
>>       .detect = adv7511_encoder_detect,
>> -     .get_modes = adv7511_get_modes,
>> +     .get_modes = adv7511_encoder_get_modes,
>>  };
>>
>>  /*
>> ---------------------------------------------------------------------------
>> --
>
> --
> Regards,
>
> Laurent Pinchart
>
> _______________________________________________
> dri-devel mailing list
> dri-devel at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/dri-devel


More information about the dri-devel mailing list