From 9020106341608698b9ad4dac487f38c7f76be31f Mon Sep 17 00:00:00 2001 From: Thomas Guillem Date: Fri, 2 Dec 2022 16:28:22 +0100 Subject: [PATCH] auhal: add kAudioDevicePropertySafetyOffset to the latency --- modules/audio_output/auhal.c | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) diff --git a/modules/audio_output/auhal.c b/modules/audio_output/auhal.c index 7f1aae337181..28153b5d95da 100644 --- a/modules/audio_output/auhal.c +++ b/modules/audio_output/auhal.c @@ -1482,7 +1482,8 @@ GetLatency(audio_output_t *p_aout, const audio_sample_format_t *fmt) aout_sys_t *p_sys = p_aout->sys; UInt32 i_latency_samples; - vlc_tick_t i_latency_us, i_device_latency_us = 0, i_stream_latency_us = 0; + vlc_tick_t i_latency_us, i_device_latency_us = 0, i_device_offset_us = 0, + i_stream_latency_us = 0; /* Get device latency */ int ret = AO_GET1PROP(p_sys->i_selected_dev, UInt32, &i_latency_samples, kAudioDevicePropertyLatency, @@ -1492,6 +1493,15 @@ GetLatency(audio_output_t *p_aout, const audio_sample_format_t *fmt) else msg_Warn(p_aout, "failed to get kAudioDevicePropertyLatency"); + /* Get device safety offset */ + ret = AO_GET1PROP(p_sys->i_selected_dev, UInt32, &i_latency_samples, + kAudioDevicePropertySafetyOffset, + kAudioObjectPropertyScopeOutput); + if (ret == VLC_SUCCESS) + i_device_offset_us = vlc_tick_from_samples(i_latency_samples, fmt->i_rate); + else + msg_Warn(p_aout, "failed to get kAudioDevicePropertySafetyOffset"); + AudioStreamID sid; /* Get stream latency */ ret = AO_GET1PROP(p_sys->i_selected_dev, AudioStreamID, &sid, @@ -1509,11 +1519,11 @@ GetLatency(audio_output_t *p_aout, const audio_sample_format_t *fmt) else msg_Warn(p_aout, "failed to get kAudioDevicePropertyStreams"); - i_latency_us = i_device_latency_us + i_stream_latency_us; + i_latency_us = i_device_latency_us + i_device_offset_us + i_stream_latency_us; msg_Dbg(p_aout, "Current device has a latency of %" PRId64 " us " - "(device: %" PRId64 " us, stream: %" PRId64 " us)", i_latency_us, - i_device_latency_us, i_stream_latency_us); + "(device: %" PRId64 " us, offset: %" PRId64 " us, stream: %" PRId64 " us)", i_latency_us, + i_device_latency_us, i_device_offset_us, i_stream_latency_us); return i_latency_us; }