[Intel-gfx] [PATCH v3 3/3] drm/i915: Defer unmasking RPS interrupts until after making adjustments
Mika Kuoppala
mika.kuoppala at linux.intel.com
Fri Mar 10 14:13:54 UTC 2017
Chris Wilson <chris at chris-wilson.co.uk> writes:
> To make our adjustments to RPS requires taking a mutex and potentially
> sleeping for an unknown duration - until we have completed our
> adjustments further RPS interrupts are immaterial (they are based on
> stale thresholds) and we can safely ignore them.
>
> Signed-off-by: Chris Wilson <chris at chris-wilson.co.uk>
> Cc: Mika Kuoppala <mika.kuoppala at linux.intel.com>
Reviewed-by: Mika Kuoppala <mika.kuoppala at intel.com>
> ---
> drivers/gpu/drm/i915/i915_irq.c | 28 +++++++++++++---------------
> 1 file changed, 13 insertions(+), 15 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/i915_irq.c b/drivers/gpu/drm/i915/i915_irq.c
> index e8f4c78c4bdc..ab55a3ddafb3 100644
> --- a/drivers/gpu/drm/i915/i915_irq.c
> +++ b/drivers/gpu/drm/i915/i915_irq.c
> @@ -1149,30 +1149,21 @@ static void gen6_pm_rps_work(struct work_struct *work)
> {
> struct drm_i915_private *dev_priv =
> container_of(work, struct drm_i915_private, rps.work);
> - bool client_boost;
> + bool client_boost = false;
> int new_delay, adj, min, max;
> - u32 pm_iir;
> + u32 pm_iir = 0;
>
> spin_lock_irq(&dev_priv->irq_lock);
> - /* Speed up work cancelation during disabling rps interrupts. */
> - if (!dev_priv->rps.interrupts_enabled) {
> - spin_unlock_irq(&dev_priv->irq_lock);
> - return;
> + if (dev_priv->rps.interrupts_enabled) {
> + pm_iir = fetch_and_zero(&dev_priv->rps.pm_iir);
> + client_boost = fetch_and_zero(&dev_priv->rps.client_boost);
> }
> -
> - pm_iir = dev_priv->rps.pm_iir;
> - dev_priv->rps.pm_iir = 0;
> - /* Make sure not to corrupt PMIMR state used by ringbuffer on GEN6 */
> - gen6_unmask_pm_irq(dev_priv, dev_priv->pm_rps_events);
> - client_boost = dev_priv->rps.client_boost;
> - dev_priv->rps.client_boost = false;
> spin_unlock_irq(&dev_priv->irq_lock);
>
> /* Make sure we didn't queue anything we're not going to process. */
> WARN_ON(pm_iir & ~dev_priv->pm_rps_events);
> -
> if ((pm_iir & dev_priv->pm_rps_events) == 0 && !client_boost)
> - return;
> + goto out;
>
> mutex_lock(&dev_priv->rps.hw_lock);
>
> @@ -1229,6 +1220,13 @@ static void gen6_pm_rps_work(struct work_struct *work)
> }
>
> mutex_unlock(&dev_priv->rps.hw_lock);
> +
> +out:
> + /* Make sure not to corrupt PMIMR state used by ringbuffer on GEN6 */
> + spin_lock_irq(&dev_priv->irq_lock);
> + if (dev_priv->rps.interrupts_enabled)
> + gen6_unmask_pm_irq(dev_priv, dev_priv->pm_rps_events);
> + spin_unlock_irq(&dev_priv->irq_lock);
> }
>
>
> --
> 2.11.0
More information about the Intel-gfx
mailing list