[PATCH] drm/i915: fix up readout of the lvds dither bit on gen2/3

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

 



Hi Knut,

When you test this patch please grab a dmesg with drm.debug=0xe
regardless of outcome, I'd like to check a few other odd things with
your system (which seem to not be directly related to the issue at
hand).

Thanks, Daniel

On Thu, Jul 11, 2013 at 1:35 PM, Daniel Vetter <daniel.vetter at ffwll.ch> wrote:
> It's in the PFIT_CONTROL register, but very much associated with the
> lvds encoder. So move the readout for it (in the case of an otherwise
> disabled pfit) from the pipe to the lvds encoder's get_config
> function.
>
> Otherwise we get a pipe state mismatch if we use pipe B for a non-lvds
> output and we've left the dither bit enabled behind us. This can
> happen if the BIOS has set the bit (some seem to unconditionally do
> that, even in the complete absence of an lvds port), but not enabled
> pipe B at boot-up. Then we won't clear the pfit control register since
> we can only touch that if the pfit is associated with our pipe in the
> crtc configuration - we could trample over the pfit state of the other
> pipe otherwise since it's shared. Once pipe B is enabled we notice
> that the 6to8 dither bit is set and complain about the mismatch.
>
> Note that testing indicates that we don't actually need to set this
> bit when the pfit is disabled, dithering on 18bpp panels seems to work
> regardless. But ripping that code out is not something for a bugfix
> meant for -rc kernels.
>
> v2: While at it clarify the logic in i9xx_get_pfit_config, spurred by
> comments from Chris on irc.
>
> v3: Use Chris suggestion to make the control flow in
> i9xx_get_pfit_config easier to understand.
>
> v4: Kill the extra line, spotted by Chris.
>
> Reported-by: Knut Petersen <Knut_Petersen at t-online.de>
> Cc: Knut Petersen <Knut_Petersen at t-online.de>
> Cc: Chris Wilson <chris at chris-wilson.co.uk>
> References: http://lists.freedesktop.org/archives/intel-gfx/2013-July/030092.html
> Signed-off-by: Daniel Vetter <daniel.vetter at ffwll.ch>
> ---
>  drivers/gpu/drm/i915/intel_display.c | 11 ++++-------
>  drivers/gpu/drm/i915/intel_lvds.c    |  7 +++++++
>  2 files changed, 11 insertions(+), 7 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c
> index 85f3eb7..c59335c 100644
> --- a/drivers/gpu/drm/i915/intel_display.c
> +++ b/drivers/gpu/drm/i915/intel_display.c
> @@ -4913,22 +4913,19 @@ static void i9xx_get_pfit_config(struct intel_crtc *crtc,
>         uint32_t tmp;
>
>         tmp = I915_READ(PFIT_CONTROL);
> +       if (!(tmp & PFIT_ENABLE))
> +               return;
>
> +       /* Check whether the pfit is attached to our pipe. */
>         if (INTEL_INFO(dev)->gen < 4) {
>                 if (crtc->pipe != PIPE_B)
>                         return;
> -
> -               /* gen2/3 store dither state in pfit control, needs to match */
> -               pipe_config->gmch_pfit.control = tmp & PANEL_8TO6_DITHER_ENABLE;
>         } else {
>                 if ((tmp & PFIT_PIPE_MASK) != (crtc->pipe << PFIT_PIPE_SHIFT))
>                         return;
>         }
>
> -       if (!(tmp & PFIT_ENABLE))
> -               return;
> -
> -       pipe_config->gmch_pfit.control = I915_READ(PFIT_CONTROL);
> +       pipe_config->gmch_pfit.control = tmp;
>         pipe_config->gmch_pfit.pgm_ratios = I915_READ(PFIT_PGM_RATIOS);
>         if (INTEL_INFO(dev)->gen < 5)
>                 pipe_config->gmch_pfit.lvds_border_bits =
> diff --git a/drivers/gpu/drm/i915/intel_lvds.c b/drivers/gpu/drm/i915/intel_lvds.c
> index 2abb2d3..1207998 100644
> --- a/drivers/gpu/drm/i915/intel_lvds.c
> +++ b/drivers/gpu/drm/i915/intel_lvds.c
> @@ -109,6 +109,13 @@ static void intel_lvds_get_config(struct intel_encoder *encoder,
>                 flags |= DRM_MODE_FLAG_PVSYNC;
>
>         pipe_config->adjusted_mode.flags |= flags;
> +
> +       /* gen2/3 store dither state in pfit control, needs to match */
> +       if (INTEL_INFO(dev)->gen < 4) {
> +               tmp = I915_READ(PFIT_CONTROL);
> +
> +               pipe_config->gmch_pfit.control |= tmp & PANEL_8TO6_DITHER_ENABLE;
> +       }
>  }
>
>  /* The LVDS pin pair needs to be on before the DPLLs are enabled.
> --
> 1.8.1.4
>



-- 
Daniel Vetter
Software Engineer, Intel Corporation
+41 (0) 79 365 57 48 - http://blog.ffwll.ch


[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]
  Powered by Linux