On Thu, Sep 04, 2014 at 12:27:11PM +0100, Damien Lespiau wrote: > From: Pradeep Bhat <pradeep.bhat@xxxxxxxxx> > > This patch defines the structures needed for computation of > watermarks of pipes and planes for SKL. > > v2: Incorporated Damien's review comments and removed unused fields > in structs for future features like rotation, drrs and scaling. > The skl_wm_values struct is now made more generic across planes > and cursor planes for all pipes. > > v3: implemented the plane/cursor split. > > Signed-off-by: Pradeep Bhat <pradeep.bhat@xxxxxxxxx> > Signed-off-by: Damien Lespiau <damien.lespiau@xxxxxxxxx> > --- > drivers/gpu/drm/i915/i915_drv.h | 18 ++++++++++++++++++ > drivers/gpu/drm/i915/intel_drv.h | 10 +++++++++- > drivers/gpu/drm/i915/intel_pm.c | 8 ++++++++ > 3 files changed, 35 insertions(+), 1 deletion(-) > > diff --git a/drivers/gpu/drm/i915/i915_drv.h b/drivers/gpu/drm/i915/i915_drv.h > index 32be299..3764ad5 100644 > --- a/drivers/gpu/drm/i915/i915_drv.h > +++ b/drivers/gpu/drm/i915/i915_drv.h > @@ -1381,6 +1381,24 @@ struct ilk_wm_values { > enum intel_ddb_partitioning partitioning; > }; > > +struct skl_wm_values { > + bool dirty[I915_MAX_PIPES]; > + uint32_t wm_linetime[I915_MAX_PIPES]; > + uint32_t plane[I915_MAX_PIPES][I915_MAX_PLANES][8]; > + uint32_t cursor[I915_MAX_PIPES][8]; > + uint32_t plane_trans[I915_MAX_PIPES][I915_MAX_PLANES]; > + uint32_t cursor_trans[I915_MAX_PIPES]; > +}; > + > +struct skl_wm_level { > + bool plane_en[I915_MAX_PLANES]; > + uint16_t plane_res_b[I915_MAX_PLANES]; > + uint8_t plane_res_l[I915_MAX_PLANES]; > + bool cursor_en; > + uint16_t cursor_res_b; > + uint8_t cursor_res_l; > +}; > + > /* > * This struct helps tracking the state needed for runtime PM, which puts the > * device in PCI D3 state. Notice that when this happens, nothing on the > diff --git a/drivers/gpu/drm/i915/intel_drv.h b/drivers/gpu/drm/i915/intel_drv.h > index 3239e58..268087f 100644 > --- a/drivers/gpu/drm/i915/intel_drv.h > +++ b/drivers/gpu/drm/i915/intel_drv.h > @@ -387,6 +387,12 @@ struct intel_mmio_flip { > u32 ring_id; > }; > > +struct skl_pipe_wm { > + struct skl_wm_level wm[8]; > + struct skl_wm_level trans_wm; > + uint32_t linetime; > +}; > + > struct intel_crtc { > struct drm_crtc base; > enum pipe pipe; > @@ -431,9 +437,11 @@ struct intel_crtc { > bool pch_fifo_underrun_disabled; > > /* per-pipe watermark state */ > - struct { > + union { I almost gave my r-b, but then I noticed this. It's going to mess up my pending watermark series. I'm going to add tons of junk here, so union is not really acceptable for me. Needs some other solution. > /* watermarks currently being used */ > struct intel_pipe_wm active; > + /* SKL wm values currently in use */ > + struct skl_pipe_wm skl_active; > } wm; > > int scanline_offset; > diff --git a/drivers/gpu/drm/i915/intel_pm.c b/drivers/gpu/drm/i915/intel_pm.c > index d8c8531..2503ab9 100644 > --- a/drivers/gpu/drm/i915/intel_pm.c > +++ b/drivers/gpu/drm/i915/intel_pm.c > @@ -1928,6 +1928,14 @@ static uint32_t ilk_wm_fbc(uint32_t pri_val, uint32_t horiz_pixels, > return DIV_ROUND_UP(pri_val * 64, horiz_pixels * bytes_per_pixel) + 2; > } > > +struct skl_pipe_wm_parameters { > + bool active; > + uint32_t pipe_htotal; > + uint32_t pixel_rate; /* in KHz */ > + struct intel_plane_wm_parameters plane[I915_MAX_PLANES]; > + struct intel_plane_wm_parameters cursor; > +}; > + > struct ilk_pipe_wm_parameters { > bool active; > uint32_t pipe_htotal; > -- > 1.8.3.1 > > _______________________________________________ > Intel-gfx mailing list > Intel-gfx@xxxxxxxxxxxxxxxxxxxxx > http://lists.freedesktop.org/mailman/listinfo/intel-gfx -- Ville Syrjälä Intel OTC _______________________________________________ Intel-gfx mailing list Intel-gfx@xxxxxxxxxxxxxxxxxxxxx http://lists.freedesktop.org/mailman/listinfo/intel-gfx