From bcfd50c8397711182a20f3044ce49b30426fb218 Mon Sep 17 00:00:00 2001 From: Moses Turner Date: Fri, 13 May 2022 14:15:54 +0100 Subject: [PATCH] u/sink: Make sure gen-locked frames have the same timestamp --- src/xrt/auxiliary/util/u_sink_force_genlock.c | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/src/xrt/auxiliary/util/u_sink_force_genlock.c b/src/xrt/auxiliary/util/u_sink_force_genlock.c index 8779dee24..262e17176 100644 --- a/src/xrt/auxiliary/util/u_sink_force_genlock.c +++ b/src/xrt/auxiliary/util/u_sink_force_genlock.c @@ -122,6 +122,21 @@ force_genlock_mainloop(void *ptr) */ pthread_mutex_unlock(&q->mutex); + /* + * Average the timestamps, SLAM systems break if they don't have the exact same timestamp. + * (This is dumb, because on DepthAI the images *are* taken like 0.1ms apart, and we *could* expose + * that, but oh well.) + */ + + int64_t ts_1 = frames[0]->timestamp; + int64_t ts_2 = frames[1]->timestamp; + + int64_t diff = (ts_2 - ts_1); + + int64_t ts = ts_1 + (diff / 2); + + frames[0]->timestamp = ts; + frames[1]->timestamp = ts; // Send to the consumer, in left-right order. xrt_sink_push_frame(q->consumer_left, frames[0]);