aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPaulo Zanoni <paulo.r.zanoni@intel.com>2016-09-22 17:00:28 -0400
committerJani Nikula <jani.nikula@intel.com>2016-10-10 09:06:37 -0400
commit6e7fdb873d6255ca3c999dd5c6c18962a769ed3e (patch)
tree17cda8c375930a45fbafd1c7846100c9a1a7f233
parent674f823b455cdb94d5773406c1caac170f87e1c4 (diff)
drm/i915: introduce intel_has_sagv()
And use it to move knowledge about the SAGV-supporting platforms from the callers to the SAGV code. We'll add more platforms to intel_has_sagv(), so IMHO it makes more sense to move all this to a single function instead of patching all the callers every time we add SAGV support to a new platform. v2: Move I915_SAGV_NOT_CONTROLLED to the new function (Lyude). Cc: stable@vger.kernel.org Reviewed-by: Maarten Lankhorst <maarten.lankhorst@linux.intel.com> Signed-off-by: Paulo Zanoni <paulo.r.zanoni@intel.com> Link: http://patchwork.freedesktop.org/patch/msgid/1474578035-424-3-git-send-email-paulo.r.zanoni@intel.com (cherry picked from commit 56feca91973459d0b62cbb2610b62d341025ed89) Signed-off-by: Jani Nikula <jani.nikula@intel.com>
-rw-r--r--drivers/gpu/drm/i915/intel_display.c5
-rw-r--r--drivers/gpu/drm/i915/intel_pm.c22
2 files changed, 20 insertions, 7 deletions
diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c
index b74e1a890f86..335822e6ddb9 100644
--- a/drivers/gpu/drm/i915/intel_display.c
+++ b/drivers/gpu/drm/i915/intel_display.c
@@ -14367,7 +14367,7 @@ static void intel_atomic_commit_tail(struct drm_atomic_state *state)
14367 * SKL workaround: bspec recommends we disable the SAGV when we 14367 * SKL workaround: bspec recommends we disable the SAGV when we
14368 * have more then one pipe enabled 14368 * have more then one pipe enabled
14369 */ 14369 */
14370 if (IS_SKYLAKE(dev_priv) && !intel_can_enable_sagv(state)) 14370 if (!intel_can_enable_sagv(state))
14371 intel_disable_sagv(dev_priv); 14371 intel_disable_sagv(dev_priv);
14372 14372
14373 intel_modeset_verify_disabled(dev); 14373 intel_modeset_verify_disabled(dev);
@@ -14425,8 +14425,7 @@ static void intel_atomic_commit_tail(struct drm_atomic_state *state)
14425 intel_modeset_verify_crtc(crtc, old_crtc_state, crtc->state); 14425 intel_modeset_verify_crtc(crtc, old_crtc_state, crtc->state);
14426 } 14426 }
14427 14427
14428 if (IS_SKYLAKE(dev_priv) && intel_state->modeset && 14428 if (intel_state->modeset && intel_can_enable_sagv(state))
14429 intel_can_enable_sagv(state))
14430 intel_enable_sagv(dev_priv); 14429 intel_enable_sagv(dev_priv);
14431 14430
14432 drm_atomic_helper_commit_hw_done(state); 14431 drm_atomic_helper_commit_hw_done(state);
diff --git a/drivers/gpu/drm/i915/intel_pm.c b/drivers/gpu/drm/i915/intel_pm.c
index 431b2251dc21..1058729843fb 100644
--- a/drivers/gpu/drm/i915/intel_pm.c
+++ b/drivers/gpu/drm/i915/intel_pm.c
@@ -2877,6 +2877,13 @@ skl_wm_plane_id(const struct intel_plane *plane)
2877 } 2877 }
2878} 2878}
2879 2879
2880static bool
2881intel_has_sagv(struct drm_i915_private *dev_priv)
2882{
2883 return IS_SKYLAKE(dev_priv) &&
2884 dev_priv->sagv_status != I915_SAGV_NOT_CONTROLLED;
2885}
2886
2880/* 2887/*
2881 * SAGV dynamically adjusts the system agent voltage and clock frequencies 2888 * SAGV dynamically adjusts the system agent voltage and clock frequencies
2882 * depending on power and performance requirements. The display engine access 2889 * depending on power and performance requirements. The display engine access
@@ -2893,8 +2900,10 @@ intel_enable_sagv(struct drm_i915_private *dev_priv)
2893{ 2900{
2894 int ret; 2901 int ret;
2895 2902
2896 if (dev_priv->sagv_status == I915_SAGV_NOT_CONTROLLED || 2903 if (!intel_has_sagv(dev_priv))
2897 dev_priv->sagv_status == I915_SAGV_ENABLED) 2904 return 0;
2905
2906 if (dev_priv->sagv_status == I915_SAGV_ENABLED)
2898 return 0; 2907 return 0;
2899 2908
2900 DRM_DEBUG_KMS("Enabling the SAGV\n"); 2909 DRM_DEBUG_KMS("Enabling the SAGV\n");
@@ -2942,8 +2951,10 @@ intel_disable_sagv(struct drm_i915_private *dev_priv)
2942{ 2951{
2943 int ret, result; 2952 int ret, result;
2944 2953
2945 if (dev_priv->sagv_status == I915_SAGV_NOT_CONTROLLED || 2954 if (!intel_has_sagv(dev_priv))
2946 dev_priv->sagv_status == I915_SAGV_DISABLED) 2955 return 0;
2956
2957 if (dev_priv->sagv_status == I915_SAGV_DISABLED)
2947 return 0; 2958 return 0;
2948 2959
2949 DRM_DEBUG_KMS("Disabling the SAGV\n"); 2960 DRM_DEBUG_KMS("Disabling the SAGV\n");
@@ -2984,6 +2995,9 @@ bool intel_can_enable_sagv(struct drm_atomic_state *state)
2984 enum pipe pipe; 2995 enum pipe pipe;
2985 int level, plane; 2996 int level, plane;
2986 2997
2998 if (!intel_has_sagv(dev_priv))
2999 return false;
3000
2987 /* 3001 /*
2988 * SKL workaround: bspec recommends we disable the SAGV when we have 3002 * SKL workaround: bspec recommends we disable the SAGV when we have
2989 * more then one pipe enabled 3003 * more then one pipe enabled