X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=nageru%2Fdecklink_capture.cpp;h=e239ec964f6f70d17fc13c24494ead77e7d726b4;hb=HEAD;hp=9bf1a0e1a8f66b1889b279c0c075093ad364a065;hpb=491a3e4a19271fba3547eead3e062c2a35371a26;p=nageru diff --git a/nageru/decklink_capture.cpp b/nageru/decklink_capture.cpp index 9bf1a0e..90d86b1 100644 --- a/nageru/decklink_capture.cpp +++ b/nageru/decklink_capture.cpp @@ -1,10 +1,16 @@ #include "decklink_capture.h" +#include "defs.h" #include #include #include #include +#include +#include #include +#include +#include +#include #ifdef __SSE2__ #include #endif @@ -250,7 +256,14 @@ HRESULT STDMETHODCALLTYPE DeckLinkCapture::VideoInputFrameArrived( assert(stride == width * 2); } - current_video_frame = video_frame_allocator->create_frame(width, height, stride); + if (width * stride > FRAME_SIZE) { + // TODO: If we had an OpenGL context here, calling create_frame() + // would be completely fine. + fprintf(stderr, "Card %u: Captured frame %d x %d (stride %d) would be larger than supported frame size (%d > %d), skipping.\n", + card_index, width, height, stride, width * stride, FRAME_SIZE); + } else { + current_video_frame = video_frame_allocator->create_frame(width, height, stride); + } if (current_video_frame.data != nullptr) { const uint8_t *src; video_frame->GetBytes((void **)&src);