return connection_mask & (-connection_mask);
}
}
+
+bool decklink_card_is_active(IDeckLink *card, unsigned card_index)
+{
+ IDeckLinkStatus *status;
+ if (card->QueryInterface(IID_IDeckLinkStatus, (void**)&status) != S_OK) {
+ fprintf(stderr, "Card %u has no status interface\n", card_index);
+ abort();
+ }
+
+ int64_t duplex_mode;
+ if (status->GetInt(bmdDeckLinkStatusDuplexMode, &duplex_mode) != S_OK) {
+ fprintf(stderr, "Could not query duplex mode for card %u\n", card_index);
+ abort();
+ }
+
+ status->Release();
+
+ return (duplex_mode != bmdDuplexStatusInactive);
+}
// Picks a video connection that the card supports. Priority list: HDMI, SDI, anything else.
BMDVideoConnection pick_default_video_connection(IDeckLink *card, BMDDeckLinkAttributeID attribute_id, unsigned card_index);
+bool decklink_card_is_active(IDeckLink *card, unsigned card_index);
+
#endif // !defined(_DECKLINK_UTIL)
#include "shared/context.h"
#include "decklink_capture.h"
#include "decklink_output.h"
+#include "decklink_util.h"
#include "defs.h"
#include "shared/disk_space_estimator.h"
#include "ffmpeg_capture.h"
break;
}
+ if (!decklink_card_is_active(decklink, card_index)) {
+ fprintf(stderr, "DeckLink card %u is inactive in current profile, skipping (try changing it in Desktop Video Setup)\n", card_index);
+ decklink->Release();
+ continue;
+ }
+
DeckLinkCapture *capture = new DeckLinkCapture(decklink, card_index);
DeckLinkOutput *output = new DeckLinkOutput(resource_pool.get(), decklink_output_surface, global_flags.width, global_flags.height, card_index);
if (!output->set_device(decklink)) {