This is the open-source SDK for discovering, interrogating and controlling NTV2 professional video I/O devices from AJA Video Systems, Inc. All code herein is licensed under the MIT license.
NOTE: Only the "release" branch will have ongoing support for AJA Video Systems, Inc. Official releases will be tagged from the release branch going forward. The main branch should be considered unstable and is for ongoing development.
- Branch Overview
- Directory Layout
- Obtaining libajantv2
- Building libajantv2
- Building the Kernel Module Driver (Linux)
- Verifying the Kernel Module Driver (Linux)
- Customizing libajantv2
- SDK Forward & Backward Compatibility
- Driver Compatibility
- Firmware and Device Features
- libajantv2 Dynamic (Shared) Libary
This branch is only updated for official, tested releases of AJA’s “retail” software.
Example: NTV2_17_0
This branch tracks weekly changes to the 17.0.x major release branch of the SDK. In this example, you can find changes in the NTV2_17_0 branch that are slated to be included in future v17.0.x releases. This code has only had minimal testing and should be considered alpha code.
This is the “bleeding edge” development branch. Changes are synced weekly and is to be considered unstable. No QA testing has been done on this branch.
The libajantv2 folder contains the following items:
- ajaanc — Classes for encoding & decoding SDI ancillary data packets.
- ajabase — Utility classes (e.g. threads, mutexes, files, etc.).
- ajantv2 — Principal classes, especially CNTV2Card.
- includes — Header files.
- src — Source files.
- test — Unit test source code.
- utilityfiles — Additional sources needed to build some command-line utilities.
- ci — Continuous integration (CI) scripts.
- cmake — Cmake build-related stuff.
- container — Docker-related stuff.
- demos — Demonstration programs and applications.
- driver — Platform-specific device drivers.
- plugins — Dynamically-loadable libraries that augment SDK behavior.
- thirdparty — Required non-AJA packages (e.g. doctest)
- tools — Useful command-line utilities.
Clone the libajantv2 repository from GitHub:
> git clone [email protected]:aja-video/libajantv2.git
Starting in the NTV2 SDK version 17.0, AJA has standardized on CMake for describing how to build the libraries, demonstration applications, command-line tools, unit tests, and plugins. AJA requires CMake version 3.15 or later.
The instructions for building the default static library are generally the same on each supported platform (Windows, macOS, Linux). Note that the default "CMake Generator" varies by platform.
NOTE: By default — absent any parameters — all standard targets are built (static library, demos, tools, tests, plugins).
To prevent building certain targets, these CMake variables can be set to 'ON' in your CMake build environment:
AJANTV2_DISABLE_DEMOS
— If ON, prevents building the demonstration programs (e.g. ntv2capture, ntv2player, …).
Demo apps are normally built by default.AJANTV2_DISABLE_TOOLS
— If ON, prevents building the command-line tools (e.g. ntv2thermo, regio, supportlog, …).
Command-line tools are normally built by default.AJANTV2_DISABLE_TESTS
— If ON, prevents building the unit test(s).
The test programs are normally built by default.AJANTV2_DISABLE_PLUGINS
— If ON, builds the standard NTV2 plugins (i.e. nublegacy, swdevice, …).
The standard NTV2 plugins are normally built by default.
Please follow the instructions below to build libajantv2 on the supported platform and development environment of your preference.
Follow these instructions to build libajantv2 from a Developer Command Prompt for Visual Studio:
-
Open a command prompt window (
cmd
) and initialize your Visual Studio environment by running thevcvarsall.cmd
script from the desired Microsoft Visual Studio directory. The location of vcvarsall.cmd may vary depending on the version of Visual Studio installed on the development system.For example, if using Visual Studio 2019 Community Edition:
> SET VS_YEAR=2019 > SET VS_EDITION=Community > call "C:\Program Files (x86)\Microsoft Visual Studio\%VS_YEAR%\%VS_EDITION%\VC\Auxiliary\Build\vcvarsall.bat" x64
-
Run cmake to generate the libajantv2 Visual Studio Solution file in a directory called
build
:> cd libajantv2 > cmake -S . -B build
-
Build libajantv2 from the command line, via the generated Visual Studio Solution:
> cmake --build build
-
If the build completes without errors, the static library should be output to
out\build\<arch>-<build type>\ajantv2
under the libajantv2 directory.Other build target outputs (demos, tools, etc.) will be available in subdirectories under the build directory mirroring their original location in the libajantv2 source tree.
For example, the
ntv2enumerateboards.exe
demo app will be located in:out\build\demos\ntv2enumerateboards
.
Alternatively, the generated Visual Studio solution from build/libajantv2.sln
may be opened in Visual Studio, where libajantv2 can be built via the usual mechanisms.
Follow these instructions to build libajantv2 via the Microsoft Visual Studio CMake integration. This requires Visual Studio 2019 or 2022.
-
Open Microsoft Visual Studio 2019.
-
From the initial splash page, select "Open a local folder..." and navigate to the libajantv2 repo directory.
-
If CMake is installed and configured properly, the Output window should show the CMake configuration logs and end with a message saying "
CMake generation finished
". -
To reconfigure the build with custom settings for certain CMake variables, additional CMake or build flags, etc. go to the Project menu and select "CMake settings for libajantv2". Make any changes to the build flags, CMake flags, variables, etc. and then save the CMakeSettings.json document. The CMake configure step should automatically be re-run upon saving.
_NOTE: To manually re-run the CMake configure step with new settings, go to the Project menu and select "Configure libajantv2". If you've added libajantv2 as a sub-folder in another project you may see a different project name in the Configure menu item.
-
From the Build menu select "Build All".
-
If the build completes without errors, the static library should be output to
out\build\<arch>-<build type>\ajantv2
under the libajantv2 directory.Other build target outputs (demos, tools, etc.) will be available in subdirectories under the build directory mirroring their original location in the libajantv2 source tree.
For example, the
ntv2enumerateboards.exe
demo app will be located in:out\build\demos\ntv2enumerateboards
.
-
Open a Terminal and generate the XCode project files:
$ cd libajantv2 $ cmake -S . -B build -G Xcode
-
Build libajantv2 static library from the terminal, via the generated XCode Project:
$ cmake --build build
NOTE: It is also possible to build the generated XCode Project via the typical
xcrun
command:$ xcrun xcodebuild -project build/libajantv2.xcodeproj -target ALL_BUILD
-
If the build completes without errors, the static library should be output to
build/ajantv2/<Debug|Release>/libajantv2d.a
under the libajantv2 directory.Other build target outputs (demos, tools, etc.) will be available in subdirectories under the build directory mirroring their original location in the libajantv2 source tree.
For example, the
ntv2enumerateboards
demo app will be located in:build/demos/ntv2enumerateboards
.
Alternatively, the generated XCode project from build/libajantv2.xcodeproj
may be opened in XCode, where the static library can be build via the usual mechanisms.
-
Open a Terminal window and run cmake to generate the GNU Makefiles in a directory called
build
.$ cd libajantv2 $ cmake -S . -B build
-
Build the libajantv2 static library from the generated GNU Makefiles:
$ cmake --build build
-
If the build completes without errors, the static library should be output to
out\build\<arch>-<build type>\ajantv2
under the libajantv2 directory.Other build target outputs (demos, tools, etc.) will be available in subdirectories under the build directory mirroring their original location in the libajantv2 source tree.
For example, the
ntv2enumerateboards
demo app will be located in:out\build\demos\ntv2enumerateboards
.
If Ninja Build is installed in the PATH it is possible to generate .ninja build configuration files with CMake.
Ninja Build is available from GitHub, or via the package manager of your preference.
Download: https://github.com/ninja-build/ninja/releases
NOTE: The compiler toolset used by Ninja Build will vary depending which compiler CMake finds in the PATH by default. On macOS and Linux this is clang or gcc, and on Windows this is usually the cl compiler available under the current Developer Command Prompt for Visual Studio Environment.
-
Open a Terminal or Command Prompt window and run cmake with the Ninja generator specified, to created .ninja files in a directory called
build
.$ cd libajantv2 $ cmake -S . -B build -GNinja
-
Build all configured libajantv2 targets:
$ cmake --build build
-
If the build completes without errors, the libajantv2 static library should be available in
build/ajantv2
.Other build target outputs (demos, tools, etc.) will be available in subdirectories under the build directory mirroring their original location in the libajantv2 source tree.
The libajantv2 repository can be opened as a directory in Visual Studio Code and built with the optional Microsoft CMake Extension for VSCode.
-
Launch Visual Studio Code
-
From the File menu select Open (or Open Folder on macOS) and navigate to the libajantv2 repo directory.
-
In the left-hand sidebar click on the Extensions button or press Ctrl+Shift+P (Cmd+Shift+P on macOS) to open the Command Palette and search for "Extensions: Install Extensions".
-
In the left-hand sidebar search for the "cmake" extension from developer "twxs" (also available in the CMake Tools extension from Microsoft) and install it.
-
Open the Command Palette once again and search for "CMake: Configure".
-
If the configuration completes successfully, open the Command Palette and search for "CMake: Build".
-
If the build completes without errors, the libajantv2 static library should be available in
build/ajantv2
.Other build target outputs (demos, tools, etc.) will be available in subdirectories under the build directory mirroring their original location in the libajantv2 source tree.
The libajantv2 repository can be opened as a directory in Qt Creator and built with the Qt Creator CMake integration.
Before building the driver please ensure that you have installed the Linux kernel headers for your current distro:
$ sudo apt install -y linux-headers-$(uname -r) linux-tools-$(uname -r)
$ sudo yum install -y kernel-devel kernel-devel-$(uname -r)
- Open a terminal window and cd into the linux driver directory:
$ cd libajantv2/driver/linux
- Run make to build the driver
$ make clean && make
-
If the kernel module build succeeds, the ajantv2.ko file will appear in
libajantv2/driver/bin
. -
The driver can be installed/uninstalled in 2 ways, the manual method:
Install the kernel module using insmod:
$ sudo insmod ajantv2.ko
Note that on hosts with Secure Boot enabled, you’ll need to sign the ajantv2.ko kernel module after it’s been built. Check your Linux distro’s documentation for Secure Boot information.
Uninstall the kernel module using rmmod (all applications using the driver must be closed):
$ sudo rmmod ajantv2
- The alternate way to install the driver is via DKMS
Install the kernel module using DKMS:
$ make dkms-install
Uninstall the kernel module using DKMS:
$ make dkms-uninstall
To confirm that the driver is loaded and running on a host that has an AJA NTV2 device installed or connected, issue
an lsmod
command, and look for ajantv2 in the list.
You can also issue an ls /dev
command, and look for devices with names that start with ajantv2.
If lsmod
doesn’t report the device, or it doesn’t appear in /dev
:
- Try disabling any/all “fast boot” options in the host BIOS.
- Try disabling any/all power management options in the host BIOS (e.g. ASPM).
- Be sure the AJA device shows up in
lspci -nn -d f1d0:
. - Be sure the installed AJA board(s) each have two green LEDs lit after host power-on.
- Check the
dmesg
log for error messages from the AJA NTV2 kernel driver. - Try installing the AJA device in a different PCIe slot on the host motherboard.
There are a number of macros that control certain aspects of NTV2:
NTV2_USE_CPLUSPLUS11
(inajantv2/includes/ajatypes.h
) — If defined (the default), assumes a C++11 compiler (or later) is being used, and C++11 language features will be used in 'ajantv2'. Note that this macro will automatically be defined or undefined as necessary by CMake depending on theCMAKE_CXX_STANDARD
that's in use at build-time. Also note that if this macro is defined, so mustAJA_USE_CPLUSPLUS11
(see below) … and vice-versa.AJA_USE_CPLUSPLUS11
(inajabase/common/types.h
) — If defined (the default), assumes a C++11 compiler (or later) is being used, and C++11 language features will be used in 'ajabase'. Note that this macro will automatically be defined or undefined as necessary by CMake depending on theCMAKE_CXX_STANDARD
that's in use at build-time. Also note that if this macro is defined, so mustNTV2_USE_CPLUSPLUS11
(see above) … and vice-versa.NTV2_NULL_DEVICE
(inajantv2/includes/ajatypes.h
) — If defined, removes all linkage to the NTV2 kernel driver. This is used, for example, to build a “sandboxed” MacOS X application with no linkage to Apple’s IOKit framework. This has the side effect of havingCNTV2DriverInterface::OpenLocalPhysical
always fail, thus permitting only remote devices to be accessed. This macro is undefined by default.NTV2_NUB_CLIENT_SUPPORT
(inajantv2/includes/ajatypes.h
) — If defined (the default), the SDK will load plugins (DLLs, dylibs, .so’s) as necessary to connect to remote or virtual devices. For applications requiring higher security, this macro can be undefined to prevent dynamic plugin loading.NTV2_WRITEREG_PROFILING
(inajantv2/includes/ajatypes.h
) — If defined (the default), theWriteRegister
profiling API inCNTV2Card
is available.NTV2_ALLOW_OPEN_UNSUPPORTED
(inajantv2/includes/ajatypes.h
) — If defined, the SDK won’t check if the host-attached device being opened is supported; otherwise (the default), the SDK will fail the Open call if the host-attached device being opened is “unsupported”. (See theNTV2GetSupportedDevices
function inntv2utils.h
.)
The NTV2 source files originated many years ago from some of the earliest hardware products produced by AJA. These products ceased being dependent on NTV2 many years ago, but unfortunately, their legacy symbols remained in the SDK.
In addition, when the first NTV2 SDK was released, the video capture/playout devices it supported were circuit boards fixed in a specific motherboard slot with barely enough I/O capability to handle a single stream of 4:2:2 YUV SD video. Today’s devices are hot-pluggable, support multiple channels, each with its own signal format, up to 4:4:4 8Kp60 and beyond. As the SDK expanded over the years to support newer, faster devices, the older functions, data types and constants remained, which resulted in a very unwieldy and confusing SDK that made it difficult for OEM developers to quickly get up to speed.
Starting with the 11.3 SDK, AJA introduced the first NTV2_DEPRECATE
macro, and gathered many of the obsolete SDK functions, data types and constants under preprocessor #ifdef
blocks:
#if !defined(NTV2_DEPRECATE)
. . .
// Obsolete constants, data types and functions
. . .
#endif // !defined(NTV2_DEPRECATE)
This means that if the NTV2_DEPRECATE
macro is undefined, then existing code that relies on the old APIs will continue to compile, link and run. If the NTV2_DEPRECATE
macro is defined, then the obsolete APIs disappear from the compilation, and build errors will result if they’re used.
Click to expand
- SDK 11.3:
NTV2_DEPRECATE
macro introduced (but not defined anywhere). - SDKs 11.3 - 12.3: Shipped libraries built with old APIs intact (i.e.
NTV2_DEPRECATE
undefined, by default). - SDK 12.4:
NTV2_DEPRECATE
macro first defined inajatypes.h
header file. This was the first SDK that jettisoned the old APIs by default. - SDK 12.5:
NTV2_DEPRECATE_12_5
macro defined inajatypes.h
. Deprecated APIs: CNTV2SignalRouter’s ‘addWithValue’ and ‘AddConnection’ methods that accepted NTV2RoutingEntry’s. - SDK 12.6:
NTV2_DEPRECATE_12_6
macro defined inajatypes.h
. Deprecated APIs:- The old AutoCirculate APIs (InitAutoCirculate, StartAutoCirculate, etc.)
- Jettisoned some old NTV2DeviceID’s
- GetFormatDescriptor global functions.
- SDK 12.7:
NTV2_DEPRECATE_12_7
macro defined inajatypes.h
. Deprecated APIs:- CNTV2Card’s runtime bitfile-swapping functions.
- CNTV2Card::DisplayNTV2Error
- The old virtual register constant names (to force use of new
kVReg…
names).
- SDK 13.0:
NTV2_DEPRECATE_13_0
macro defined inajatypes.h
. Deprecated APIs:- NTV2FormatDescriptor constructors with bools for wide & tall VANC and 2Kx1080.
- GetFormatDescriptor global functions.
kRegAuxInterruptDelay
andkRegReserved89
registers got redeployed askRegBitfileDate
andkRegBitfileDate
, respectively.- Fill8BitYCbCrVideoFrame and Fill10BitYCbCrVideoFrame utility functions.
- CNTV2Card::GetVideoActiveSize and CNTV2Card::GetVideoWriteSize utility functions that accept bools for wide & tall VANC.
- SDK 13.1:
NTV2_DEPRECATE_13_1
macro defined inajatypes.h
. - SDK 14.0:
NTV2_DEPRECATE_14_0
macro defined inajatypes.h
. Deprecated APIs:- CNTV2Card’s RP188 functions that use
RP188_STRUCT
s. - Retired several mis-named NTV2DeviceIDs.
- CNTV2Card’s RP188 functions that use
- SDK 14.1:
NTV2_DEPRECATE_14_1
macro defined inajatypes.h
. - SDK 14.2:
NTV2_DEPRECATE_14_2
macro defined inajatypes.h
. Deprecated APIs:- AJAAncillaryData::SetLocationVideoStream
- The 3-parameter variant of AJAAncillaryList::AddVANCData.
- AJA CC library’s caption logging control flags.
- SDK 14.3:
NTV2_DEPRECATE_14_3
macro defined inajatypes.h
. Deprecated APIs:- The 4-parameter CNTV2Card constructor.
- The CNTV2Card::GetFrameBufferSize function that returns NTV2FrameSize via a pointer.
- Several CNTV2Card GetHDMI…/SetHDMI… member functions were replaced by GetHDMIOut…/SetHDMIOut… functions.
- Several CNTV2Card GetAnc…/SetAnc… member functions were replaced by AncInsert…/AncExtract… functions.
- Most CNTV2Card functions that returned data via a pointer-based parameter.
- The NTV2DeviceType data type.
- The NTV2DeviceTypeString debug function.
- The NTV2DeviceCanDoFreezeOutput device features function.
- The 4-parameter variants of CNTV2DriverInterface::Open, CNTV2LinuxDriverInterface::Open, CNTV2MacDriverInterface::Open and CNTV2WinDriverInterface::Open.
- The pointer-based variants of CNTV2DriverInterface::ReadRegister, CNTV2LinuxDriverInterface::ReadRegister
- The “un-numbered” NTV2_XptHDMIIn… output crosspoint IDs that were replaced by “numbered” ones (e.g. NTV2_XptHDMIIn1).
- The AJATestPattern… data types that were replaced by the NTV2TestPattern… ones.
- The
AJA_TestPattEx_
… enumerations that were replaced by theNTV2_TestPatt_
… ones.
- SDK 15.0:
NTV2_DEPRECATE_15_0
macro defined inajatypes.h
. Deprecated APIs:- The entire AJATestPatternGen class that was replaced with NTV2TestPatternGen.
- CNTV2Card::IsKonaIPDevice was replaced with CNTV2Card::IsIPDevice.
- NTV2TestPatternList was replaced with NTV2TestPatternNames.
- NTV2TestPatternGen::getTestPatternList was replaced with NTV2TestPatternGen::getTestPatternNames.
kVRegLinuxDriverVersion
was replaced bykVRegDriverVersion
.
- SDK 15.1:
NTV2_DEPRECATE_15_1
macro defined inajatypes.h
. Deprecated APIs:NTV2SDIInputFormatSelect
,NTV2PauseModeType
andNTV2PulldownPatternType
data types were removed.- CNTV2MacDriverInterface::SetOutputTimecodeOffset, CNTV2MacDriverInterface::GetOutputTimecodeOffset, CNTV2MacDriverInterface::SetOutputTimecodeType and CNTV2MacDriverInterface::GetOutputTimecodeType functions were removed.
- SDK 15.2:
NTV2_DEPRECATE_15_2
macro defined inajatypes.h
. Deprecated APIs:- AJAAncillaryDataLocation::Set was removed.
- AJAAncillaryDataLocation instance data members were made private.
- AJAAncillaryData::GetDataLocation members having parameters were removed.
- AJAAncillaryData::GetLocationVideoStream was replaced by AJAAncillaryData::GetLocationDataChannel.
- The multi-parameter variant of AJAAncillaryData::SetDataLocation was removed.
- AJAAncillaryData::SetLocationVideoSpace
- AJAAncillaryList::SetFromSDIAncData and AJAAncillaryList::SetFromIPAncData were deprecated in favor of the generic AJAAncillaryList::SetFromDeviceAncBuffers.
- The
UByte*
versions of CNTV2Card::DMAReadAnc and CNTV2Card::DMAWriteAnc. - CNTV2Card::GetQuadFrameEnable and CNTV2Card::GetQuadQuadFrameEnable.
- The
RP188_STRUCT
-based variants of CNTV2Card’s Get/SetRP188Data and Get/SetRP188Source. - The
RP188SourceSelect
type definition was deprecated in favor of the more meaningfulRP188SourceFilterSelect
.
- SDK 15.5:
NTV2_DEPRECATE_15_3
andNTV2_DEPRECATE_15_5
macros defined inajatypes.h
. Deprecated APIs:- AJARTPAncPayloadHeader::GetPacketLength was deprecated.
- An overloaded version of AJAAncillaryList::GetIPTransmitData was deprecated.
- An overloaded version of AJAAncillaryList::GetIPTransmitDataLength was deprecated.
- The original Audio Mixer API in CNTV2Card was deprecated and replaced with a new, improved API.
- SDK 16.0: Defined macros
NTV2_DEPRECATE_15_6
andNTV2_DEPRECATE_16_0
inajatypes.h
. As-shipped, allNTV2_DEPRECATE_
macros preceding SDK 15.0 are defined in SDK 16.0 (making all symbols they deprecate unavailable). Here are the functions that have newly been marked for deprecation in SDK 16.0:- In CNTV2Card:
- Deprecated the original SDI Relay APIs: CNTV2Card::GetSDIRelayPosition12, CNTV2Card::GetSDIRelayPosition34, CNTV2Card::GetSDIRelayManualControl12, CNTV2Card::GetSDIRelayManualControl34, CNTV2Card::GetSDIWatchdogEnable12, CNTV2Card::GetSDIWatchdogEnable34, CNTV2Card::SetSDIRelayManualControl12, CNTV2Card::SetSDIRelayManualControl34, CNTV2Card::SetSDIWatchdogEnable12, CNTV2Card::SetSDIWatchdogEnable34, CNTV2Card::GetSDIWatchdogState, and CNTV2Card::SetSDIWatchdogState. These have all been replaced with a new, much cleaner API.
- Deprecated these Audio API functions: CNTV2Card::WriteAudioSource, CNTV2Card::ReadAudioSource, CNTV2Card::SetAudioOutputReset, CNTV2Card::GetAudioOutputReset, CNTV2Card::SetAudioInputReset, and CNTV2Card::GetAudioInputReset
- Deprecated CNTV2Card::GetBaseAddress, CNTV2Card::GetBaseAddress, CNTV2Card::GetRegisterBaseAddress, and CNTV2Card::GetXena2FlashBaseAddress
- Deprecated CNTV2Card::SetRegisterWritemode and CNTV2Card::GetRegisterWritemode
- In CNTV2DriverInterface:
- Deprecated CNTV2DriverInterface::LockFormat, CNTV2DriverInterface::StartDriver, CNTV2DriverInterface::SetUserModeDebugLevel, CNTV2DriverInterface::GetUserModeDebugLevel, CNTV2DriverInterface::SetKernelModeDebugLevel, CNTV2DriverInterface::GetKernelModeDebugLevel, CNTV2DriverInterface::SetUserModePingLevel, CNTV2DriverInterface::GetUserModePingLevel, CNTV2DriverInterface::SetKernelModePingLevel, CNTV2DriverInterface::GetKernelModePingLevel, CNTV2DriverInterface::SetLatencyTimerValue, CNTV2DriverInterface::GetLatencyTimerValue, CNTV2DriverInterface::SetDebugFilterStrings, and CNTV2DriverInterface::GetDebugFilterStrings
- Deprecated CNTV2DriverInterface::SuspendAudio, CNTV2DriverInterface::ResumeAudio, CNTV2DriverInterface::MapFrameBuffers, CNTV2DriverInterface::UnmapFrameBuffers, CNTV2DriverInterface::MapRegisters, CNTV2DriverInterface::UnmapRegisters, CNTV2DriverInterface::MapXena2Flash, CNTV2DriverInterface::UnmapXena2Flash, CNTV2DriverInterface::DmaUnlock, CNTV2DriverInterface::CompleteMemoryForDMA, CNTV2DriverInterface::PrepareMemoryForDMA, CNTV2DriverInterface::GetInterruptCount, CNTV2DriverInterface::ReadRegisterMulti, CNTV2DriverInterface::GetPCISlotNumber, CNTV2DriverInterface::SleepMs, and CNTV2DriverInterface::GetAudioFrameBufferNumber
- In CNTV2MacDriverInterface:
- Deprecated CNTV2MacDriverInterface::SetUserModeDebugLevel, CNTV2MacDriverInterface::GetUserModeDebugLevel, CNTV2MacDriverInterface::SetKernelModeDebugLevel, CNTV2MacDriverInterface::GetKernelModeDebugLevel, CNTV2MacDriverInterface::SetUserModePingLevel, CNTV2MacDriverInterface::GetUserModePingLevel, CNTV2MacDriverInterface::SetKernelModePingLevel, CNTV2MacDriverInterface::GetKernelModePingLevel, CNTV2MacDriverInterface::SetLatencyTimerValue, CNTV2MacDriverInterface::GetLatencyTimerValue, CNTV2MacDriverInterface::SetDebugFilterStrings, CNTV2MacDriverInterface::GetDebugFilterStrings, CNTV2MacDriverInterface::LockFormat, and CNTV2MacDriverInterface::GetQuickTimeTime
- Deprecated CNTV2MacDriverInterface::GetStreamingApplication, CNTV2MacDriverInterface::SystemControl, CNTV2MacDriverInterface::Sleep, CNTV2MacDriverInterface::MapFrameBuffers, CNTV2MacDriverInterface::UnmapFrameBuffers, CNTV2MacDriverInterface::MapRegisters, CNTV2MacDriverInterface::UnmapRegisters, CNTV2MacDriverInterface::MapXena2Flash, CNTV2MacDriverInterface::UnmapXena2Flash, CNTV2MacDriverInterface::GetPCISlotNumber, and CNTV2MacDriverInterface::MapMemory
- In CNTV2WinDriverInterface:
- Deprecated CNTV2WinDriverInterface::SetStrictTiming, CNTV2WinDriverInterface::GetStrictTiming, CNTV2WinDriverInterface::GetStreamingApplication, and CNTV2WinDriverInterface::GetStreamingApplication
- Deprecated CNTV2WinDriverInterface::MapFrameBuffers, CNTV2WinDriverInterface::UnmapFrameBuffers, CNTV2WinDriverInterface::MapRegisters, CNTV2WinDriverInterface::UnmapRegisters, CNTV2WinDriverInterface::MapXena2Flash, CNTV2WinDriverInterface::UnmapXena2Flash, CNTV2WinDriverInterface::MapMemory, CNTV2WinDriverInterface::DmaUnlock, CNTV2WinDriverInterface::CompleteMemoryForDMA, and CNTV2WinDriverInterface::PrepareMemoryForDMA
- In CNTV2LinuxDriverInterface:
- Deprecated CNTV2LinuxDriverInterface::GetStreamingApplication, CNTV2LinuxDriverInterface::GetStreamingApplication, CNTV2LinuxDriverInterface::MapFrameBuffers, CNTV2LinuxDriverInterface::UnmapFrameBuffers, CNTV2LinuxDriverInterface::MapRegisters, CNTV2LinuxDriverInterface::UnmapRegisters, CNTV2LinuxDriverInterface::GetBA0MemorySize, CNTV2LinuxDriverInterface::GetBA1MemorySize, CNTV2LinuxDriverInterface::GetBA2MemorySize, CNTV2LinuxDriverInterface::GetBA4MemorySize, CNTV2LinuxDriverInterface::MapXena2Flash, CNTV2LinuxDriverInterface::UnmapXena2Flash, MapDNXRegisters, and UnmapDNXRegisters have all been deprecated.
- Deprecated NTV2DeviceCanConnect
- In CNTV2CaptionDecoder608:
- Deprecated an overloaded version of CNTV2CaptionDecoder608::BurnCaptions
- In NTV2TestPatternGen:
- Deprecated an overloaded version of NTV2TestPatternGen::DrawTestPattern
- In CNTV2CaptionRenderer:
- Deprecated these overloaded functions: CNTV2CaptionRenderer::GetRenderer, CNTV2CaptionRenderer::BurnChar, CNTV2CaptionRenderer::BurnString, CNTV2CaptionRenderer::BurnStringAtXY
- In CNTV2Card:
- SDK 16.1: Defined macro
NTV2_DEPRECATE_16_1
inajatypes.h
. Here are the functions that have newly been marked for deprecation in SDK 16.1:- In CNTV2Card:
- Deprecated CNTV2Card::WriteAudioLastOut, CNTV2Card::ReadAudioLastOut, and CNTV2Card::ReadAudioLastIn functions that accept an
NTV2Channel
value, replacing them with identical functions that accept anNTV2AudioSystem
. - Deprecated CNTV2Card::SetAudioOutputMonitorSource and CNTV2Card::GetAudioOutputMonitorSource functions that accept the deprecated
NTV2AudioMonitorSelect
andNTV2Channel
values, replacing them with identical functions that acceptNTV2AudioChannelPair
andNTV2AudioSystem
values. - Deprecated CNTV2Card::SetAnalogAudioIOConfiguration, CNTV2Card::GetAnalogAudioIOConfiguration functions, replacing them with CNTV2Card::SetAnalogAudioTransmitEnable and CNTV2Card::GetAnalogAudioTransmitEnable, respectively.
- Deprecated obsolete CNTV2Card::GetSecondConverterOutStandard, CNTV2Card::SetSecondConverterOutStandard, CNTV2Card::GetSecondDownConvert, and CNTV2Card::GetSecondDownConvert functions.
- Deprecated CNTV2Card::WriteAudioLastOut, CNTV2Card::ReadAudioLastOut, and CNTV2Card::ReadAudioLastIn functions that accept an
- Deprecated
NTV2AnalogAudioIO
andNTV2AudioMonitorSelect
enum types. - Deprecated
NTV2_AudioMonitor1_2
thruNTV2_AudioMonitor15_16
in favor ofNTV2_AudioChannel1_2
thruNTV2_AudioChannel17_18
. - Deprecated NTV2AudioMonitorSelectToString utility.
- In CNTV2Card:
- SDK 16.2: Defined macro
NTV2_DEPRECATE_16_2
inajatypes.h
. Here are the functions that have newly been marked for deprecation in SDK 16.2:- In CNTV2Card:
- Deprecated obsolete functions CNTV2Card::GetActiveFrameDimensions and CNTV2Card::GetNumberActiveLines.
- Deprecated obsolete functions CNTV2Card::SetPCIAccessFrame, CNTV2Card::GetPCIAccessFrame and CNTV2Card::FlipFlopPage.
- Member functions CNTV2Card::GetBaseAddress, CNTV2Card::GetRegisterBaseAddress and CNTV2Card::GetXena2FlashBaseAddress first deprecated in SDK 16.0 now produce compile-time warnings when used.
- Two overloaded member functions NTV2TestPatternGen::DrawTestPattern first deprecated in SDK 16.0 now produce compile-time warnings when used.
- In libajacc Closed-Caption Library, the deprecated CNTV2CaptionRenderer member functions (GetRenderer, BurnChar, BurnString, BurnStringAtXY) first deprecated in SDK 16.0 now produce compile-time warnings when used.
- In CNTV2Card:
To build the ajantv2 library to include a deprecated API, comment out or remove its corresponding #define NTV2_DEPRECATE
… line in ajatypes.h
, then rebuild the library.
Note: It’s best to undefine macros from oldest-to-newest SDKs in contiguous blocks or unexpected results may occur. For example, do this:
#define NTV2_DEPRECATE
#define NTV2_DEPRECATE_15_5
//#define NTV2_DEPRECATE_15_6
//#define NTV2_DEPRECATE_15_7
… and not this:
#define NTV2_DEPRECATE
//#define NTV2_DEPRECATE_15_5
//#define NTV2_DEPRECATE_15_6
#define NTV2_DEPRECATE_15_7
AJA may jettison all deprecated symbols and APIs in a future SDK. Please prepare for this by porting your code to the latest SDK. AJA developer partners are encouraged to use the NTV2 SDK Porting Guide, available at sdksupport.aja.com.
The NTV2 SDK contains its version information as symbols defined in ajaversion.h
(located inside libajantv2/ajantv2/includes
). It defines the following symbols:
AJA_NTV2_SDK_VERSION_MAJOR
The SDK’s major version number (an unsigned numeric constant).AJA_NTV2_SDK_VERSION_MINOR
The SDK’s minor version number (an unsigned numeric constant).AJA_NTV2_SDK_VERSION_POINT
The SDK’s “point” version number (an unsigned numeric constant).AJA_NTV2_SDK_BUILD_NUMBER
The SDK build number (an unsigned numeric constant).AJA_NTV2_SDK_BUILD_DATETIME
The date and time the SDK was built, a string literal of the formMM/DD/YYYY +/-Z:hh:mm:ss
, whereMM
is the 2-digit month (01 thru 12),DD
is the 2-digit day number,YYYY
is the 4-digit year,+/-Z
is the number of hours relative to UTC,hh
is the 2-digit hour (0 thru 23),mm
is the number of minutes past the hour (0 thru 59), andss
is the number of seconds past the minute (0 thru 59).AJA_NTV2_SDK_BUILD_TYPE
The SDK build type, a string literal containing a single character, whered
means “development”,a
means “alpha”,b
means “beta” and the empty string means “release”.AJA_NTV2_SDK_VERSION
An unsigned integer value built from the SDK version components that can be reliably compared with other version integer values. There’s also a convenient macro for testing which SDK version is being used at compile-time:AJA_NTV2_SDK_VERSION_AT_LEAST(major, minor)
Yields “true” if the major and minor version numbers of the current SDK being compiled are at least (greater than or equal to) the specified major and minor values, respectively. To use this macro, call it with the minimum version of the required SDK:
#if AJA_NTV2_SDK_VERSION_AT_LEAST (16, 2)
. . .
#endif // if NTV2 SDK version >= 12.0
AJA always recommends that NTV2-based applications be built from the same SDK version as the installed driver that will be used.
Warning: While AJA always tries to maintain backward compatibility between newer SDKs and older drivers, AJA cannot guarantee correct operation of applications built from an older SDK running on a newer version driver, nor applications built from a newer SDK running on an older version driver.
For a given SDK release, the CanDoXXXX, GetNumXXXX, etc. Device Features API responses should be correct for all supported devices running the latest firmware available on or after the SDK release date. AJA will do its best to document any exceptions on the SDK’s download page and/or the device firmware page in the Knowledgebase.
Starting in SDK 16.1, AJA started to distribute libajantv2 as a dynamic library both on public forums, and in AJA’s MacOS, Windows, and Linux “retail” desktop software installers.
libajantv2 is publically-distributed as a dynamic library. AJA’s retail desktop installers install the NTV2 dynamic libraries into the following host locations:
- Linux —
/opt/aja
- ajantv2_MM.so (…where MM is a two-digit major version number)
- macOS —
/Library/Application Support/AJA
- ajantv2_MM.dylib
- ajantv2d_MM.dylib — if present, the debug version of the library
- Windows —
…\Program Files\AJA
- MMAJANTV2.DLL
File Name: The libary’s file name includes the SDK major version number in the name (e.g. ajantv2_16.dylib
).
- All public, non-static symbols are exported as intended for “strong” linkage.
- The dynamic library is intended for “tight” integration with client applications. Changing even one NTV2 data type, class definition or function signature without rebuilding both the SDK library and the client application(s) will likely yield dynamic loader failures at launch-time, or unexpected results at runtime (including crashes).
When dynamically loading the NTV2 library at runtime (as opposed to having it automatically loaded by the host operating system at launch time), the library can be queried for more specific version information by two utility functions:
NTV2GetVersionString
– returns a string that starts with “major.minor.point” that includes the major, minor, and point version number values in decimal form.NTV2GetSDKVersionComponent
– returns any of the major, minor, and point version number values by passing 0, 1, 2 or 3, respectively, for the version component being requested.
NOTE: It is strongly recommended that the SDK client software operates with the SDK dynamic library that has the same version.
WARNING: Do not use an SDK dynamic library whose major version number differs from the SDK major version number when the SDK client was compiled.
To build the libajantv2 dynamic library, set the AJANTV2_BUILD_SHARED
CMake variable to 'ON' in your build environment.
AJANTV2_BUILD_SHARED
— If ON, produces the libajantv2 dynamic library.
By default, the libajantv2 dynamic library is not built.