+ });
+ }
+
+ void dma_present_thread_actual()
+ {
+ bvc_wrapper wait_b;
+ wait_b.attach(device_index_);
+ EBlueVideoChannel out_vid_channel = get_bluesdk_videochannel_from_streamid(device_output_channel_);
+ wait_b.set_card_property32(DEFAULT_VIDEO_OUTPUT_CHANNEL, out_vid_channel);
+ int frames_to_buffer = BLUEFISH_HW_BUFFER_DEPTH;
+ unsigned long buffer_id = 0;
+ unsigned long underrun = 0;
+
+ while (!end_dma_thread_)
+ {
+ if (!live_frames_.empty() && BLUE_OK(blue_->video_playback_allocate(buffer_id, underrun)))
+ {
+ blue_dma_buffer_ptr buf = nullptr;
+ live_frames_.pop(buf);
+
+ // Send and display
+ if (embedded_audio_)
+ {
+ // Do video first, then do hanc DMA...
+ blue_->system_buffer_write(const_cast<uint8_t*>(buf->image_data()),
+ static_cast<unsigned long>(buf->image_size()),
+ BlueImage_HANC_DMABuffer(buffer_id, BLUE_DATA_IMAGE),
+ 0);
+
+ blue_->system_buffer_write(buf->hanc_data(),
+ static_cast<unsigned long>(buf->hanc_size()),
+ BlueImage_HANC_DMABuffer(buffer_id, BLUE_DATA_HANC),
+ 0);
+
+ if (BLUE_FAIL(blue_->video_playback_present(BlueBuffer_Image_HANC(buffer_id), 1, 0, 0)))
+ {
+ CASPAR_LOG(warning) << print() << TEXT(" video_playback_present failed.");
+ }
+ }
+ else
+ {
+ blue_->system_buffer_write(const_cast<uint8_t*>(buf->image_data()),
+ static_cast<unsigned long>(buf->image_size()),
+ BlueImage_DMABuffer(buffer_id, BLUE_DATA_IMAGE),
+ 0);
+
+ if (BLUE_FAIL(blue_->video_playback_present(BlueBuffer_Image(buffer_id), 1, 0, 0)))
+ CASPAR_LOG(warning) << print() << TEXT(" video_playback_present failed.");
+ }
+
+ reserved_frames_.push(buf);
+ }
+ else
+ {
+ // do WFS
+ unsigned long n_field = 0;
+ wait_b.wait_video_output_sync(UPD_FMT_FRAME, n_field);
+ }
+
+ if (frames_to_buffer > 0)
+ {
+ frames_to_buffer--;
+ if (frames_to_buffer == 0)
+ {
+ if (BLUE_FAIL(blue_->video_playback_start(0, 0)))
+ CASPAR_LOG(warning) << print() << TEXT("Error video playback start failed");
+ }
+ }
+ }
+ wait_b.detach();