diff options
author | Zhenyu Wang <zhenyu.z.wang@intel.com> | 2009-03-23 12:45:13 -0400 |
---|---|---|
committer | Eric Anholt <eric@anholt.net> | 2009-04-01 18:22:00 -0400 |
commit | 7d6ff7851c23740c3813bdf457be638381774b69 (patch) | |
tree | dfdd8e79481d34a25b32715fc46cb00d9d5a8b99 /drivers | |
parent | ebcc8f2eade76946dbb5d5c545b91f8157051aa8 (diff) |
drm/i915: fix TV mode setting in property change
Only set TV DAC in property change seems doesn't work, we have to
setup whole crtc pipe which assigned to TV alone.
Signed-off-by: Zhenyu Wang <zhenyu.z.wang@intel.com>
[anholt: Note that this should also fix the oops at startup with new 2D]
Signed-off-by: Eric Anholt <eric@anholt.net>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/gpu/drm/i915/intel_tv.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/drivers/gpu/drm/i915/intel_tv.c b/drivers/gpu/drm/i915/intel_tv.c index 5d9ca779ce25..d2c32983242d 100644 --- a/drivers/gpu/drm/i915/intel_tv.c +++ b/drivers/gpu/drm/i915/intel_tv.c | |||
@@ -1570,6 +1570,8 @@ intel_tv_set_property(struct drm_connector *connector, struct drm_property *prop | |||
1570 | struct drm_device *dev = connector->dev; | 1570 | struct drm_device *dev = connector->dev; |
1571 | struct intel_output *intel_output = to_intel_output(connector); | 1571 | struct intel_output *intel_output = to_intel_output(connector); |
1572 | struct intel_tv_priv *tv_priv = intel_output->dev_priv; | 1572 | struct intel_tv_priv *tv_priv = intel_output->dev_priv; |
1573 | struct drm_encoder *encoder = &intel_output->enc; | ||
1574 | struct drm_crtc *crtc = encoder->crtc; | ||
1573 | int ret = 0; | 1575 | int ret = 0; |
1574 | bool changed = false; | 1576 | bool changed = false; |
1575 | 1577 | ||
@@ -1608,8 +1610,9 @@ intel_tv_set_property(struct drm_connector *connector, struct drm_property *prop | |||
1608 | goto out; | 1610 | goto out; |
1609 | } | 1611 | } |
1610 | 1612 | ||
1611 | if (changed) | 1613 | if (changed && crtc) |
1612 | intel_tv_mode_set(&intel_output->enc, NULL, NULL); | 1614 | drm_crtc_helper_set_mode(crtc, &crtc->mode, crtc->x, |
1615 | crtc->y, crtc->fb); | ||
1613 | out: | 1616 | out: |
1614 | return ret; | 1617 | return ret; |
1615 | } | 1618 | } |