forked from Minki/linux
drm/i915: Program VSYNCSHIFT in a more consistent manner
When interlaced sdvo output is used, vsyncshift should supposedly be (htotal-1)/2. In reality PIPECONF/TRANSCONF will override it by using the legacy vsyncshift interlace mode which causes the hardware to ignore the VSYNCSHIFT register. The only odd thing here is that on PCH platforms we program the VSYNCSHIFT on both CPU and PCH, and it's not entirely clear if both sides have to agree on the value or not. On the CPU side there's no way to override the value via PIPECONF anymore, so if we want to make the CPU side agree with the PCH side, we should probably program the approriate value into VSYNCSHIFT manually. So let's do that, but for now leave the PCH side to still use the legacy interlace mode in TRANSCONF. We can also drop the gen2 check since gen2 doesn't support interlaced modes at all. Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com> Reviewed-by: Jesse Barnes <jbarnes@virtuousgeek.org> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
This commit is contained in:
parent
92b576e6e9
commit
609aeacaac
@ -5369,21 +5369,23 @@ static void intel_set_pipe_timings(struct intel_crtc *intel_crtc)
|
||||
enum transcoder cpu_transcoder = intel_crtc->config.cpu_transcoder;
|
||||
struct drm_display_mode *adjusted_mode =
|
||||
&intel_crtc->config.adjusted_mode;
|
||||
uint32_t vsyncshift, crtc_vtotal, crtc_vblank_end;
|
||||
uint32_t vsyncshift = 0, crtc_vtotal, crtc_vblank_end;
|
||||
|
||||
/* We need to be careful not to changed the adjusted mode, for otherwise
|
||||
* the hw state checker will get angry at the mismatch. */
|
||||
crtc_vtotal = adjusted_mode->crtc_vtotal;
|
||||
crtc_vblank_end = adjusted_mode->crtc_vblank_end;
|
||||
|
||||
if (!IS_GEN2(dev) && adjusted_mode->flags & DRM_MODE_FLAG_INTERLACE) {
|
||||
if (adjusted_mode->flags & DRM_MODE_FLAG_INTERLACE) {
|
||||
/* the chip adds 2 halflines automatically */
|
||||
crtc_vtotal -= 1;
|
||||
crtc_vblank_end -= 1;
|
||||
vsyncshift = adjusted_mode->crtc_hsync_start
|
||||
- adjusted_mode->crtc_htotal / 2;
|
||||
} else {
|
||||
vsyncshift = 0;
|
||||
|
||||
if (intel_pipe_has_type(&intel_crtc->base, INTEL_OUTPUT_SDVO))
|
||||
vsyncshift = (adjusted_mode->crtc_htotal - 1) / 2;
|
||||
else
|
||||
vsyncshift = adjusted_mode->crtc_hsync_start -
|
||||
adjusted_mode->crtc_htotal / 2;
|
||||
}
|
||||
|
||||
if (INTEL_INFO(dev)->gen > 3)
|
||||
|
Loading…
Reference in New Issue
Block a user