提交 7e79a683 编写于 作者: S Sagar Arun Kamble 提交者: Chris Wilson

drm/i915: Set adjustment to zero on Up/Down interrupts if freq is already max/min

When we reach the user's RPS limits, stop requesting an adjustment. Even
though we will clamp the requested frequency later, we rely on interrupt
masking to disable further adjustments in the same direction. Even
though it is unlikely (one scenario is a bug in the driver, another is
careful manipulation through the uAPI) if we keep exponentially
increasing the adjustment value, it will wrap and cause a negative
adjustment.
Signed-off-by: NChris Wilson <chris@chris-wilson.co.uk>
Reviewed-by: NSagar Arun Kamble <sagar.a.kamble@intel.com>
Link: http://patchwork.freedesktop.org/patch/msgid/1484884104-28134-2-git-send-email-sagar.a.kamble@intel.com
上级 e9612823
...@@ -1170,6 +1170,9 @@ static void gen6_pm_rps_work(struct work_struct *work) ...@@ -1170,6 +1170,9 @@ static void gen6_pm_rps_work(struct work_struct *work)
adj *= 2; adj *= 2;
else /* CHV needs even encode values */ else /* CHV needs even encode values */
adj = IS_CHERRYVIEW(dev_priv) ? 2 : 1; adj = IS_CHERRYVIEW(dev_priv) ? 2 : 1;
if (new_delay >= dev_priv->rps.max_freq_softlimit)
adj = 0;
/* /*
* For better performance, jump directly * For better performance, jump directly
* to RPe if we're below it. * to RPe if we're below it.
...@@ -1191,6 +1194,9 @@ static void gen6_pm_rps_work(struct work_struct *work) ...@@ -1191,6 +1194,9 @@ static void gen6_pm_rps_work(struct work_struct *work)
adj *= 2; adj *= 2;
else /* CHV needs even encode values */ else /* CHV needs even encode values */
adj = IS_CHERRYVIEW(dev_priv) ? -2 : -1; adj = IS_CHERRYVIEW(dev_priv) ? -2 : -1;
if (new_delay <= dev_priv->rps.min_freq_softlimit)
adj = 0;
} else { /* unknown event */ } else { /* unknown event */
adj = 0; adj = 0;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册