aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/video/omap2/omapfb
diff options
context:
space:
mode:
authorArchit Taneja <archit@ti.com>2012-06-28 08:53:18 -0400
committerTomi Valkeinen <tomi.valkeinen@ti.com>2012-06-29 03:15:53 -0400
commit23bae3adbf90f8ad537687e1b46b7c87558936ae (patch)
tree37fac7f828ce3aa126a81cb07ad899785fb81c86 /drivers/video/omap2/omapfb
parent8050cbe4cd9a96ff333df718f38830eabab690bd (diff)
OMAPFB: Map interlace field in omap_video_timings with fb vmode flags
Use the interlace field in omap_video_timings to configure/retrieve corresponding fb mode flags in fb_var_screeninfo and fb_videomode. The interlace field maps with the fb mode flags FB_VMODE_INTERLACED and FB_VMODE_NONINTERLACED. Signed-off-by: Archit Taneja <archit@ti.com>
Diffstat (limited to 'drivers/video/omap2/omapfb')
-rw-r--r--drivers/video/omap2/omapfb/omapfb-main.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/drivers/video/omap2/omapfb/omapfb-main.c b/drivers/video/omap2/omapfb/omapfb-main.c
index 5491817ef979..08ec1a7103f2 100644
--- a/drivers/video/omap2/omapfb/omapfb-main.c
+++ b/drivers/video/omap2/omapfb/omapfb-main.c
@@ -737,6 +737,8 @@ int check_fb_var(struct fb_info *fbi, struct fb_var_screeninfo *var)
737 FB_SYNC_HOR_HIGH_ACT : 0; 737 FB_SYNC_HOR_HIGH_ACT : 0;
738 var->sync |= timings.vsync_level == OMAPDSS_SIG_ACTIVE_HIGH ? 738 var->sync |= timings.vsync_level == OMAPDSS_SIG_ACTIVE_HIGH ?
739 FB_SYNC_VERT_HIGH_ACT : 0; 739 FB_SYNC_VERT_HIGH_ACT : 0;
740 var->vmode = timings.interlace ?
741 FB_VMODE_INTERLACED : FB_VMODE_NONINTERLACED;
740 } else { 742 } else {
741 var->pixclock = 0; 743 var->pixclock = 0;
742 var->left_margin = 0; 744 var->left_margin = 0;
@@ -746,11 +748,9 @@ int check_fb_var(struct fb_info *fbi, struct fb_var_screeninfo *var)
746 var->hsync_len = 0; 748 var->hsync_len = 0;
747 var->vsync_len = 0; 749 var->vsync_len = 0;
748 var->sync = 0; 750 var->sync = 0;
751 var->vmode = FB_VMODE_NONINTERLACED;
749 } 752 }
750 753
751 /* TODO: get these from panel->config */
752 var->vmode = FB_VMODE_NONINTERLACED;
753
754 return 0; 754 return 0;
755} 755}
756 756
@@ -2074,6 +2074,7 @@ static int omapfb_mode_to_timings(const char *mode_str,
2074 timings->vsync_level = var->sync & FB_SYNC_VERT_HIGH_ACT ? 2074 timings->vsync_level = var->sync & FB_SYNC_VERT_HIGH_ACT ?
2075 OMAPDSS_SIG_ACTIVE_HIGH : 2075 OMAPDSS_SIG_ACTIVE_HIGH :
2076 OMAPDSS_SIG_ACTIVE_LOW; 2076 OMAPDSS_SIG_ACTIVE_LOW;
2077 timings->interlace = var->vmode & FB_VMODE_INTERLACED;
2077 2078
2078 switch (var->bits_per_pixel) { 2079 switch (var->bits_per_pixel) {
2079 case 16: 2080 case 16:
@@ -2223,6 +2224,7 @@ static void fb_videomode_to_omap_timings(struct fb_videomode *m,
2223 t->vsync_level = m->sync & FB_SYNC_VERT_HIGH_ACT ? 2224 t->vsync_level = m->sync & FB_SYNC_VERT_HIGH_ACT ?
2224 OMAPDSS_SIG_ACTIVE_HIGH : 2225 OMAPDSS_SIG_ACTIVE_HIGH :
2225 OMAPDSS_SIG_ACTIVE_LOW; 2226 OMAPDSS_SIG_ACTIVE_LOW;
2227 t->interlace = m->vmode & FB_VMODE_INTERLACED;
2226} 2228}
2227 2229
2228static int omapfb_find_best_mode(struct omap_dss_device *display, 2230static int omapfb_find_best_mode(struct omap_dss_device *display,