diff options
author | Ian Armstrong <ian@iarmst.demon.co.uk> | 2007-03-16 06:44:42 -0400 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@infradead.org> | 2007-04-27 14:44:48 -0400 |
commit | 9e0df402e695e638dfee94a6e05fca48b15404e6 (patch) | |
tree | b4f91692f6c13fdf2b6a788cecc59aa05393730b /drivers/media/video/ivtv/ivtv-yuv.c | |
parent | 59fc7f52898fb35eb053bc7b54430d81629b5966 (diff) |
V4L/DVB (5438): Fix ivtv yuv threshold handling
Modifies automatic mode selection for yuv playback. Behaviour is now that
source video with a vertical resolution below that of the currently set
broadcast mode will be treated as progressive. Video with a vertical
resolution greater or equal to the current broadcast mode (up to 576 lines)
will be treated as interlaced.
Signed-off-by: Ian Armstrong <ian@iarmst.demon.co.uk>
Signed-off-by: Hans Verkuil <hverkuil@xs4all.nl>
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
Diffstat (limited to 'drivers/media/video/ivtv/ivtv-yuv.c')
-rw-r--r-- | drivers/media/video/ivtv/ivtv-yuv.c | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/drivers/media/video/ivtv/ivtv-yuv.c b/drivers/media/video/ivtv/ivtv-yuv.c index 286a0d7e7208..bcea09542e5a 100644 --- a/drivers/media/video/ivtv/ivtv-yuv.c +++ b/drivers/media/video/ivtv/ivtv-yuv.c | |||
@@ -613,16 +613,19 @@ static void ivtv_yuv_handle_vertical(struct ivtv *itv, struct yuv_frame_info *wi | |||
613 | } | 613 | } |
614 | 614 | ||
615 | itv->yuv_info.frame_interlaced_last = itv->yuv_info.frame_interlaced; | 615 | itv->yuv_info.frame_interlaced_last = itv->yuv_info.frame_interlaced; |
616 | itv->yuv_info.lace_threshold_last = itv->yuv_info.lace_threshold; | ||
617 | } | 616 | } |
618 | 617 | ||
619 | /* Modify the supplied coordinate information to fit the visible osd area */ | 618 | /* Modify the supplied coordinate information to fit the visible osd area */ |
620 | static u32 ivtv_yuv_window_setup (struct ivtv *itv, struct yuv_frame_info *window) | 619 | static u32 ivtv_yuv_window_setup (struct ivtv *itv, struct yuv_frame_info *window) |
621 | { | 620 | { |
622 | int osd_crop; | 621 | int osd_crop, lace_threshold; |
623 | u32 osd_scale; | 622 | u32 osd_scale; |
624 | u32 yuv_update = 0; | 623 | u32 yuv_update = 0; |
625 | 624 | ||
625 | lace_threshold = itv->yuv_info.lace_threshold; | ||
626 | if (lace_threshold < 0) | ||
627 | lace_threshold = itv->yuv_info.decode_height - 1; | ||
628 | |||
626 | /* Work out the lace settings */ | 629 | /* Work out the lace settings */ |
627 | switch (itv->yuv_info.lace_mode) { | 630 | switch (itv->yuv_info.lace_mode) { |
628 | case IVTV_YUV_MODE_PROGRESSIVE: /* Progressive mode */ | 631 | case IVTV_YUV_MODE_PROGRESSIVE: /* Progressive mode */ |
@@ -639,7 +642,7 @@ static u32 ivtv_yuv_window_setup (struct ivtv *itv, struct yuv_frame_info *windo | |||
639 | break; | 642 | break; |
640 | 643 | ||
641 | case IVTV_YUV_MODE_AUTO: | 644 | case IVTV_YUV_MODE_AUTO: |
642 | if (window->tru_h <= itv->yuv_info.lace_threshold || window->tru_h > 576 || window->tru_w > 720){ | 645 | if (window->tru_h <= lace_threshold || window->tru_h > 576 || window->tru_w > 720){ |
643 | itv->yuv_info.frame_interlaced = 0; | 646 | itv->yuv_info.frame_interlaced = 0; |
644 | if ((window->tru_h < 512) || | 647 | if ((window->tru_h < 512) || |
645 | (window->tru_h > 576 && window->tru_h < 1021) || | 648 | (window->tru_h > 576 && window->tru_h < 1021) || |