[Intel-gfx] [PATCH] drm/i915/skl: fetch, enable/disable pfit as needed v2
Paulo Zanoni
przanoni at gmail.com
Thu Sep 25 20:06:17 CEST 2014
2014-09-25 14:58 GMT-03:00 Jesse Barnes <jbarnes at virtuousgeek.org>:
> This moved around on SKL, so we need to make sure we read/write the
> correct regs.
>
> v2: fixup WIN_POS offsets (Paulo)
> zero out WIN_POS reg at disable time (Paulo)
Reviewed-by: Paulo Zanoni <paulo.r.zanoni at intel.com>
>
> Signed-off-by: Jesse Barnes <jbarnes at virtuougseek.org>
> Signed-off-by: Damien Lespiau <damien.lespiau at intel.com>
> ---
> drivers/gpu/drm/i915/i915_reg.h | 12 +++++++
> drivers/gpu/drm/i915/intel_display.c | 62 +++++++++++++++++++++++++++++++++---
> 2 files changed, 70 insertions(+), 4 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/i915_reg.h b/drivers/gpu/drm/i915/i915_reg.h
> index 6f5a70f..44133fb 100644
> --- a/drivers/gpu/drm/i915/i915_reg.h
> +++ b/drivers/gpu/drm/i915/i915_reg.h
> @@ -4760,6 +4760,18 @@ enum punit_power_well {
> #define PF_VSCALE(pipe) _PIPE(pipe, _PFA_VSCALE, _PFB_VSCALE)
> #define PF_HSCALE(pipe) _PIPE(pipe, _PFA_HSCALE, _PFB_HSCALE)
>
> +#define _PSA_CTL 0x68180
> +#define _PSB_CTL 0x68980
> +#define PS_ENABLE (1<<31)
> +#define _PSA_WIN_SZ 0x68174
> +#define _PSB_WIN_SZ 0x68974
> +#define _PSA_WIN_POS 0x68170
> +#define _PSB_WIN_POS 0x68970
> +
> +#define PS_CTL(pipe) _PIPE(pipe, _PSA_CTL, _PSB_CTL)
> +#define PS_WIN_SZ(pipe) _PIPE(pipe, _PSA_WIN_SZ, _PSB_WIN_SZ)
> +#define PS_WIN_POS(pipe) _PIPE(pipe, _PSA_WIN_POS, _PSB_WIN_POS)
> +
> /* legacy palette */
> #define _LGC_PALETTE_A 0x4a000
> #define _LGC_PALETTE_B 0x4a800
> diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c
> index b8488a8..550cde3 100644
> --- a/drivers/gpu/drm/i915/intel_display.c
> +++ b/drivers/gpu/drm/i915/intel_display.c
> @@ -3911,6 +3911,19 @@ static void cpt_verify_modeset(struct drm_device *dev, int pipe)
> }
> }
>
> +static void skylake_pfit_enable(struct intel_crtc *crtc)
> +{
> + struct drm_device *dev = crtc->base.dev;
> + struct drm_i915_private *dev_priv = dev->dev_private;
> + int pipe = crtc->pipe;
> +
> + if (crtc->config.pch_pfit.enabled) {
> + I915_WRITE(PS_CTL(pipe), PS_ENABLE);
> + I915_WRITE(PS_WIN_POS(pipe), crtc->config.pch_pfit.pos);
> + I915_WRITE(PS_WIN_SZ(pipe), crtc->config.pch_pfit.size);
> + }
> +}
> +
> static void ironlake_pfit_enable(struct intel_crtc *crtc)
> {
> struct drm_device *dev = crtc->base.dev;
> @@ -4288,7 +4301,10 @@ static void haswell_crtc_enable(struct drm_crtc *crtc)
>
> intel_ddi_enable_pipe_clock(intel_crtc);
>
> - ironlake_pfit_enable(intel_crtc);
> + if (IS_SKYLAKE(dev))
> + skylake_pfit_enable(intel_crtc);
> + else
> + ironlake_pfit_enable(intel_crtc);
>
> /*
> * On ILK+ LUT must be loaded before the pipe is running but with
> @@ -4322,6 +4338,21 @@ static void haswell_crtc_enable(struct drm_crtc *crtc)
> intel_crtc_enable_planes(crtc);
> }
>
> +static void skylake_pfit_disable(struct intel_crtc *crtc)
> +{
> + struct drm_device *dev = crtc->base.dev;
> + struct drm_i915_private *dev_priv = dev->dev_private;
> + int pipe = crtc->pipe;
> +
> + /* To avoid upsetting the power well on haswell only disable the pfit if
> + * it's in use. The hw state code will make sure we get this right. */
> + if (crtc->config.pch_pfit.enabled) {
> + I915_WRITE(PS_CTL(pipe), 0);
> + I915_WRITE(PS_WIN_POS(pipe), 0);
> + I915_WRITE(PS_WIN_SZ(pipe), 0);
> + }
> +}
> +
> static void ironlake_pfit_disable(struct intel_crtc *crtc)
> {
> struct drm_device *dev = crtc->base.dev;
> @@ -4433,7 +4464,10 @@ static void haswell_crtc_disable(struct drm_crtc *crtc)
>
> intel_ddi_disable_transcoder_func(dev_priv, cpu_transcoder);
>
> - ironlake_pfit_disable(intel_crtc);
> + if (IS_SKYLAKE(dev))
> + skylake_pfit_disable(intel_crtc);
> + else
> + ironlake_pfit_disable(intel_crtc);
>
> intel_ddi_disable_pipe_clock(intel_crtc);
>
> @@ -7412,6 +7446,22 @@ static void ironlake_get_fdi_m_n_config(struct intel_crtc *crtc,
> &pipe_config->fdi_m_n, NULL);
> }
>
> +static void skylake_get_pfit_config(struct intel_crtc *crtc,
> + struct intel_crtc_config *pipe_config)
> +{
> + struct drm_device *dev = crtc->base.dev;
> + struct drm_i915_private *dev_priv = dev->dev_private;
> + uint32_t tmp;
> +
> + tmp = I915_READ(PS_CTL(crtc->pipe));
> +
> + if (tmp & PS_ENABLE) {
> + pipe_config->pch_pfit.enabled = true;
> + pipe_config->pch_pfit.pos = I915_READ(PS_WIN_POS(crtc->pipe));
> + pipe_config->pch_pfit.size = I915_READ(PS_WIN_SZ(crtc->pipe));
> + }
> +}
> +
> static void ironlake_get_pfit_config(struct intel_crtc *crtc,
> struct intel_crtc_config *pipe_config)
> {
> @@ -7944,8 +7994,12 @@ static bool haswell_get_pipe_config(struct intel_crtc *crtc,
> intel_get_pipe_timings(crtc, pipe_config);
>
> pfit_domain = POWER_DOMAIN_PIPE_PANEL_FITTER(crtc->pipe);
> - if (intel_display_power_enabled(dev_priv, pfit_domain))
> - ironlake_get_pfit_config(crtc, pipe_config);
> + if (intel_display_power_enabled(dev_priv, pfit_domain)) {
> + if (IS_SKYLAKE(dev))
> + skylake_get_pfit_config(crtc, pipe_config);
> + else
> + ironlake_get_pfit_config(crtc, pipe_config);
> + }
>
> if (IS_HASWELL(dev))
> pipe_config->ips_enabled = hsw_crtc_supports_ips(crtc) &&
> --
> 1.9.1
>
> _______________________________________________
> Intel-gfx mailing list
> Intel-gfx at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/intel-gfx
--
Paulo Zanoni
More information about the Intel-gfx
mailing list