All of lore.kernel.org
 help / color / mirror / Atom feed
From: ville.syrjala@linux.intel.com (Ville Syrjälä)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH] drm/bridge: sii902x: Fall back to standard modes
Date: Thu, 1 Mar 2018 23:18:40 +0200	[thread overview]
Message-ID: <20180301211840.GD5453@intel.com> (raw)
In-Reply-To: <CACRpkdYuZE+ohhLf6mmPHEsGmNw6r7UOBCyQEFOcYOYxdVj2oA@mail.gmail.com>

On Thu, Mar 01, 2018 at 10:02:55PM +0100, Linus Walleij wrote:
> Hm, hard to get review feedback on this one.
> 
> It gives me proper video on an ARM Versatile Express utilizing the
> bridge driver with a plugged in DVI-to-VGA dongle with the new
> PL111 DRI driver.
> 
> Liviu? Pawel?
> 
> Some ACK is fine to know I am doing the right thing :)

Why isn't the probe helper's noedid fallback working?

> 
> Yours,
> Linus Walleij
> 
> On Wed, Feb 14, 2018 at 2:00 PM, Linus Walleij <linus.walleij@linaro.org> wrote:
> > The following happens when connection a DVI output driven
> > from the SiI9022 using a DVI-to-VGA adapter plug:
> >
> > i2c i2c-0: sendbytes: NAK bailout.
> > i2c i2c-0: sendbytes: NAK bailout.
> >
> > Then no picture. Apparently the I2C engine inside the SiI9022
> > is not smart enough to try to fall back to DDC I2C. Or the
> > vendor have not integrated the electronics properly. I don't
> > know which one it is.
> >
> > By using standard modes as fallback, the bridge probes nicely
> > with a minor warning and we get picture.
> >
> > This code is inspired by similar code in the dumb VGA bridge.
> >
> > Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
> > ---
> >  drivers/gpu/drm/bridge/sii902x.c | 15 +++++++++++++--
> >  1 file changed, 13 insertions(+), 2 deletions(-)
> >
> > diff --git a/drivers/gpu/drm/bridge/sii902x.c b/drivers/gpu/drm/bridge/sii902x.c
> > index b1ab4ab09532..4483095c4013 100644
> > --- a/drivers/gpu/drm/bridge/sii902x.c
> > +++ b/drivers/gpu/drm/bridge/sii902x.c
> > @@ -168,8 +168,19 @@ static int sii902x_get_modes(struct drm_connector *connector)
> >                 return ret;
> >
> >         edid = drm_get_edid(connector, sii902x->i2c->adapter);
> > -       drm_mode_connector_update_edid_property(connector, edid);
> > -       if (edid) {
> > +       if (!edid) {
> > +               /*
> > +                * This happens when using a simple DVI-to-VGA converter
> > +                * dongle for example: the I2C lines are not bridged over
> > +                * to VGA DDC.
> > +                */
> > +               DRM_INFO("EDID readout failed, falling back to standard modes\n");
> > +               ret = drm_add_modes_noedid(connector, 1920, 1080);
> > +               /* Set some standard resolution most monitors can handle */
> > +               drm_set_preferred_mode(connector, 1024, 768);
> > +       } else {
> > +               /* Data from EDID readout */
> > +               drm_mode_connector_update_edid_property(connector, edid);
> >                 num = drm_add_edid_modes(connector, edid);
> >                 kfree(edid);
> >         }
> > --
> > 2.14.3
> >
> _______________________________________________
> dri-devel mailing list
> dri-devel at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/dri-devel

-- 
Ville Syrj?l?
Intel OTC

WARNING: multiple messages have this Message-ID (diff)
From: "Ville Syrjälä" <ville.syrjala@linux.intel.com>
To: Linus Walleij <linus.walleij@linaro.org>
Cc: Pawel Moll <pawel.moll@arm.com>,
	Liviu Dudau <Liviu.Dudau@arm.com>,
	"open list:DRM PANEL DRIVERS" <dri-devel@lists.freedesktop.org>,
	Laurent Pinchart <Laurent.pinchart@ideasonboard.com>,
	Linux ARM <linux-arm-kernel@lists.infradead.org>
Subject: Re: [PATCH] drm/bridge: sii902x: Fall back to standard modes
Date: Thu, 1 Mar 2018 23:18:40 +0200	[thread overview]
Message-ID: <20180301211840.GD5453@intel.com> (raw)
In-Reply-To: <CACRpkdYuZE+ohhLf6mmPHEsGmNw6r7UOBCyQEFOcYOYxdVj2oA@mail.gmail.com>

On Thu, Mar 01, 2018 at 10:02:55PM +0100, Linus Walleij wrote:
> Hm, hard to get review feedback on this one.
> 
> It gives me proper video on an ARM Versatile Express utilizing the
> bridge driver with a plugged in DVI-to-VGA dongle with the new
> PL111 DRI driver.
> 
> Liviu? Pawel?
> 
> Some ACK is fine to know I am doing the right thing :)

