From be6eba3e9e792dd5c64d3ffdbf444ebef70ac87a Mon Sep 17 00:00:00 2001 From: Sebastian Dröge Date: Tue, 24 Sep 2024 17:32:54 +0300 Subject: ntv2: Update to AJA NTV2 SDK 17.1.0 Part-of: --- .../sys/aja/gstajadeviceprovider.cpp | 104 ++++++++++++--------- subprojects/ntv2.wrap | 8 +- subprojects/packagefiles/ntv2/meson.build | 12 ++- 3 files changed, 69 insertions(+), 55 deletions(-) diff --git a/subprojects/gst-plugins-bad/sys/aja/gstajadeviceprovider.cpp b/subprojects/gst-plugins-bad/sys/aja/gstajadeviceprovider.cpp index 361aac8cfe..ee95eebdef 100644 --- a/subprojects/gst-plugins-bad/sys/aja/gstajadeviceprovider.cpp +++ b/subprojects/gst-plugins-bad/sys/aja/gstajadeviceprovider.cpp @@ -25,7 +25,8 @@ #include "gstajacommon.h" #include "gstajadeviceprovider.h" -static GstDevice *gst_aja_device_new(NTV2DeviceInfo &device, gboolean video); +static GstDevice *gst_aja_device_new(CNTV2Device &device, guint index, + gboolean video); G_DEFINE_TYPE(GstAjaDeviceProvider, gst_aja_device_provider, GST_TYPE_DEVICE_PROVIDER); @@ -35,18 +36,19 @@ static void gst_aja_device_provider_init(GstAjaDeviceProvider *self) {} static GList *gst_aja_device_provider_probe(GstDeviceProvider *provider) { GList *ret = NULL; - CNTV2DeviceScanner scanner; + CNTV2Card device; + guint device_idx = 0; - NTV2DeviceInfoList devices = scanner.GetDeviceInfoList(); - for (NTV2DeviceInfoList::iterator it = devices.begin(); it != devices.end(); - it++) { + while (CNTV2DeviceScanner::GetDeviceAtIndex(device_idx, device)) { + auto features = device.features(); // Skip non-input / non-output devices - if (it->numVidInputs == 0 && it->numVidOutputs == 0) continue; + if (features.GetNumVideoInputs() == 0 && features.GetNumVideoOutputs() == 0) + continue; - if (it->numVidInputs > 0) - ret = g_list_prepend(ret, gst_aja_device_new(*it, TRUE)); - if (it->numVidOutputs > 0) - ret = g_list_prepend(ret, gst_aja_device_new(*it, FALSE)); + if (features.GetNumVideoInputs() > 0) + ret = g_list_prepend(ret, gst_aja_device_new(device, device_idx, TRUE)); + if (features.GetNumVideoOutputs() > 0) + ret = g_list_prepend(ret, gst_aja_device_new(device, device_idx, FALSE)); } ret = g_list_reverse(ret); @@ -98,7 +100,7 @@ static void gst_aja_device_class_init(GstAjaDeviceClass *klass) { GST_DEBUG_FUNCPTR(gst_aja_device_create_element); } -static GstDevice *gst_aja_device_new(NTV2DeviceInfo &device, +static GstDevice *gst_aja_device_new(CNTV2Card &device, guint index, gboolean is_capture) { GstDevice *ret; gchar *display_name; @@ -107,52 +109,62 @@ static GstDevice *gst_aja_device_new(NTV2DeviceInfo &device, GstStructure *properties; device_class = is_capture ? "Audio/Video/Source" : "Audio/Video/Sink"; - display_name = g_strdup_printf("AJA %s (%s)", device.deviceIdentifier.c_str(), + display_name = g_strdup_printf("AJA %s (%s)", device.GetDisplayName().c_str(), is_capture ? "Source" : "Sink"); - caps = gst_ntv2_supported_caps(device.deviceID); + caps = gst_ntv2_supported_caps(device.GetDeviceID()); properties = gst_structure_new_empty("properties"); + auto features = device.features(); + auto widget_ids = device.GetSupportedItems(kNTV2EnumsID_WidgetID); gst_structure_set( - properties, "device-id", G_TYPE_UINT, device.deviceID, "device-index", - G_TYPE_UINT, device.deviceIndex, "pci-slot", G_TYPE_UINT, device.pciSlot, - "serial-number", G_TYPE_UINT64, device.deviceSerialNumber, - "device-identifier", G_TYPE_STRING, device.deviceIdentifier.c_str(), - "num-audio-streams", G_TYPE_UINT, device.numAudioStreams, - "dual-link-support", G_TYPE_BOOLEAN, device.dualLinkSupport, - "sdi-3g-support", G_TYPE_BOOLEAN, device.sdi3GSupport, "sdi-12g-support", - G_TYPE_BOOLEAN, device.sdi12GSupport, "ip-support", G_TYPE_BOOLEAN, - device.ipSupport, "bi-directional-sdi", G_TYPE_BOOLEAN, - device.biDirectionalSDI, "ltc-in-support", G_TYPE_BOOLEAN, - device.ltcInSupport, "ltc-in-on-ref-port", G_TYPE_BOOLEAN, - device.ltcInOnRefPort, "2k-support", G_TYPE_BOOLEAN, device.has2KSupport, - "4k-support", G_TYPE_BOOLEAN, device.has4KSupport, "8k-support", - G_TYPE_BOOLEAN, device.has8KSupport, "multiformat-support", - G_TYPE_BOOLEAN, device.multiFormat, NULL); + properties, "device-id", G_TYPE_UINT, device.GetDeviceID(), + "device-index", G_TYPE_UINT, index, "serial-number", G_TYPE_UINT64, + device.GetSerialNumber(), "device-identifier", G_TYPE_STRING, + device.GetDisplayName().c_str(), "num-audio-streams", G_TYPE_UINT, + features.GetNumAudioSystems(), "dual-link-support", G_TYPE_BOOLEAN, + features.CanDoDualLink(), "sdi-3g-support", G_TYPE_BOOLEAN, + widget_ids.find(NTV2_Wgt3GSDIOut1) != widget_ids.end(), "sdi-12g-support", + G_TYPE_BOOLEAN, device.IsSupported(kDeviceCanDo12GSDI), "ip-support", + G_TYPE_BOOLEAN, device.IsSupported(kDeviceCanDoIP), "bi-directional-sdi", + G_TYPE_BOOLEAN, device.IsSupported(kDeviceHasBiDirectionalSDI), + "ltc-in-support", G_TYPE_BOOLEAN, + device.GetNumSupported(kDeviceGetNumLTCInputs) > 0, "ltc-in-on-ref-port", + G_TYPE_BOOLEAN, device.IsSupported(kDeviceCanDoLTCInOnRefPort), + "2k-support", G_TYPE_BOOLEAN, device.IsSupported(kDeviceCanDo2KVideo), + "4k-support", G_TYPE_BOOLEAN, device.IsSupported(kDeviceCanDo4KVideo), + "8k-support", G_TYPE_BOOLEAN, device.IsSupported(kDeviceCanDo8KVideo), + "multiformat-support", G_TYPE_BOOLEAN, + device.IsSupported(kDeviceCanDoMultiFormat), NULL); if (is_capture) { gst_structure_set( - properties, "num-vid-inputs", G_TYPE_UINT, device.numVidInputs, - "num-anlg-vid-inputs", G_TYPE_UINT, device.numAnlgVidInputs, - "num-hdmi-vid-inputs", G_TYPE_UINT, device.numHDMIVidInputs, + properties, "num-vid-inputs", G_TYPE_UINT, features.GetNumVideoInputs(), + "num-anlg-vid-inputs", G_TYPE_UINT, features.GetNumAnalogVideoInputs(), + "num-hdmi-vid-inputs", G_TYPE_UINT, features.GetNumHDMIVideoInputs(), "num-analog-audio-input-channels", G_TYPE_UINT, - device.numAnalogAudioInputChannels, "num-aes-audio-input-channels", - G_TYPE_UINT, device.numAESAudioInputChannels, + features.GetNumAnalogAudioInputChannels(), + "num-aes-audio-input-channels", G_TYPE_UINT, + features.GetNumAESAudioInputChannels(), "num-embedded-audio-input-channels", G_TYPE_UINT, - device.numEmbeddedAudioInputChannels, "num-hdmi-audio-input-channels", - G_TYPE_UINT, device.numHDMIAudioInputChannels, NULL); + features.GetNumEmbeddedAudioInputChannels(), + "num-hdmi-audio-input-channels", G_TYPE_UINT, + features.GetNumHDMIAudioInputChannels(), NULL); } else { - gst_structure_set( - properties, "num-vid-outputs", G_TYPE_UINT, device.numVidOutputs, - "num-anlg-vid-outputs", G_TYPE_UINT, device.numAnlgVidOutputs, - "num-hdmi-vid-outputs", G_TYPE_UINT, device.numHDMIVidOutputs, - "num-analog-audio-output-channels", G_TYPE_UINT, - device.numAnalogAudioOutputChannels, "num-aes-audio-output-channels", - G_TYPE_UINT, device.numAESAudioOutputChannels, - "num-embedded-audio-output-channels", G_TYPE_UINT, - device.numEmbeddedAudioOutputChannels, "num-hdmi-audio-output-channels", - G_TYPE_UINT, device.numHDMIAudioOutputChannels, NULL); + gst_structure_set(properties, "num-vid-outputs", G_TYPE_UINT, + features.GetNumVideoOutputs(), "num-anlg-vid-outputs", + G_TYPE_UINT, features.GetNumAnalogVideoOutputs(), + "num-hdmi-vid-outputs", G_TYPE_UINT, + features.GetNumHDMIVideoOutputs(), + "num-analog-audio-output-channels", G_TYPE_UINT, + features.GetNumAnalogAudioOutputChannels(), + "num-aes-audio-output-channels", G_TYPE_UINT, + features.GetNumAESAudioOutputChannels(), + "num-embedded-audio-output-channels", G_TYPE_UINT, + features.GetNumEmbeddedAudioOutputChannels(), + "num-hdmi-audio-output-channels", G_TYPE_UINT, + features.GetNumHDMIAudioOutputChannels(), NULL); } ret = GST_DEVICE(g_object_new(GST_TYPE_AJA_DEVICE, "display-name", @@ -164,7 +176,7 @@ static GstDevice *gst_aja_device_new(NTV2DeviceInfo &device, gst_structure_free(properties); GST_AJA_DEVICE(ret)->is_capture = is_capture; - GST_AJA_DEVICE(ret)->device_index = device.deviceIndex; + GST_AJA_DEVICE(ret)->device_index = index; return ret; } diff --git a/subprojects/ntv2.wrap b/subprojects/ntv2.wrap index 74d927f4c0..296300d1d3 100644 --- a/subprojects/ntv2.wrap +++ b/subprojects/ntv2.wrap @@ -1,8 +1,8 @@ [wrap-file] -directory = libajantv2-ntv2_17_0_1 -source_url = https://github.com/aja-video/libajantv2/archive/refs/tags/ntv2_17_0_1.tar.gz -source_filename = libajantv2-ntv2_17_0_1.tar.gz -source_hash = a4be947e4e34dd8065b25082a681994067877966c2aaef8fbc9a25681f03ebe7 +directory = libajantv2-ntv2_17_1_0 +source_url = https://github.com/aja-video/libajantv2/archive/refs/tags/ntv2_17_1_0.tar.gz +source_filename = libajantv2-ntv2_17_1_0.tar.gz +source_hash = b19bd5d2eb2cb20552d084cd709549517875922c4a6960e077ce96bf2922b7dd patch_directory = ntv2 [provide] diff --git a/subprojects/packagefiles/ntv2/meson.build b/subprojects/packagefiles/ntv2/meson.build index 92f05abf37..816773538e 100644 --- a/subprojects/packagefiles/ntv2/meson.build +++ b/subprojects/packagefiles/ntv2/meson.build @@ -1,5 +1,5 @@ project('ajantv2', ['c', 'cpp'], - version : '17.0.1', + version : '17.1.0', meson_version : '>= 0.54.0', default_options : [ 'warning_level=1', 'buildtype=debugoptimized', @@ -30,10 +30,10 @@ endif conf_data = configuration_data() conf_data.set('AJA_NTV2_SDK_VERSION_MAJOR', '17') -conf_data.set('AJA_NTV2_SDK_VERSION_MINOR', '0') -conf_data.set('AJA_NTV2_SDK_VERSION_POINT', '1') +conf_data.set('AJA_NTV2_SDK_VERSION_MINOR', '1') +conf_data.set('AJA_NTV2_SDK_VERSION_POINT', '0') conf_data.set('AJA_NTV2_SDK_BUILD_NUMBER', '0') -conf_data.set('AJA_NTV2_SDK_BUILD_DATETIME', '2024-02-15T17:41:48-08:00') +conf_data.set('AJA_NTV2_SDK_BUILD_DATETIME', '2024-07-18T13:40:28-07:00') conf_data.set('AJA_NTV2_SDK_BUILD_TYPE', '') configure_file(input : 'ajantv2/includes/ntv2version.h.in', output : 'ntv2version.h', @@ -58,6 +58,7 @@ ajantv2_sources = [ 'ajaanc/src/ancillarydata_timecode.cpp', 'ajaanc/src/ancillarydata_timecode_atc.cpp', 'ajaanc/src/ancillarydata_timecode_vitc.cpp', + 'ajaanc/src/ancillarydata_hdmi_aux.cpp', 'ajaanc/src/ancillarylist.cpp', 'ajabase/common/audioutilities.cpp', 'ajabase/common/buffer.cpp', @@ -103,6 +104,7 @@ ajantv2_sources = [ 'ajabase/system/linux/processimpl.cpp', 'ajabase/system/linux/threadimpl.cpp', 'ajantv2/src/ntv2anc.cpp', + 'ajantv2/src/ntv2aux.cpp', 'ajantv2/src/ntv2audio.cpp', 'ajantv2/src/ntv2autocirculate.cpp', 'ajantv2/src/ntv2bitfile.cpp', @@ -148,7 +150,6 @@ ajantv2_sources = [ 'ajantv2/src/ntv2task.cpp', 'ajantv2/src/ntv2testpatterngen.cpp', 'ajantv2/src/ntv2transcode.cpp', - 'ajantv2/src/ntv2utf8.cpp', 'ajantv2/src/ntv2utils.cpp', 'ajantv2/src/ntv2version.cpp', 'ajantv2/src/ntv2verticalfilter.cpp', @@ -164,6 +165,7 @@ ajantv2_args = [ '-DAJA_USE_CPLUSPLUS11', '-DNDEBUG', '-DNTV2_USE_CPLUSPLUS11', + '-DNTV2_PREVENT_PLUGIN_LOAD', ] ajantv2_inc = include_directories( -- cgit v1.2.3-70-g09d2