<html><head></head><body><div>Hi,</div><div><br></div><div>Le vendredi 23 décembre 2022 à 20:55 +0530, Pradeep Acharya via gstreamer-devel a écrit :</div><blockquote type="cite" style="margin:0 0 0 .8ex; border-left:2px #729fcf solid;padding-left:1ex"><div dir="ltr"><div>Hi,</div><div><br></div><div>I;m using audiomixer element to mix audio from live sources in a video conference call. The o/p of audio mixer is given to the opus encoder and then transmitted to the remote end . It works fine when there is only one one sink pad attached to the mixer i,,e only one client joins the conference. Problem starts when the 2nd participant joins and a second sink pad is added to the mixer.</div><div><br></div><div>I observe a delay proportional to the time the first user joined. After some time, the mixer starts to output data. Audio is not lost but delayed and the delay continues. I tried some of the configuration parameters like " start-time-selection" to 1 and "start-time" to 0. , "ignore-inactive-pads" to TRUE. There is no improvement even after configuring these params. From gstreamer logs, i could see that</div></div></blockquote><div><br></div><div>somehow gives me the impression this is the same issue that led into adding the "min-upstream-latency" property. When you add pad, the latency changes, and that can disturb the playback, using upstream-latency you can fix that latency so your worst case ahead of time. Let's hope this is it.</div><div><br></div><div>regards,</div><div>Nicolas</div><div><br></div><blockquote type="cite" style="margin:0 0 0 .8ex; border-left:2px #729fcf solid;padding-left:1ex"><div dir="ltr"><div><br></div><div><b>0:00:39.011285060</b> ^[[32m3313765^[[00m 0x7f6fdc00e460 ^[[37mDEBUG ^[[00m ^[[00;35m aggregator gstaggregator.c:2172:gst_aggregator_query_latency_unlocked:<audiomixer_111>^[[00m configured <b>latency live:true min:20000000 max:20000000 ---> when first sink pad is added <br></b></div><div><div><br></div><div>0:00:39.022481190 ^[[32m3313765^[[00m 0x<b>7f7068024760</b> ^[[33;01mLOG ^[[00m ^[[00;35m aggregator gstaggregator.c:3415:gst_aggregator_pad_buffer_consumed:<audiomixer_111:sink_0>^[[00m Signaling buffer consumed from thread 0x7f7068024760<br>0:00:39.022543769 ^[[32m3313765^[[00m 0x<b>7f706802476</b>0 ^[[37mDEBUG ^[[00m ^[[00;35m aggregator gstaggregator.c:3513:gst_aggregator_pad_pop_buffer:<audiomixer_111:sink_0>^[[00m Consumed: buffer: 0x7f6fa0004120, pts 0:00:00.822554913, dts 0:00:37.845570590, dur 0:00:00.020000000, size 3840, offset none, offset_end none, flags 0x0</div><div><br></div><div>0:00:39.023672822 ^[[32m3313765^[[00m 0x<b>7f7068024760</b> ^[[37mTRACE ^[[00m ^[[00;35m aggregator gstaggregator.c:3446:gst_aggregator_pad_clip_buffer_unlocked:<audiomixer_111:sink_0>^[[00m Clipping: buffer: 0x7f6fa0004240, pts 0:00:00.842553968, dts 0:00:37.847505654, dur 0:00:00.020000000, size 3840, offset none, offset_end none, flags 0x800</div><div><br></div><div>0:00:39.023926552 ^[[32m3313765^[[00m 0x7f7068024760 ^[[37mTRACE ^[[00m ^[[00;35m aggregator gstaggregator.c:713:gst_aggregator_default_finish_buffer:<audiomixer_111>^[[00m GstAggregator: 0x7f70680562a0 <b>pushing buffer buffer: </b>0x7f6ff4064900, pts 0:00:00.842541666, dts 99:99:99.999999999, dur 0:00:00.020000000, size 3840, offset 40442, offset_end 41402, flags 0x800<br></div><div><br></div><div><br></div><div>When 2nd participant joins after 8 minutes, sink_1 pad is created for audiomixer. Audio o/p is delayed by ~ 38 seconds i,,e time duration of 1st sink pad's <b>(sink_0 )</b> buffer start time .<br></div><div><br></div><div><b>0:08:53.918540128</b> ^[[32m3313765^[[00m 0x<b>7f6f98006e70</b> ^[[36mINFO ^[[00m ^[[00;35m aggregator gstaggregator.c:1524:gst_aggregator_start_srcpad_task:<audiomixer_111>^[[00m Starting srcpad task ---> when second sink pad is created sink_1<br><b>0:08:53.918829275</b> ^[[32m3313765^[[00m 0x<b>7f6fdc04a700</b> ^[[33;01mLOG ^[[00m ^[[00;35m aggregator gstaggregator.c:1380:gst_aggregator_aggregate_func:<audiomixer_111>^[[00m Checking aggregate<br></div><div><br></div><div>I see errors like pads not ready : no sink pads. However 2 sink pads were already created <br></div><div>0:10:17.737484397 ^[[32m3313765^[[00m 0x<b>7f7068024760</b> ^[[33;01mLOG ^[[00m ^[[00;35m aggregator gstaggregator.c:567:gst_aggregator_check_pads_ready:<audiomixer_111>^[[00m pads not ready: no sink pads</div><div>0:10:17.737527246 ^[[32m3313765^[[00m 0x<b>7f7068024760</b> ^[[37mDEBUG ^[[00m ^[[00;35m aggregator gstaggregator.c:893:gst_aggregator_wait_and_check:<audiomixer_111>^[[00m <b>possibly waiting for clock to reac</b>h 1246:02:12.632613629 (base 1245:51:56.05007196<b>3 start 0:10:16.562541666</b> latency 0:00:00.020000000 current 1246:02:12.613770784)<br></div><div><br></div><div><b>The source code works fine if i replace audio mixer element with adder element without modifying any other configurations or elements of the pipeline. This makes me to suspect audiomixer. i don't see delay issues that i see using the audiomixer. Any suggestions on how to debug and what to look for ? Should i continue using adder element instead of audiomixer. <br></b></div><div><br></div><div>Thanks & Regards</div><div>Pradeep<br></div></div></div></blockquote><div><br></div><div><span></span></div></body></html>