Why isn't the probe helper's noedid fallback working?

> 
> Yours,
> Linus Walleij
> 
> On Wed, Feb 14, 2018 at 2:00 PM, Linus Walleij <linus.walleij@linaro.org> wrote:
> > The following happens when connection a DVI output driven
> > from the SiI9022 using a DVI-to-VGA adapter plug:
> >
> > i2c i2c-0: sendbytes: NAK bailout.
> > i2c i2c-0: sendbytes: NAK bailout.
> >
> > Then no picture. Apparently the I2C engine inside the SiI9022
> > is not smart enough to try to fall back to DDC I2C. Or the
> > vendor have not integrated the electronics properly. I don't
> > know which one it is.
> >
> > By using standard modes as fallback, the bridge probes nicely
> > with a minor warning and we get picture.
> >
> > This code is inspired by similar code in the dumb VGA bridge.
> >
> > Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
> > ---
> >  drivers/gpu/drm/bridge/sii902x.c | 15 +++++++++++++--
> >  1 file changed, 13 insertions(+), 2 deletions(-)
> >
> > diff --git a/drivers/gpu/drm/bridge/sii902x.c b/drivers/gpu/drm/bridge/sii902x.c
> > index b1ab4ab09532..4483095c4013 100644
> > --- a/drivers/gpu/drm/bridge/sii902x.c
> > +++ b/drivers/gpu/drm/bridge/sii902x.c
> > @@ -168,8 +168,19 @@ static int sii902x_get_modes(struct drm_connector *connector)
> >                 return ret;
> >
> >         edid = drm_get_edid(connector, sii902x->i2c->adapter);
> > -       drm_mode_connector_update_edid_property(connector, edid);
> > -       if (edid) {
> > +       if (!edid) {
> > +               /*
> > +                * This happens when using a simple DVI-to-VGA converter
> > +                * dongle for example: the I2C lines are not bridged over
> > +                * to VGA DDC.
> > +                */
> > +               DRM_INFO("EDID readout failed, falling back to standard modes\n");
> > +               ret = drm_add_modes_noedid(connector, 1920, 1080);
> > +               /* Set some standard resolution most monitors can handle */
> > +               drm_set_preferred_mode(connector, 1024, 768);
> > +       } else {
> > +               /* Data from EDID readout */
> > +               drm_mode_connector_update_edid_property(connector, edid);
> >                 num = drm_add_edid_modes(connector, edid);
> >                 kfree(edid);
> >         }
> > --
> > 2.14.3
> >
> _______________________________________________
> dri-devel mailing list
> dri-devel@lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/dri-devel

-- 
Ville Syrjälä
Intel OTC
_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel

  reply	other threads:[~2018-03-01 21:18 UTC|newest]

Thread overview: 12+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-02-14 13:00 [PATCH] drm/bridge: sii902x: Fall back to standard modes Linus Walleij
2018-02-14 13:00 ` Linus Walleij
2018-03-01 21:02 ` Linus Walleij
2018-03-01 21:02   ` Linus Walleij
2018-03-01 21:18   ` Ville Syrjälä [this message]
2018-03-01 21:18     ` Ville Syrjälä
2018-03-01 22:12     ` Linus Walleij
2018-03-01 22:12       ` Linus Walleij
2018-03-02  8:07       ` Ville Syrjälä
2018-03-02  8:07         ` Ville Syrjälä
2018-03-02 13:28         ` Linus Walleij
2018-03-02 13:28           ` Linus Walleij

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20180301211840.GD5453@intel.com \
    --to=ville.syrjala@linux.intel.com \
    --cc=linux-arm-kernel@lists.infradead.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.