[DVO][PATCH] drm/i915: Fall back to bit banging mode for DVO transmitter detection
Daniel Vetter
daniel at ffwll.ch
Fri Apr 19 02:14:14 PDT 2013
On Fri, Apr 19, 2013 at 10:41:50AM +0200, "David Müller (ELSOFT AG)" wrote:
> Hello
>
> As discussed in this thread
> http://lists.freedesktop.org/archives/dri-devel/2013-April/037411.html
> GMBUS based DVO transmitter detection seems to be unreliable which could
> result in an unusable DVO port.
>
> The attached patch fixes this by falling back to bit banging mode for
> the time DVO transmitter detection is in progress.
>
> Signed-off-by: David Müller <d.mueller at elsoft.ch>
> Tested-by: David Müller <d.mueller at elsoft.ch>
>
> ---
> diff -dpurN a/drivers/gpu/drm/i915/intel_dvo.c b/drivers/gpu/drm/i915/intel_dvo.c
> --- a/drivers/gpu/drm/i915/intel_dvo.c 2012-12-11 10:09:35.113446850 +0100
> +++ b/drivers/gpu/drm/i915/intel_dvo.c 2013-04-19 07:21:54.054546365 +0200
> @@ -449,6 +449,7 @@ void intel_dvo_init(struct drm_device *d
> const struct intel_dvo_device *dvo = &intel_dvo_devices[i];
> struct i2c_adapter *i2c;
> int gpio;
> + bool dvoinit;
>
> /* Allow the I2C driver info to specify the GPIO to be used in
> * special cases, but otherwise default to what's defined
> @@ -468,7 +469,17 @@ void intel_dvo_init(struct drm_device *d
> i2c = intel_gmbus_get_adapter(dev_priv, gpio);
>
> intel_dvo->dev = *dvo;
> - if (!dvo->dev_ops->init(&intel_dvo->dev, i2c))
> +
> + /* GMBUS NAK handling seems to be unstable, hence let the
> + * transmitter detection run in bit banging mode for now.
> + */
> + intel_gmbus_force_bit(i2c, true);
> +
> + dvoinit = dvo->dev_ops->init(&intel_dvo->dev, i2c);
> +
> + intel_gmbus_force_bit(i2c, false);
Shouldn't we keep the dvo i2c line in bit-banging mode always, i.e.
restore gmbus mode only when dvo init failed?
I suspect that for fickle hw not just init will fail ...
-Daniel
> +
> + if (!dvoinit)
> continue;
>
> intel_encoder->type = INTEL_OUTPUT_DVO;
--
Daniel Vetter
Software Engineer, Intel Corporation
+41 (0) 79 365 57 48 - http://blog.ffwll.ch
More information about the dri-devel
mailing list