diff options
Diffstat (limited to 'drivers/media/video/ivtv/ivtv-streams.c')
-rw-r--r-- | drivers/media/video/ivtv/ivtv-streams.c | 19 |
1 files changed, 14 insertions, 5 deletions
diff --git a/drivers/media/video/ivtv/ivtv-streams.c b/drivers/media/video/ivtv/ivtv-streams.c index 3939a804f043..e05af62a8cd5 100644 --- a/drivers/media/video/ivtv/ivtv-streams.c +++ b/drivers/media/video/ivtv/ivtv-streams.c | |||
@@ -404,8 +404,8 @@ static void ivtv_vbi_setup(struct ivtv *itv) | |||
404 | if (!itv->vbi.fpi) | 404 | if (!itv->vbi.fpi) |
405 | itv->vbi.fpi = 1; | 405 | itv->vbi.fpi = 1; |
406 | 406 | ||
407 | IVTV_DEBUG_INFO("Setup VBI start 0x%08x frames %d fpi %d lines 0x%08x\n", | 407 | IVTV_DEBUG_INFO("Setup VBI start 0x%08x frames %d fpi %d\n", |
408 | itv->vbi.enc_start, data[1], itv->vbi.fpi, itv->digitizer); | 408 | itv->vbi.enc_start, data[1], itv->vbi.fpi); |
409 | 409 | ||
410 | /* select VBI lines. | 410 | /* select VBI lines. |
411 | Note that the sliced argument seems to have no effect. */ | 411 | Note that the sliced argument seems to have no effect. */ |
@@ -494,6 +494,8 @@ int ivtv_start_v4l2_encode_stream(struct ivtv_stream *s) | |||
494 | clear_bit(IVTV_F_S_STREAMOFF, &s->s_flags); | 494 | clear_bit(IVTV_F_S_STREAMOFF, &s->s_flags); |
495 | 495 | ||
496 | if (atomic_read(&itv->capturing) == 0) { | 496 | if (atomic_read(&itv->capturing) == 0) { |
497 | int digitizer; | ||
498 | |||
497 | /* Always use frame based mode. Experiments have demonstrated that byte | 499 | /* Always use frame based mode. Experiments have demonstrated that byte |
498 | stream based mode results in dropped frames and corruption. Not often, | 500 | stream based mode results in dropped frames and corruption. Not often, |
499 | but occasionally. Many thanks go to Leonard Orb who spent a lot of | 501 | but occasionally. Many thanks go to Leonard Orb who spent a lot of |
@@ -519,7 +521,14 @@ int ivtv_start_v4l2_encode_stream(struct ivtv_stream *s) | |||
519 | ivtv_vapi(itv, CX2341X_ENC_SET_PLACEHOLDER, 12, | 521 | ivtv_vapi(itv, CX2341X_ENC_SET_PLACEHOLDER, 12, |
520 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0); | 522 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0); |
521 | 523 | ||
522 | ivtv_vapi(itv, CX2341X_ENC_SET_NUM_VSYNC_LINES, 2, itv->digitizer, itv->digitizer); | 524 | if (itv->card->hw_all & (IVTV_HW_SAA7115 | IVTV_HW_SAA717X)) |
525 | digitizer = 0xF1; | ||
526 | else if (itv->card->hw_all & IVTV_HW_SAA7114) | ||
527 | digitizer = 0xEF; | ||
528 | else /* cx25840 */ | ||
529 | digitizer = 0x140; | ||
530 | |||
531 | ivtv_vapi(itv, CX2341X_ENC_SET_NUM_VSYNC_LINES, 2, digitizer, digitizer); | ||
523 | 532 | ||
524 | /* Setup VBI */ | 533 | /* Setup VBI */ |
525 | if (itv->v4l2_cap & V4L2_CAP_VBI_CAPTURE) { | 534 | if (itv->v4l2_cap & V4L2_CAP_VBI_CAPTURE) { |
@@ -761,7 +770,7 @@ int ivtv_stop_v4l2_encode_stream(struct ivtv_stream *s, int gop_end) | |||
761 | unsigned long duration; | 770 | unsigned long duration; |
762 | 771 | ||
763 | then = jiffies; | 772 | then = jiffies; |
764 | add_wait_queue(&itv->cap_w, &wait); | 773 | add_wait_queue(&itv->eos_waitq, &wait); |
765 | 774 | ||
766 | set_current_state(TASK_INTERRUPTIBLE); | 775 | set_current_state(TASK_INTERRUPTIBLE); |
767 | 776 | ||
@@ -787,7 +796,7 @@ int ivtv_stop_v4l2_encode_stream(struct ivtv_stream *s, int gop_end) | |||
787 | IVTV_DEBUG_INFO("%s: EOS took %lu ms to occur.\n", s->name, duration); | 796 | IVTV_DEBUG_INFO("%s: EOS took %lu ms to occur.\n", s->name, duration); |
788 | } | 797 | } |
789 | set_current_state(TASK_RUNNING); | 798 | set_current_state(TASK_RUNNING); |
790 | remove_wait_queue(&itv->cap_w, &wait); | 799 | remove_wait_queue(&itv->eos_waitq, &wait); |
791 | } | 800 | } |
792 | 801 | ||
793 | then = jiffies; | 802 | then = jiffies; |