Commit 41a05a3a authored by Daniel Vetter's avatar Daniel Vetter

drm/i915: streamline hsw_pm_irq_handler

The if (pm_iir & ~GEN6_PM_RPS_EVENTS) check was redunandant. Otoh
adding a check for rps events allows us to avoid the spinlock grabbing
for VECS interrupts.

v2: Drop misplaced hunk which now moved to the right patch.
Reviewed-by: default avatarBen Widawsky <ben@bwidawsk.net>
Signed-off-by: default avatarDaniel Vetter <daniel.vetter@ffwll.ch>
parent d0ecd7e2
...@@ -963,18 +963,17 @@ static void dp_aux_irq_handler(struct drm_device *dev) ...@@ -963,18 +963,17 @@ static void dp_aux_irq_handler(struct drm_device *dev)
static void hsw_pm_irq_handler(struct drm_i915_private *dev_priv, static void hsw_pm_irq_handler(struct drm_i915_private *dev_priv,
u32 pm_iir) u32 pm_iir)
{ {
if (pm_iir & GEN6_PM_RPS_EVENTS) {
spin_lock(&dev_priv->rps.lock); spin_lock(&dev_priv->rps.lock);
dev_priv->rps.pm_iir |= pm_iir & GEN6_PM_RPS_EVENTS; dev_priv->rps.pm_iir |= pm_iir & GEN6_PM_RPS_EVENTS;
if (dev_priv->rps.pm_iir) {
I915_WRITE(GEN6_PMIMR, dev_priv->rps.pm_iir); I915_WRITE(GEN6_PMIMR, dev_priv->rps.pm_iir);
/* never want to mask useful interrupts. (also posting read) */ /* never want to mask useful interrupts. (also posting read) */
WARN_ON(I915_READ_NOTRACE(GEN6_PMIMR) & ~GEN6_PM_RPS_EVENTS); WARN_ON(I915_READ_NOTRACE(GEN6_PMIMR) & ~GEN6_PM_RPS_EVENTS);
/* TODO: if queue_work is slow, move it out of the spinlock */ /* TODO: if queue_work is slow, move it out of the spinlock */
queue_work(dev_priv->wq, &dev_priv->rps.work); queue_work(dev_priv->wq, &dev_priv->rps.work);
}
spin_unlock(&dev_priv->rps.lock); spin_unlock(&dev_priv->rps.lock);
}
if (pm_iir & ~GEN6_PM_RPS_EVENTS) {
if (pm_iir & PM_VEBOX_USER_INTERRUPT) if (pm_iir & PM_VEBOX_USER_INTERRUPT)
notify_ring(dev_priv->dev, &dev_priv->ring[VECS]); notify_ring(dev_priv->dev, &dev_priv->ring[VECS]);
...@@ -982,7 +981,6 @@ static void hsw_pm_irq_handler(struct drm_i915_private *dev_priv, ...@@ -982,7 +981,6 @@ static void hsw_pm_irq_handler(struct drm_i915_private *dev_priv,
DRM_ERROR("VEBOX CS error interrupt 0x%08x\n", pm_iir); DRM_ERROR("VEBOX CS error interrupt 0x%08x\n", pm_iir);
i915_handle_error(dev_priv->dev, false); i915_handle_error(dev_priv->dev, false);
} }
}
} }
static irqreturn_t valleyview_irq_handler(int irq, void *arg) static irqreturn_t valleyview_irq_handler(int irq, void *arg)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment