> -----Original Message-----
> From: Laxminarayan Bharadiya, Pankaj
> <pankaj.laxminarayan.bharad...@intel.com>
> Sent: Monday, August 3, 2020 10:00 AM
> To: jani.nik...@linux.intel.com; dan...@ffwll.ch; 
> intel-...@lists.freedesktop.org;
> dri-devel@lists.freedesktop.org; ville.syrj...@linux.intel.com;
> dani...@collabora.com; Lattannavar, Sameer <sameer.lattanna...@intel.com>;
> Joonas Lahtinen <joonas.lahti...@linux.intel.com>; Vivi, Rodrigo
> <rodrigo.v...@intel.com>; David Airlie <airl...@linux.ie>; Maarten Lankhorst
> <maarten.lankho...@linux.intel.com>; Chris Wilson <ch...@chris-wilson.co.uk>;
> Deak, Imre <imre.d...@intel.com>; Laxminarayan Bharadiya, Pankaj
> <pankaj.laxminarayan.bharad...@intel.com>; Lisovskiy, Stanislav
> <stanislav.lisovs...@intel.com>; Souza, Jose <jose.so...@intel.com>; Navare,
> Manasi D <manasi.d.nav...@intel.com>; Wambui Karuga
> <wambui.karu...@gmail.com>; Gupta, Anshuman
> <anshuman.gu...@intel.com>; Shankar, Uma <uma.shan...@intel.com>; Roper,
> Matthew D <matthew.d.ro...@intel.com>; Pandiyan, Dhinakaran
> <dhinakaran.pandi...@intel.com>
> Subject: [PATCH v5 5/5] drm/i915: Enable scaling filter for plane and CRTC
> 
> GEN >= 10 hardware supports the programmable scaler filter.
> 
> Attach scaling filter property for CRTC and plane for GEN >= 10 hardwares and
> program scaler filter based on the selected filter type.

Looks good to me.
Reviewed-by: Uma Shankar <uma.shan...@intel.com>  

> changes since v3:
> * None
> changes since v2:
> * Use updated functions
> * Add ps_ctrl var to contain the full PS_CTRL register value (Ville)
> * Duplicate the scaling filter in crtc and plane hw state (Ville) changes 
> since v1:
> * None
> Changes since RFC:
> * Enable properties for GEN >= 10 platforms (Ville)
> * Do not round off the crtc co-ordinate (Danial Stone, Ville)
> * Add new functions to handle scaling filter setup (Ville)
> * Remove coefficient set 0 hardcoding.
> 
> Signed-off-by: Shashank Sharma <shashank.sha...@intel.com>
> Signed-off-by: Ankit Nautiyal <ankit.k.nauti...@intel.com>
> Signed-off-by: Pankaj Bharadiya <pankaj.laxminarayan.bharad...@intel.com>
> ---
>  .../gpu/drm/i915/display/intel_atomic_plane.c  |  1 +
>  drivers/gpu/drm/i915/display/intel_display.c   | 18 ++++++++++++++++--
>  .../gpu/drm/i915/display/intel_display_types.h |  2 ++
>  drivers/gpu/drm/i915/display/intel_sprite.c    | 15 +++++++++++++--
>  4 files changed, 32 insertions(+), 4 deletions(-)
> 
> diff --git a/drivers/gpu/drm/i915/display/intel_atomic_plane.c
> b/drivers/gpu/drm/i915/display/intel_atomic_plane.c
> index 79032701873a..415d41b21915 100644
> --- a/drivers/gpu/drm/i915/display/intel_atomic_plane.c
> +++ b/drivers/gpu/drm/i915/display/intel_atomic_plane.c
> @@ -262,6 +262,7 @@ void intel_plane_copy_uapi_to_hw_state(struct
> intel_plane_state *plane_state,
>       plane_state->hw.rotation = from_plane_state->uapi.rotation;
>       plane_state->hw.color_encoding = from_plane_state-
> >uapi.color_encoding;
>       plane_state->hw.color_range = from_plane_state->uapi.color_range;
> +     plane_state->hw.scaling_filter =
> +from_plane_state->uapi.scaling_filter;
>  }
> 
>  void intel_plane_set_invisible(struct intel_crtc_state *crtc_state, diff 
> --git
> a/drivers/gpu/drm/i915/display/intel_display.c
> b/drivers/gpu/drm/i915/display/intel_display.c
> index 388999404e05..507932099b8d 100644
> --- a/drivers/gpu/drm/i915/display/intel_display.c
> +++ b/drivers/gpu/drm/i915/display/intel_display.c
> @@ -6352,6 +6352,7 @@ static void skl_pfit_enable(const struct 
> intel_crtc_state
> *crtc_state)
>       int hscale, vscale;
>       unsigned long irqflags;
>       int id;
> +     u32 ps_ctrl;
> 
>       if (!crtc_state->pch_pfit.enabled)
>               return;
> @@ -6368,10 +6369,16 @@ static void skl_pfit_enable(const struct
> intel_crtc_state *crtc_state)
> 
>       id = scaler_state->scaler_id;
> 
> +     ps_ctrl = skl_scaler_get_filter_select(crtc_state->hw.scaling_filter, 
> 0);
> +     ps_ctrl |=  PS_SCALER_EN | scaler_state->scalers[id].mode;
> +
>       spin_lock_irqsave(&dev_priv->uncore.lock, irqflags);
> 
> -     intel_de_write_fw(dev_priv, SKL_PS_CTRL(pipe, id), PS_SCALER_EN |
> -                       PS_FILTER_MEDIUM | scaler_state->scalers[id].mode);
> +     skl_scaler_setup_filter(dev_priv, pipe, id, 0,
> +                             crtc_state->hw.scaling_filter);
> +
> +     intel_de_write_fw(dev_priv, SKL_PS_CTRL(pipe, id), ps_ctrl);
> +
>       intel_de_write_fw(dev_priv, SKL_PS_VPHASE(pipe, id),
>                         PS_Y_PHASE(0) | PS_UV_RGB_PHASE(uv_rgb_vphase));
>       intel_de_write_fw(dev_priv, SKL_PS_HPHASE(pipe, id), @@ -13332,6
> +13339,7 @@ intel_crtc_copy_uapi_to_hw_state(struct intel_crtc_state
> *crtc_state)
>       crtc_state->hw.active = crtc_state->uapi.active;
>       crtc_state->hw.mode = crtc_state->uapi.mode;
>       crtc_state->hw.adjusted_mode = crtc_state->uapi.adjusted_mode;
> +     crtc_state->hw.scaling_filter = crtc_state->uapi.scaling_filter;
>       intel_crtc_copy_uapi_to_hw_state_nomodeset(crtc_state);
>  }
> 
> @@ -13343,6 +13351,7 @@ static void intel_crtc_copy_hw_to_uapi_state(struct
> intel_crtc_state *crtc_state
>                   drm_atomic_set_mode_for_crtc(&crtc_state->uapi,
> &crtc_state->hw.mode) < 0);
> 
>       crtc_state->uapi.adjusted_mode = crtc_state->hw.adjusted_mode;
> +     crtc_state->uapi.scaling_filter = crtc_state->hw.scaling_filter;
> 
>       /* copy color blobs to uapi */
>       drm_property_replace_blob(&crtc_state->uapi.degamma_lut,
> @@ -16810,6 +16819,11 @@ static int intel_crtc_init(struct drm_i915_private
> *dev_priv, enum pipe pipe)
>               dev_priv->plane_to_crtc_mapping[i9xx_plane] = crtc;
>       }
> 
> +     if (INTEL_GEN(dev_priv) >= 10)
> +             drm_crtc_create_scaling_filter_property(&crtc->base,
> +
>       BIT(DRM_SCALING_FILTER_DEFAULT) |
> +
>       BIT(DRM_SCALING_FILTER_NEAREST_NEIGHBOR));
> +
>       intel_color_init(crtc);
> 
>       intel_crtc_crc_init(crtc);
> diff --git a/drivers/gpu/drm/i915/display/intel_display_types.h
> b/drivers/gpu/drm/i915/display/intel_display_types.h
> index f581260e8dbf..670ab317134b 100644
> --- a/drivers/gpu/drm/i915/display/intel_display_types.h
> +++ b/drivers/gpu/drm/i915/display/intel_display_types.h
> @@ -518,6 +518,7 @@ struct intel_plane_state {
>               unsigned int rotation;
>               enum drm_color_encoding color_encoding;
>               enum drm_color_range color_range;
> +             enum drm_scaling_filter scaling_filter;
>       } hw;
> 
>       struct i915_ggtt_view view;
> @@ -808,6 +809,7 @@ struct intel_crtc_state {
>               bool active, enable;
>               struct drm_property_blob *degamma_lut, *gamma_lut, *ctm;
>               struct drm_display_mode mode, adjusted_mode;
> +             enum drm_scaling_filter scaling_filter;
>       } hw;
> 
>       /**
> diff --git a/drivers/gpu/drm/i915/display/intel_sprite.c
> b/drivers/gpu/drm/i915/display/intel_sprite.c
> index c26ca029fc0a..8f1a6b6061af 100644
> --- a/drivers/gpu/drm/i915/display/intel_sprite.c
> +++ b/drivers/gpu/drm/i915/display/intel_sprite.c
> @@ -429,6 +429,7 @@ skl_program_scaler(struct intel_plane *plane,
>       u16 y_hphase, uv_rgb_hphase;
>       u16 y_vphase, uv_rgb_vphase;
>       int hscale, vscale;
> +     u32 ps_ctrl;
> 
>       hscale = drm_rect_calc_hscale(&plane_state->uapi.src,
>                                     &plane_state->uapi.dst,
> @@ -455,8 +456,13 @@ skl_program_scaler(struct intel_plane *plane,
>               uv_rgb_vphase = skl_scaler_calc_phase(1, vscale, false);
>       }
> 
> -     intel_de_write_fw(dev_priv, SKL_PS_CTRL(pipe, scaler_id),
> -                       PS_SCALER_EN | PS_PLANE_SEL(plane->id) | scaler-
> >mode);
> +     ps_ctrl = skl_scaler_get_filter_select(plane_state->hw.scaling_filter, 
> 0);
> +     ps_ctrl |= PS_SCALER_EN | PS_PLANE_SEL(plane->id) | scaler->mode;
> +
> +     skl_scaler_setup_filter(dev_priv, pipe, scaler_id, 0,
> +                             plane_state->hw.scaling_filter);
> +
> +     intel_de_write_fw(dev_priv, SKL_PS_CTRL(pipe, scaler_id), ps_ctrl);
>       intel_de_write_fw(dev_priv, SKL_PS_VPHASE(pipe, scaler_id),
>                         PS_Y_PHASE(y_vphase) |
> PS_UV_RGB_PHASE(uv_rgb_vphase));
>       intel_de_write_fw(dev_priv, SKL_PS_HPHASE(pipe, scaler_id), @@ -
> 3161,6 +3167,11 @@ skl_universal_plane_create(struct drm_i915_private
> *dev_priv,
>       if (INTEL_GEN(dev_priv) >= 12)
>               drm_plane_enable_fb_damage_clips(&plane->base);
> 
> +     if (INTEL_GEN(dev_priv) >= 10)
> +             drm_plane_create_scaling_filter_property(&plane->base,
> +
>       BIT(DRM_SCALING_FILTER_DEFAULT) |
> +
>       BIT(DRM_SCALING_FILTER_NEAREST_NEIGHBOR));
> +
>       drm_plane_helper_add(&plane->base, &intel_plane_helper_funcs);
> 
>       return plane;
> --
> 2.23.0

_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel

Reply via email to