drm/i915: wrap GEN6_PMIMR changes
Just like we're doing with the other IMR changes. One of the functional changes is that not every caller was doing the POSTING_READ. Signed-off-by: Paulo Zanoni <paulo.r.zanoni@intel.com> Reviewed-by: Rodrigo Vivi <rodrigo.vivi@gmail.com> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
This commit is contained in:
parent
43eaea1318
commit
edbfdb4560
|
@ -132,6 +132,41 @@ void ilk_disable_gt_irq(struct drm_i915_private *dev_priv, uint32_t mask)
|
||||||
ilk_update_gt_irq(dev_priv, mask, 0);
|
ilk_update_gt_irq(dev_priv, mask, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* snb_update_pm_irq - update GEN6_PMIMR
|
||||||
|
* @dev_priv: driver private
|
||||||
|
* @interrupt_mask: mask of interrupt bits to update
|
||||||
|
* @enabled_irq_mask: mask of interrupt bits to enable
|
||||||
|
*/
|
||||||
|
static void snb_update_pm_irq(struct drm_i915_private *dev_priv,
|
||||||
|
uint32_t interrupt_mask,
|
||||||
|
uint32_t enabled_irq_mask)
|
||||||
|
{
|
||||||
|
uint32_t pmimr = I915_READ(GEN6_PMIMR);
|
||||||
|
pmimr &= ~interrupt_mask;
|
||||||
|
pmimr |= (~enabled_irq_mask & interrupt_mask);
|
||||||
|
|
||||||
|
assert_spin_locked(&dev_priv->irq_lock);
|
||||||
|
|
||||||
|
I915_WRITE(GEN6_PMIMR, pmimr);
|
||||||
|
POSTING_READ(GEN6_PMIMR);
|
||||||
|
}
|
||||||
|
|
||||||
|
void snb_enable_pm_irq(struct drm_i915_private *dev_priv, uint32_t mask)
|
||||||
|
{
|
||||||
|
snb_update_pm_irq(dev_priv, mask, mask);
|
||||||
|
}
|
||||||
|
|
||||||
|
void snb_disable_pm_irq(struct drm_i915_private *dev_priv, uint32_t mask)
|
||||||
|
{
|
||||||
|
snb_update_pm_irq(dev_priv, mask, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void snb_set_pm_irq(struct drm_i915_private *dev_priv, uint32_t val)
|
||||||
|
{
|
||||||
|
snb_update_pm_irq(dev_priv, 0xffffffff, ~val);
|
||||||
|
}
|
||||||
|
|
||||||
static bool ivb_can_enable_err_int(struct drm_device *dev)
|
static bool ivb_can_enable_err_int(struct drm_device *dev)
|
||||||
{
|
{
|
||||||
struct drm_i915_private *dev_priv = dev->dev_private;
|
struct drm_i915_private *dev_priv = dev->dev_private;
|
||||||
|
@ -739,15 +774,14 @@ static void gen6_pm_rps_work(struct work_struct *work)
|
||||||
{
|
{
|
||||||
drm_i915_private_t *dev_priv = container_of(work, drm_i915_private_t,
|
drm_i915_private_t *dev_priv = container_of(work, drm_i915_private_t,
|
||||||
rps.work);
|
rps.work);
|
||||||
u32 pm_iir, pm_imr;
|
u32 pm_iir;
|
||||||
u8 new_delay;
|
u8 new_delay;
|
||||||
|
|
||||||
spin_lock_irq(&dev_priv->irq_lock);
|
spin_lock_irq(&dev_priv->irq_lock);
|
||||||
pm_iir = dev_priv->rps.pm_iir;
|
pm_iir = dev_priv->rps.pm_iir;
|
||||||
dev_priv->rps.pm_iir = 0;
|
dev_priv->rps.pm_iir = 0;
|
||||||
pm_imr = I915_READ(GEN6_PMIMR);
|
|
||||||
/* Make sure not to corrupt PMIMR state used by ringbuffer code */
|
/* Make sure not to corrupt PMIMR state used by ringbuffer code */
|
||||||
I915_WRITE(GEN6_PMIMR, pm_imr & ~GEN6_PM_RPS_EVENTS);
|
snb_enable_pm_irq(dev_priv, GEN6_PM_RPS_EVENTS);
|
||||||
spin_unlock_irq(&dev_priv->irq_lock);
|
spin_unlock_irq(&dev_priv->irq_lock);
|
||||||
|
|
||||||
if ((pm_iir & GEN6_PM_RPS_EVENTS) == 0)
|
if ((pm_iir & GEN6_PM_RPS_EVENTS) == 0)
|
||||||
|
@ -921,8 +955,7 @@ static void gen6_rps_irq_handler(struct drm_i915_private *dev_priv,
|
||||||
|
|
||||||
spin_lock(&dev_priv->irq_lock);
|
spin_lock(&dev_priv->irq_lock);
|
||||||
dev_priv->rps.pm_iir |= pm_iir;
|
dev_priv->rps.pm_iir |= pm_iir;
|
||||||
I915_WRITE(GEN6_PMIMR, dev_priv->rps.pm_iir);
|
snb_set_pm_irq(dev_priv, dev_priv->rps.pm_iir);
|
||||||
POSTING_READ(GEN6_PMIMR);
|
|
||||||
spin_unlock(&dev_priv->irq_lock);
|
spin_unlock(&dev_priv->irq_lock);
|
||||||
|
|
||||||
queue_work(dev_priv->wq, &dev_priv->rps.work);
|
queue_work(dev_priv->wq, &dev_priv->rps.work);
|
||||||
|
@ -1005,8 +1038,8 @@ static void hsw_pm_irq_handler(struct drm_i915_private *dev_priv,
|
||||||
if (pm_iir & GEN6_PM_RPS_EVENTS) {
|
if (pm_iir & GEN6_PM_RPS_EVENTS) {
|
||||||
spin_lock(&dev_priv->irq_lock);
|
spin_lock(&dev_priv->irq_lock);
|
||||||
dev_priv->rps.pm_iir |= pm_iir & GEN6_PM_RPS_EVENTS;
|
dev_priv->rps.pm_iir |= pm_iir & GEN6_PM_RPS_EVENTS;
|
||||||
I915_WRITE(GEN6_PMIMR, dev_priv->rps.pm_iir);
|
snb_set_pm_irq(dev_priv, dev_priv->rps.pm_iir);
|
||||||
/* never want to mask useful interrupts. (also posting read) */
|
/* never want to mask useful interrupts. */
|
||||||
WARN_ON(I915_READ_NOTRACE(GEN6_PMIMR) & ~GEN6_PM_RPS_EVENTS);
|
WARN_ON(I915_READ_NOTRACE(GEN6_PMIMR) & ~GEN6_PM_RPS_EVENTS);
|
||||||
spin_unlock(&dev_priv->irq_lock);
|
spin_unlock(&dev_priv->irq_lock);
|
||||||
|
|
||||||
|
|
|
@ -781,5 +781,8 @@ extern void hsw_restore_lcpll(struct drm_i915_private *dev_priv);
|
||||||
extern void ilk_enable_gt_irq(struct drm_i915_private *dev_priv, uint32_t mask);
|
extern void ilk_enable_gt_irq(struct drm_i915_private *dev_priv, uint32_t mask);
|
||||||
extern void ilk_disable_gt_irq(struct drm_i915_private *dev_priv,
|
extern void ilk_disable_gt_irq(struct drm_i915_private *dev_priv,
|
||||||
uint32_t mask);
|
uint32_t mask);
|
||||||
|
extern void snb_enable_pm_irq(struct drm_i915_private *dev_priv, uint32_t mask);
|
||||||
|
extern void snb_disable_pm_irq(struct drm_i915_private *dev_priv,
|
||||||
|
uint32_t mask);
|
||||||
|
|
||||||
#endif /* __INTEL_DRV_H__ */
|
#endif /* __INTEL_DRV_H__ */
|
||||||
|
|
|
@ -3450,7 +3450,7 @@ static void gen6_enable_rps_interrupts(struct drm_device *dev)
|
||||||
|
|
||||||
spin_lock_irq(&dev_priv->irq_lock);
|
spin_lock_irq(&dev_priv->irq_lock);
|
||||||
WARN_ON(dev_priv->rps.pm_iir);
|
WARN_ON(dev_priv->rps.pm_iir);
|
||||||
I915_WRITE(GEN6_PMIMR, I915_READ(GEN6_PMIMR) & ~GEN6_PM_RPS_EVENTS);
|
snb_enable_pm_irq(dev_priv, GEN6_PM_RPS_EVENTS);
|
||||||
I915_WRITE(GEN6_PMIIR, GEN6_PM_RPS_EVENTS);
|
I915_WRITE(GEN6_PMIIR, GEN6_PM_RPS_EVENTS);
|
||||||
spin_unlock_irq(&dev_priv->irq_lock);
|
spin_unlock_irq(&dev_priv->irq_lock);
|
||||||
/* only unmask PM interrupts we need. Mask all others. */
|
/* only unmask PM interrupts we need. Mask all others. */
|
||||||
|
|
|
@ -1062,10 +1062,8 @@ hsw_vebox_get_irq(struct intel_ring_buffer *ring)
|
||||||
|
|
||||||
spin_lock_irqsave(&dev_priv->irq_lock, flags);
|
spin_lock_irqsave(&dev_priv->irq_lock, flags);
|
||||||
if (ring->irq_refcount++ == 0) {
|
if (ring->irq_refcount++ == 0) {
|
||||||
u32 pm_imr = I915_READ(GEN6_PMIMR);
|
|
||||||
I915_WRITE_IMR(ring, ~ring->irq_enable_mask);
|
I915_WRITE_IMR(ring, ~ring->irq_enable_mask);
|
||||||
I915_WRITE(GEN6_PMIMR, pm_imr & ~ring->irq_enable_mask);
|
snb_enable_pm_irq(dev_priv, ring->irq_enable_mask);
|
||||||
POSTING_READ(GEN6_PMIMR);
|
|
||||||
}
|
}
|
||||||
spin_unlock_irqrestore(&dev_priv->irq_lock, flags);
|
spin_unlock_irqrestore(&dev_priv->irq_lock, flags);
|
||||||
|
|
||||||
|
@ -1084,10 +1082,8 @@ hsw_vebox_put_irq(struct intel_ring_buffer *ring)
|
||||||
|
|
||||||
spin_lock_irqsave(&dev_priv->irq_lock, flags);
|
spin_lock_irqsave(&dev_priv->irq_lock, flags);
|
||||||
if (--ring->irq_refcount == 0) {
|
if (--ring->irq_refcount == 0) {
|
||||||
u32 pm_imr = I915_READ(GEN6_PMIMR);
|
|
||||||
I915_WRITE_IMR(ring, ~0);
|
I915_WRITE_IMR(ring, ~0);
|
||||||
I915_WRITE(GEN6_PMIMR, pm_imr | ring->irq_enable_mask);
|
snb_disable_pm_irq(dev_priv, ring->irq_enable_mask);
|
||||||
POSTING_READ(GEN6_PMIMR);
|
|
||||||
}
|
}
|
||||||
spin_unlock_irqrestore(&dev_priv->irq_lock, flags);
|
spin_unlock_irqrestore(&dev_priv->irq_lock, flags);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue