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 | |
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>
-rw-r--r-- | drivers/media/video/ivtv/ivtv-driver.c | 2 | ||||
-rw-r--r-- | drivers/media/video/ivtv/ivtv-driver.h | 1 | ||||
-rw-r--r-- | drivers/media/video/ivtv/ivtv-yuv.c | 9 |
3 files changed, 7 insertions, 5 deletions
diff --git a/drivers/media/video/ivtv/ivtv-driver.c b/drivers/media/video/ivtv/ivtv-driver.c index 8b5597ff3cd7..45b9328a538f 100644 --- a/drivers/media/video/ivtv/ivtv-driver.c +++ b/drivers/media/video/ivtv/ivtv-driver.c | |||
@@ -116,7 +116,7 @@ static int dec_yuv_buffers = IVTV_DEFAULT_DEC_YUV_BUFFERS; | |||
116 | static int dec_vbi_buffers = IVTV_DEFAULT_DEC_VBI_BUFFERS; | 116 | static int dec_vbi_buffers = IVTV_DEFAULT_DEC_VBI_BUFFERS; |
117 | 117 | ||
118 | static int ivtv_yuv_mode = 0; | 118 | static int ivtv_yuv_mode = 0; |
119 | static int ivtv_yuv_threshold=480; | 119 | static int ivtv_yuv_threshold=-1; |
120 | static int ivtv_pci_latency = 1; | 120 | static int ivtv_pci_latency = 1; |
121 | 121 | ||
122 | int ivtv_debug = 0; | 122 | int ivtv_debug = 0; |
diff --git a/drivers/media/video/ivtv/ivtv-driver.h b/drivers/media/video/ivtv/ivtv-driver.h index ce28923a5c9c..9a412d6c6d06 100644 --- a/drivers/media/video/ivtv/ivtv-driver.h +++ b/drivers/media/video/ivtv/ivtv-driver.h | |||
@@ -606,7 +606,6 @@ struct yuv_playback_info | |||
606 | 606 | ||
607 | int lace_mode; | 607 | int lace_mode; |
608 | int lace_threshold; | 608 | int lace_threshold; |
609 | int lace_threshold_last; | ||
610 | int lace_sync_field; | 609 | int lace_sync_field; |
611 | 610 | ||
612 | atomic_t next_dma_frame; | 611 | atomic_t next_dma_frame; |
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) || |