libajantv2
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.
Table of Contents
- 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
Directory Layout
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.
Obtaining libajantv2
Clone the libajantv2 repository from GitHub:
> git clone git@github.com:aja-video/libajantv2.git
Building libajantv2
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.
Please follow the instructions below to build libajantv2 on the supported platform and development environment of your preference.
Windows
Option 1: Developer Command Prompt for Visual Studio
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 the vcvarsall.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.
Option 2: Visual Studio CMake Integration
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
.
macOS
CMake Xcode Project Generation
- 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.
macOS and Linux
GNU Makefiles
- 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
.
All Platforms
Ninja Build
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.
Visual Studio Code
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.
Qt Creator
The libajantv2 repository can be opened as a directory in Qt Creator and built with the Qt Creator CMake integration.
Building the Kernel Module Driver (Linux)
Prerequisites
Before building the driver please ensure that you have installed the Linux kernel headers for your current distro:
Ubuntu 20.04/22.04
$ sudo apt install -y linux-headers-$(uname -r) linux-tools-$(uname -r)
CentOS7
$ sudo yum install -y kernel-devel kernel-devel-$(uname -r)
Building
-
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
Verifying the Kernel Module Driver (Linux)
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.
Customizing libajantv2
There are a number of macros that control certain aspects of NTV2:
NTV2_USE_CPLUSPLUS11
(in ajantv2/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 the CMAKE_CXX_STANDARD
that's in use at build-time.
Also note that if this macro is defined, so must AJA_USE_CPLUSPLUS11
(see below) … and vice-versa.
(Also note that SDK 17.1 is the last that will build with a C++98 compiler. The next SDK release will require C++11.)
AJA_USE_CPLUSPLUS11
(in ajabase/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 the CMAKE_CXX_STANDARD
that's in use at build-time.
Also note that if this macro is defined, so must NTV2_USE_CPLUSPLUS11
(see above) … and vice-versa.
(Also note that SDK 17.1 is the last that will build with a C++98 compiler. The next SDK release will require C++11.)
NTV2_NULL_DEVICE
(in ajantv2/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 having CNTV2DriverInterface::OpenLocalPhysical
always fail, thus permitting only remote devices to be accessed. This macro is undefined by default.
NTV2_NUB_CLIENT_SUPPORT
(in ajantv2/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
(in ajantv2/includes/ajatypes.h
) — If defined (the default), the WriteRegister
profiling API in CNTV2Card
is available.
NTV2_ALLOW_OPEN_UNSUPPORTED
(in ajantv2/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 the NTV2GetSupportedDevices
function in ntv2utils.h
.)
SDK Forward and Backward Compatibility
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.
Deprecation History
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 in `ajatypes.h` header file. This was the first SDK that jettisoned the old APIs by default.
- **SDK 12.5:** `NTV2_DEPRECATE_12_5` macro defined in `ajatypes.h`. Deprecated APIs:
**CNTV2SignalRouter**’s ‘**addWithValue**’ and ‘**AddConnection**’ methods that accepted **NTV2RoutingEntry**’s.
- **SDK 12.6:** `NTV2_DEPRECATE_12_6` macro defined in `ajatypes.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 in `ajatypes.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 in `ajatypes.h`. Deprecated APIs:
- **NTV2FormatDescriptor** constructors with bools for wide & tall VANC and 2Kx1080.
- **GetFormatDescriptor** global functions.
- `kRegAuxInterruptDelay` and `kRegReserved89` registers got redeployed as `kRegBitfileDate` and `kRegBitfileDate`, 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 in `ajatypes.h`.
- **SDK 14.0:** `NTV2_DEPRECATE_14_0` macro defined in `ajatypes.h`. Deprecated APIs:
- **CNTV2Card**’s RP188 functions that use `RP188_STRUCT`s.
- Retired several mis-named **NTV2DeviceID**s.
- **SDK 14.1:** `NTV2_DEPRECATE_14_1` macro defined in `ajatypes.h`.
- **SDK 14.2:** `NTV2_DEPRECATE_14_2` macro defined in `ajatypes.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 in `ajatypes.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 the `NTV2_TestPatt_`… ones.
- **SDK 15.0:** `NTV2_DEPRECATE_15_0` macro defined in `ajatypes.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 by `kVRegDriverVersion`.
- **SDK 15.1:** `NTV2_DEPRECATE_15_1` macro defined in `ajatypes.h`. Deprecated APIs:
- `NTV2SDIInputFormatSelect`, `NTV2PauseModeType` and `NTV2PulldownPatternType` 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 in `ajatypes.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 meaningful `RP188SourceFilterSelect`.
- **SDK 15.5:** `NTV2_DEPRECATE_15_3` and `NTV2_DEPRECATE_15_5` macros defined in `ajatypes.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` and `NTV2_DEPRECATE_16_0` in `ajatypes.h`. As-shipped, all `NTV2_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**
- **SDK 16.1:** Defined macro `NTV2_DEPRECATE_16_1` in `ajatypes.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 an `NTV2AudioSystem`.
- Deprecated **CNTV2Card::SetAudioOutputMonitorSource** and **CNTV2Card::GetAudioOutputMonitorSource** functions that accept the deprecated `NTV2AudioMonitorSelect` and `NTV2Channel` values, replacing them with identical functions that accept `NTV2AudioChannelPair` and `NTV2AudioSystem` 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 `NTV2AnalogAudioIO` and `NTV2AudioMonitorSelect` enum types.
- Deprecated `NTV2_AudioMonitor1_2` thru `NTV2_AudioMonitor15_16` in favor of `NTV2_AudioChannel1_2` thru `NTV2_AudioChannel17_18`.
- Deprecated **NTV2AudioMonitorSelectToString** utility.
- **SDK 16.2:** Defined macro `NTV2_DEPRECATE_16_2` in `ajatypes.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.
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.
Conditional Compilation Based on NTV2 SDK Version
The NTV2 SDK contains its version information as symbols defined in ntv2version.h
. This file is generated by CMake from the template ntv2version.h.in
. Both files are located in libajantv2/ajantv2/includes
. The following symbols are defined:
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 form MM/DD/YYYY +/-Z:hh:mm:ss
, where MM
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), and ss
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, where d
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
Driver Compatibility
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.
Firmware and Device Features
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.
libajantv2 Dynamic (Shared) Libary
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
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).
Determining dynamic library SDK version
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.
Building the libajantv2 Dynamic (Shared) Libary
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.