diff options
author | Jani Nikula <jani.nikula@intel.com> | 2013-09-13 04:03:08 -0400 |
---|---|---|
committer | Daniel Vetter <daniel.vetter@ffwll.ch> | 2013-09-13 08:58:09 -0400 |
commit | 93ce0ba6985245ba806f0846a9ce42ca7a3184f2 (patch) | |
tree | ba419202f9996cfa04ea25e4960e907fc18284bd | |
parent | 33618ea5e0e2ccd00331fa169145894b9c5dcffe (diff) |
drm/i915: add asserts for cursor disabled
The cursor is supposed to be disabled during crtc mode set (disabled by
ctrc disable). Assert this is the case.
v2: move cursor disabled assert next to plane asserts (Ville)
Suggested-by: Chris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
-rw-r--r-- | drivers/gpu/drm/i915/intel_display.c | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c index b8d409f5ead3..2e74ccce447d 100644 --- a/drivers/gpu/drm/i915/intel_display.c +++ b/drivers/gpu/drm/i915/intel_display.c | |||
@@ -1069,6 +1069,26 @@ static void assert_panel_unlocked(struct drm_i915_private *dev_priv, | |||
1069 | pipe_name(pipe)); | 1069 | pipe_name(pipe)); |
1070 | } | 1070 | } |
1071 | 1071 | ||
1072 | static void assert_cursor(struct drm_i915_private *dev_priv, | ||
1073 | enum pipe pipe, bool state) | ||
1074 | { | ||
1075 | struct drm_device *dev = dev_priv->dev; | ||
1076 | bool cur_state; | ||
1077 | |||
1078 | if (IS_IVYBRIDGE(dev) || IS_HASWELL(dev)) | ||
1079 | cur_state = I915_READ(CURCNTR_IVB(pipe)) & CURSOR_MODE; | ||
1080 | else if (IS_845G(dev) || IS_I865G(dev)) | ||
1081 | cur_state = I915_READ(_CURACNTR) & CURSOR_ENABLE; | ||
1082 | else | ||
1083 | cur_state = I915_READ(CURCNTR(pipe)) & CURSOR_MODE; | ||
1084 | |||
1085 | WARN(cur_state != state, | ||
1086 | "cursor on pipe %c assertion failure (expected %s, current %s)\n", | ||
1087 | pipe_name(pipe), state_string(state), state_string(cur_state)); | ||
1088 | } | ||
1089 | #define assert_cursor_enabled(d, p) assert_cursor(d, p, true) | ||
1090 | #define assert_cursor_disabled(d, p) assert_cursor(d, p, false) | ||
1091 | |||
1072 | void assert_pipe(struct drm_i915_private *dev_priv, | 1092 | void assert_pipe(struct drm_i915_private *dev_priv, |
1073 | enum pipe pipe, bool state) | 1093 | enum pipe pipe, bool state) |
1074 | { | 1094 | { |
@@ -1670,6 +1690,7 @@ static void intel_enable_pipe(struct drm_i915_private *dev_priv, enum pipe pipe, | |||
1670 | u32 val; | 1690 | u32 val; |
1671 | 1691 | ||
1672 | assert_planes_disabled(dev_priv, pipe); | 1692 | assert_planes_disabled(dev_priv, pipe); |
1693 | assert_cursor_disabled(dev_priv, pipe); | ||
1673 | assert_sprites_disabled(dev_priv, pipe); | 1694 | assert_sprites_disabled(dev_priv, pipe); |
1674 | 1695 | ||
1675 | if (HAS_PCH_LPT(dev_priv->dev)) | 1696 | if (HAS_PCH_LPT(dev_priv->dev)) |
@@ -1731,6 +1752,7 @@ static void intel_disable_pipe(struct drm_i915_private *dev_priv, | |||
1731 | * or we might hang the display. | 1752 | * or we might hang the display. |
1732 | */ | 1753 | */ |
1733 | assert_planes_disabled(dev_priv, pipe); | 1754 | assert_planes_disabled(dev_priv, pipe); |
1755 | assert_cursor_disabled(dev_priv, pipe); | ||
1734 | assert_sprites_disabled(dev_priv, pipe); | 1756 | assert_sprites_disabled(dev_priv, pipe); |
1735 | 1757 | ||
1736 | /* Don't disable pipe A or pipe A PLLs if needed */ | 1758 | /* Don't disable pipe A or pipe A PLLs if needed */ |
@@ -3867,6 +3889,7 @@ static void intel_crtc_disable(struct drm_crtc *crtc) | |||
3867 | dev_priv->display.off(crtc); | 3889 | dev_priv->display.off(crtc); |
3868 | 3890 | ||
3869 | assert_plane_disabled(dev->dev_private, to_intel_crtc(crtc)->plane); | 3891 | assert_plane_disabled(dev->dev_private, to_intel_crtc(crtc)->plane); |
3892 | assert_cursor_disabled(dev_priv, to_intel_crtc(crtc)->pipe); | ||
3870 | assert_pipe_disabled(dev->dev_private, to_intel_crtc(crtc)->pipe); | 3893 | assert_pipe_disabled(dev->dev_private, to_intel_crtc(crtc)->pipe); |
3871 | 3894 | ||
3872 | if (crtc->fb) { | 3895 | if (crtc->fb) { |