drm/omap: HDMI5: Add interlace support
authorTomi Valkeinen <tomi.valkeinen@ti.com>
Wed, 13 Jan 2016 16:41:39 +0000 (18:41 +0200)
committerTomi Valkeinen <tomi.valkeinen@ti.com>
Thu, 3 Mar 2016 15:36:43 +0000 (17:36 +0200)
Add the missing bits for interlace:

* Set VBLANK_OSC if the videomode's vblank is fractional
* Halve the vertical timings for interlace
* Double the horizontal timings for double-pixel mode
* Set FC_PRCONF properly for double-pixel mode

Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
Acked-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
drivers/gpu/drm/omapdrm/dss/hdmi5_core.c

index 947edb9d4275093ccb52891910c532fb3c0449f0..6a397520cae57f3f6fee331ba8a34e9988a2f196 100644 (file)
@@ -298,10 +298,30 @@ static void hdmi_core_init(struct hdmi_core_vid_config *video_cfg,
        video_cfg->data_enable_pol = 1; /* It is always 1*/
        video_cfg->hblank = cfg->timings.hfp +
                                cfg->timings.hbp + cfg->timings.hsw;
-       video_cfg->vblank_osc = 0; /* Always 0 - need to confirm */
+       video_cfg->vblank_osc = 0;
        video_cfg->vblank = cfg->timings.vsw +
                                cfg->timings.vfp + cfg->timings.vbp;
        video_cfg->v_fc_config.hdmi_dvi_mode = cfg->hdmi_dvi_mode;
+
+       if (cfg->timings.interlace) {
+               /* set vblank_osc if vblank is fractional */
+               if (video_cfg->vblank % 2 != 0)
+                       video_cfg->vblank_osc = 1;
+
+               video_cfg->v_fc_config.timings.y_res /= 2;
+               video_cfg->vblank /= 2;
+               video_cfg->v_fc_config.timings.vfp /= 2;
+               video_cfg->v_fc_config.timings.vsw /= 2;
+               video_cfg->v_fc_config.timings.vbp /= 2;
+       }
+
+       if (cfg->timings.double_pixel) {
+               video_cfg->v_fc_config.timings.x_res *= 2;
+               video_cfg->hblank *= 2;
+               video_cfg->v_fc_config.timings.hfp *= 2;
+               video_cfg->v_fc_config.timings.hsw *= 2;
+               video_cfg->v_fc_config.timings.hbp *= 2;
+       }
 }
 
 /* DSS_HDMI_CORE_VIDEO_CONFIG */
@@ -368,6 +388,11 @@ static void hdmi_core_video_config(struct hdmi_core_data *core,
        /* select DVI mode */
        REG_FLD_MOD(base, HDMI_CORE_FC_INVIDCONF,
                        cfg->v_fc_config.hdmi_dvi_mode, 3, 3);
+
+       if (cfg->v_fc_config.timings.double_pixel)
+               REG_FLD_MOD(base, HDMI_CORE_FC_PRCONF, 2, 7, 4);
+       else
+               REG_FLD_MOD(base, HDMI_CORE_FC_PRCONF, 1, 7, 4);
 }
 
 static void hdmi_core_config_video_packetizer(struct hdmi_core_data *core)