diff --git a/plugins/aja/aja-source.cpp b/plugins/aja/aja-source.cpp index 7cda6de9a..d0e8ebf70 100644 --- a/plugins/aja/aja-source.cpp +++ b/plugins/aja/aja-source.cpp @@ -7,11 +7,13 @@ #include #include #include +#include #include #include #include +#define NSEC_PER_SEC 1000000000LL #define NTV2_AUDIOSIZE_MAX (401 * 1024) AJASource::AJASource(obs_source_t *source) @@ -172,6 +174,16 @@ void AJASource::GenerateTestPattern(NTV2VideoFormat vf, NTV2PixelFormat pf, blog(LOG_DEBUG, "AJASource::GenerateTestPattern: Black"); } +static inline uint64_t samples_to_ns(size_t frames, uint_fast32_t rate) +{ + return util_mul_div64(frames, NSEC_PER_SEC, rate); +} + +static inline uint64_t get_sample_time(size_t frames, uint_fast32_t rate) +{ + return os_gettime_ns() - samples_to_ns(frames, rate); +} + void AJASource::CaptureThread(AJAThread *thread, void *data) { UNUSED_PARAMETER(thread); @@ -337,7 +349,8 @@ void AJASource::CaptureThread(AJAThread *thread, void *data) audioPacket.format = AUDIO_FORMAT_32BIT; audioPacket.speakers = SPEAKERS_7POINT1; audioPacket.frames = offsets.bytesRead / 32; - audioPacket.timestamp = os_gettime_ns(); + audioPacket.timestamp = + get_sample_time(audioPacket.frames, 48000); audioPacket.data[0] = (uint8_t *)ajaSource->mAudioBuffer .GetHostPointer(); obs_source_output_audio(ajaSource->mSource,