diff options
author | Archit Taneja <archit@ti.com> | 2012-06-28 08:53:18 -0400 |
---|---|---|
committer | Tomi Valkeinen <tomi.valkeinen@ti.com> | 2012-06-29 03:15:53 -0400 |
commit | 23bae3adbf90f8ad537687e1b46b7c87558936ae (patch) | |
tree | 37fac7f828ce3aa126a81cb07ad899785fb81c86 /drivers/video/omap2/omapfb | |
parent | 8050cbe4cd9a96ff333df718f38830eabab690bd (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.c | 8 |
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 | ||
2228 | static int omapfb_find_best_mode(struct omap_dss_device *display, | 2230 | static int omapfb_find_best_mode(struct omap_dss_device *display, |