diff options
author | Paulo Zanoni <paulo.r.zanoni@intel.com> | 2016-09-22 17:00:28 -0400 |
---|---|---|
committer | Jani Nikula <jani.nikula@intel.com> | 2016-10-10 09:06:37 -0400 |
commit | 6e7fdb873d6255ca3c999dd5c6c18962a769ed3e (patch) | |
tree | 17cda8c375930a45fbafd1c7846100c9a1a7f233 | |
parent | 674f823b455cdb94d5773406c1caac170f87e1c4 (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.c | 5 | ||||
-rw-r--r-- | drivers/gpu/drm/i915/intel_pm.c | 22 |
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 | ||
2880 | static bool | ||
2881 | intel_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 |