drm/i915: kill pch_init_clock_gating indirection
Now that we no longer pretend to have flexibility in matching any north display block with any pch, we can ditch this. v2: Fix the embarassing rebase fail that Paulo Zanoni spotted. Reviewed-by: Paulo Zanoni <paulo.r.zanoni@intel.com> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
This commit is contained in:
parent
ce40141f55
commit
3107bd48bf
2 changed files with 38 additions and 41 deletions
|
@ -270,7 +270,6 @@ struct drm_i915_display_funcs {
|
||||||
struct drm_crtc *crtc);
|
struct drm_crtc *crtc);
|
||||||
void (*fdi_link_train)(struct drm_crtc *crtc);
|
void (*fdi_link_train)(struct drm_crtc *crtc);
|
||||||
void (*init_clock_gating)(struct drm_device *dev);
|
void (*init_clock_gating)(struct drm_device *dev);
|
||||||
void (*init_pch_clock_gating)(struct drm_device *dev);
|
|
||||||
int (*queue_flip)(struct drm_device *dev, struct drm_crtc *crtc,
|
int (*queue_flip)(struct drm_device *dev, struct drm_crtc *crtc,
|
||||||
struct drm_framebuffer *fb,
|
struct drm_framebuffer *fb,
|
||||||
struct drm_i915_gem_object *obj);
|
struct drm_i915_gem_object *obj);
|
||||||
|
|
|
@ -3324,6 +3324,18 @@ void intel_enable_gt_powersave(struct drm_device *dev)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void ibx_init_clock_gating(struct drm_device *dev)
|
||||||
|
{
|
||||||
|
struct drm_i915_private *dev_priv = dev->dev_private;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* On Ibex Peak and Cougar Point, we need to disable clock
|
||||||
|
* gating for the panel power sequencer or it will fail to
|
||||||
|
* start up when no ports are active.
|
||||||
|
*/
|
||||||
|
I915_WRITE(SOUTH_DSPCLK_GATE_D, PCH_DPLSUNIT_CLOCK_GATE_DISABLE);
|
||||||
|
}
|
||||||
|
|
||||||
static void ironlake_init_clock_gating(struct drm_device *dev)
|
static void ironlake_init_clock_gating(struct drm_device *dev)
|
||||||
{
|
{
|
||||||
struct drm_i915_private *dev_priv = dev->dev_private;
|
struct drm_i915_private *dev_priv = dev->dev_private;
|
||||||
|
@ -3386,6 +3398,28 @@ static void ironlake_init_clock_gating(struct drm_device *dev)
|
||||||
/* WaDisableRenderCachePipelinedFlush */
|
/* WaDisableRenderCachePipelinedFlush */
|
||||||
I915_WRITE(CACHE_MODE_0,
|
I915_WRITE(CACHE_MODE_0,
|
||||||
_MASKED_BIT_ENABLE(CM0_PIPELINED_RENDER_FLUSH_DISABLE));
|
_MASKED_BIT_ENABLE(CM0_PIPELINED_RENDER_FLUSH_DISABLE));
|
||||||
|
|
||||||
|
ibx_init_clock_gating(dev);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void cpt_init_clock_gating(struct drm_device *dev)
|
||||||
|
{
|
||||||
|
struct drm_i915_private *dev_priv = dev->dev_private;
|
||||||
|
int pipe;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* On Ibex Peak and Cougar Point, we need to disable clock
|
||||||
|
* gating for the panel power sequencer or it will fail to
|
||||||
|
* start up when no ports are active.
|
||||||
|
*/
|
||||||
|
I915_WRITE(SOUTH_DSPCLK_GATE_D, PCH_DPLSUNIT_CLOCK_GATE_DISABLE);
|
||||||
|
I915_WRITE(SOUTH_CHICKEN2, I915_READ(SOUTH_CHICKEN2) |
|
||||||
|
DPLS_EDP_PPS_FIX_DIS);
|
||||||
|
/* WADP0ClockGatingDisable */
|
||||||
|
for_each_pipe(pipe) {
|
||||||
|
I915_WRITE(TRANS_CHICKEN1(pipe),
|
||||||
|
TRANS_CHICKEN1_DP0UNIT_GC_DISABLE);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void gen6_init_clock_gating(struct drm_device *dev)
|
static void gen6_init_clock_gating(struct drm_device *dev)
|
||||||
|
@ -3468,6 +3502,8 @@ static void gen6_init_clock_gating(struct drm_device *dev)
|
||||||
* platforms I checked have a 0 for this. (Maybe BIOS overrides?) */
|
* platforms I checked have a 0 for this. (Maybe BIOS overrides?) */
|
||||||
I915_WRITE(GEN6_GT_MODE, _MASKED_BIT_DISABLE(0xffff));
|
I915_WRITE(GEN6_GT_MODE, _MASKED_BIT_DISABLE(0xffff));
|
||||||
I915_WRITE(GEN6_GT_MODE, _MASKED_BIT_ENABLE(GEN6_GT_MODE_HI));
|
I915_WRITE(GEN6_GT_MODE, _MASKED_BIT_ENABLE(GEN6_GT_MODE_HI));
|
||||||
|
|
||||||
|
cpt_init_clock_gating(dev);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void gen7_setup_fixed_func_scheduler(struct drm_i915_private *dev_priv)
|
static void gen7_setup_fixed_func_scheduler(struct drm_i915_private *dev_priv)
|
||||||
|
@ -3612,6 +3648,8 @@ static void ivybridge_init_clock_gating(struct drm_device *dev)
|
||||||
snpcr &= ~GEN6_MBC_SNPCR_MASK;
|
snpcr &= ~GEN6_MBC_SNPCR_MASK;
|
||||||
snpcr |= GEN6_MBC_SNPCR_MED;
|
snpcr |= GEN6_MBC_SNPCR_MED;
|
||||||
I915_WRITE(GEN6_MBCUNIT_SNPCR, snpcr);
|
I915_WRITE(GEN6_MBCUNIT_SNPCR, snpcr);
|
||||||
|
|
||||||
|
cpt_init_clock_gating(dev);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void valleyview_init_clock_gating(struct drm_device *dev)
|
static void valleyview_init_clock_gating(struct drm_device *dev)
|
||||||
|
@ -3779,46 +3817,11 @@ static void i830_init_clock_gating(struct drm_device *dev)
|
||||||
I915_WRITE(DSPCLK_GATE_D, OVRUNIT_CLOCK_GATE_DISABLE);
|
I915_WRITE(DSPCLK_GATE_D, OVRUNIT_CLOCK_GATE_DISABLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ibx_init_clock_gating(struct drm_device *dev)
|
|
||||||
{
|
|
||||||
struct drm_i915_private *dev_priv = dev->dev_private;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* On Ibex Peak and Cougar Point, we need to disable clock
|
|
||||||
* gating for the panel power sequencer or it will fail to
|
|
||||||
* start up when no ports are active.
|
|
||||||
*/
|
|
||||||
I915_WRITE(SOUTH_DSPCLK_GATE_D, PCH_DPLSUNIT_CLOCK_GATE_DISABLE);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void cpt_init_clock_gating(struct drm_device *dev)
|
|
||||||
{
|
|
||||||
struct drm_i915_private *dev_priv = dev->dev_private;
|
|
||||||
int pipe;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* On Ibex Peak and Cougar Point, we need to disable clock
|
|
||||||
* gating for the panel power sequencer or it will fail to
|
|
||||||
* start up when no ports are active.
|
|
||||||
*/
|
|
||||||
I915_WRITE(SOUTH_DSPCLK_GATE_D, PCH_DPLSUNIT_CLOCK_GATE_DISABLE);
|
|
||||||
I915_WRITE(SOUTH_CHICKEN2, I915_READ(SOUTH_CHICKEN2) |
|
|
||||||
DPLS_EDP_PPS_FIX_DIS);
|
|
||||||
/* WADP0ClockGatingDisable */
|
|
||||||
for_each_pipe(pipe) {
|
|
||||||
I915_WRITE(TRANS_CHICKEN1(pipe),
|
|
||||||
TRANS_CHICKEN1_DP0UNIT_GC_DISABLE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void intel_init_clock_gating(struct drm_device *dev)
|
void intel_init_clock_gating(struct drm_device *dev)
|
||||||
{
|
{
|
||||||
struct drm_i915_private *dev_priv = dev->dev_private;
|
struct drm_i915_private *dev_priv = dev->dev_private;
|
||||||
|
|
||||||
dev_priv->display.init_clock_gating(dev);
|
dev_priv->display.init_clock_gating(dev);
|
||||||
|
|
||||||
if (dev_priv->display.init_pch_clock_gating)
|
|
||||||
dev_priv->display.init_pch_clock_gating(dev);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Starting with Haswell, we have different power wells for
|
/* Starting with Haswell, we have different power wells for
|
||||||
|
@ -3882,11 +3885,6 @@ void intel_init_pm(struct drm_device *dev)
|
||||||
|
|
||||||
/* For FIFO watermark updates */
|
/* For FIFO watermark updates */
|
||||||
if (HAS_PCH_SPLIT(dev)) {
|
if (HAS_PCH_SPLIT(dev)) {
|
||||||
if (HAS_PCH_IBX(dev))
|
|
||||||
dev_priv->display.init_pch_clock_gating = ibx_init_clock_gating;
|
|
||||||
else if (HAS_PCH_CPT(dev))
|
|
||||||
dev_priv->display.init_pch_clock_gating = cpt_init_clock_gating;
|
|
||||||
|
|
||||||
if (IS_GEN5(dev)) {
|
if (IS_GEN5(dev)) {
|
||||||
if (I915_READ(MLTR_ILK) & ILK_SRLT_MASK)
|
if (I915_READ(MLTR_ILK) & ILK_SRLT_MASK)
|
||||||
dev_priv->display.update_wm = ironlake_update_wm;
|
dev_priv->display.update_wm = ironlake_update_wm;
|
||||||
|
|
Loading…
Add table
Reference in a new issue