Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 329325
b: refs/heads/master
c: 6306cb4
h: refs/heads/master
i:
  329323: 547c121
v: v3
  • Loading branch information
Daniel Vetter committed Aug 17, 2012
1 parent 21c31da commit aad2a28
Show file tree
Hide file tree
Showing 2 changed files with 2 additions and 58 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: a37b9b349ef26cb44f0e8d59c3efbcd9485018b4
refs/heads/master: 6306cb4f809ccf92c1b7bf446635c571e33f5151
58 changes: 1 addition & 57 deletions trunk/drivers/gpu/drm/i915/intel_overlay.c
Original file line number Diff line number Diff line change
Expand Up @@ -235,72 +235,19 @@ static int intel_overlay_do_wait_request(struct intel_overlay *overlay,
return 0;
}

/* Workaround for i830 bug where pipe a must be enable to change control regs */
static int
i830_activate_pipe_a(struct drm_device *dev)
{
drm_i915_private_t *dev_priv = dev->dev_private;
struct intel_crtc *crtc;
struct drm_crtc_helper_funcs *crtc_funcs;
struct drm_display_mode vesa_640x480 = {
DRM_MODE("640x480", DRM_MODE_TYPE_DRIVER, 25175, 640, 656,
752, 800, 0, 480, 489, 492, 525, 0,
DRM_MODE_FLAG_NHSYNC | DRM_MODE_FLAG_NVSYNC)
}, *mode;

crtc = to_intel_crtc(dev_priv->pipe_to_crtc_mapping[0]);
if (crtc->dpms_mode == DRM_MODE_DPMS_ON)
return 0;

/* most i8xx have pipe a forced on, so don't trust dpms mode */
if (I915_READ(_PIPEACONF) & PIPECONF_ENABLE)
return 0;

crtc_funcs = crtc->base.helper_private;
if (crtc_funcs->dpms == NULL)
return 0;

DRM_DEBUG_DRIVER("Enabling pipe A in order to enable overlay\n");

mode = drm_mode_duplicate(dev, &vesa_640x480);

if (!drm_crtc_helper_set_mode(&crtc->base, mode,
crtc->base.x, crtc->base.y,
crtc->base.fb))
return 0;

crtc_funcs->dpms(&crtc->base, DRM_MODE_DPMS_ON);
return 1;
}

static void
i830_deactivate_pipe_a(struct drm_device *dev)
{
drm_i915_private_t *dev_priv = dev->dev_private;
struct drm_crtc *crtc = dev_priv->pipe_to_crtc_mapping[0];
struct drm_crtc_helper_funcs *crtc_funcs = crtc->helper_private;

crtc_funcs->dpms(crtc, DRM_MODE_DPMS_OFF);
}

/* overlay needs to be disable in OCMD reg */
static int intel_overlay_on(struct intel_overlay *overlay)
{
struct drm_device *dev = overlay->dev;
struct drm_i915_private *dev_priv = dev->dev_private;
struct intel_ring_buffer *ring = &dev_priv->ring[RCS];
struct drm_i915_gem_request *request;
int pipe_a_quirk = 0;
int ret;

BUG_ON(overlay->active);
overlay->active = 1;

if (IS_I830(dev)) {
pipe_a_quirk = i830_activate_pipe_a(dev);
if (pipe_a_quirk < 0)
return pipe_a_quirk;
}
WARN_ON(IS_I830(dev) && !(dev_priv->quirks & QUIRK_PIPEA_FORCE));

request = kzalloc(sizeof(*request), GFP_KERNEL);
if (request == NULL) {
Expand All @@ -322,9 +269,6 @@ static int intel_overlay_on(struct intel_overlay *overlay)

ret = intel_overlay_do_wait_request(overlay, request, NULL);
out:
if (pipe_a_quirk)
i830_deactivate_pipe_a(dev);

return ret;
}

Expand Down

0 comments on commit aad2a28

Please sign in to comment.