<div dir="ltr"><br><div class="gmail_extra"><br><br><div class="gmail_quote">On Sat, Jan 25, 2014 at 11:56 AM, Sebastian Dröge <span dir="ltr"><<a href="mailto:sebastian@centricular.com" target="_blank">sebastian@centricular.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;padding-left:1ex;border-left-color:rgb(204,204,204);border-left-width:1px;border-left-style:solid"><div class="im">On Fr, 2014-01-24 at 11:36 -0500, Ricky Houghton wrote:<br>

> As a follow up, I have determined that the program, Tutorial #4,l thinks<br>
> that the stream is "NOT LIVE", however it never hits the buffering_cb<br>
> function in tutorial-4.c, so this function is not responsible for the delay.<br>
<br>
</div>Buffering only happens if the stream is not considered live, and for<br>
RTSP streams only if the complete duration is known. What's the case<br>
here?<br></blockquote><div><br></div><div>The duration is unknown so I would assume there is no buffering - but there is some somewhere.</div><div>(N.B. the function Tutorial 4 function buffering_cb is never called, so there is no buffering happening here.)</div>
<div><br></div><div>The RTSP stream is coming from a hardware encoder running the TI DaVinci 8168. The particular</div><div>encoder is here: <a href="http://www.neyasystems.com/products/uxstreamer">http://www.neyasystems.com/products/uxstreamer</a> - they have demonstrated 100ms </div>
<div>video to network in the past. (These guys are my friends.) Network latency is single digit millisecond as the units are sitting</div><div>on an isolated AP, encoder hardwired, Nexus 7 is only wireless device. </div><div>
<br></div><div>I have continued playing/exploring and I stumbled upon </div><div><br></div><div>g_object_get (data->pipeline, "buffer-duration", &bufdur,NULL);</div><div>g_object_get(data->pipeline, "buffer-size", &bufsize,NULL);</div>
<div><br></div><div>Are these two values relevant, even if local buffering (in Tutorial 4) is not being used?</div><div><br></div><div>Can you point me to how I can control the rtspsrc buffer? I am using Tutorial 4 and have access to the </div>
<div>pipeline etc, but not exactly clear how to access the rtspsrc filter and how I might set the parameters for the buffering?</div><div>I can RTFM, however I don't fully understand the connection of the Android world and the GStreamer world via the NDK.</div>
<div><br></div><div>I am software dev, but mostly embedded and mostly C/C++. - If there is an example somewhere on how to reach into the </div><div>rtspsrc and which parameters I could adjust to likely pull the pieces together. </div>
<div><br></div><div>Thanks for your time,</div><div><br></div><div>Ricky</div><div><br></div><div><br></div><div><br></div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;padding-left:1ex;border-left-color:rgb(204,204,204);border-left-width:1px;border-left-style:solid">

<br>
Some more comments below<br>
<div class="im"><br>
> On Thu, Jan 23, 2014 at 9:15 PM, Ricky Houghton <<a href="mailto:ricky.houghton@gmail.com">ricky.houghton@gmail.com</a>>wrote:<br>
><br>
> > I was able to successfully compile and run the tutorials on my Nexus 7<br>
> > device. (Thanks to all who made this possible.)<br>
> ><br>
> > I modified the code for Android Tutorial #4 slightly to serve up a live<br>
> > stream from a H.264 device serving up a RTSP stream. The video displays<br>
> > correctly and everything works nicely. I've left it running for more than<br>
> > an hour with no issue.<br>
> ><br>
> > However there is a constant delay of about 4 to 5 seconds on the video<br>
> > stream. I've used Bing and Google to search for an answer, but can't seem<br>
> > to find which buffer/cache variable might contribute to the delay. (The<br>
> > code appears to ignore buffering if the stream is live, but there is<br>
> > clearly some buffering underneath that is creating this delay)<br>
> ><br>
> > Please note, the delay is constant over the hour, so I'm pretty sure the<br>
> > decoder is able to keep up - and the latency/delay doesn't increase which<br>
> > lends me to believe there is a buffer/cache value that is set rather high.<br>
<br>
</div>There's a latency property on rtspsrc which by default is 2000<br>
milliseconds. So you automatically have a delay of 2 seconds added there<br>
already. You can try to lower the latency but how low it can go depends<br>
on your network conditions.<br>
<br>
Apart from that there is probably also some delay caused by the encoder<br>
(x264enc by default has a delay of 3 seconds for example, which encoder<br>
do you use here?)... and of course the network.<br>
<div class="im"><br>
> > Thanks,<br>
> ><br>
> > Ricky<br>
> ><br>
> > btw, when the application starts, I do receive a few messages similar to<br>
> > this one, however they quickly disappear once the video stream synchronizes<br>
> > and stabilizes. It normally takes about 3 or 4 seconds for this, then<br>
> > everything is fine. I do not see this message again, no matter how long I<br>
> > run the encoder.<br>
> ><br>
> >  01-23 21:10:54.550: W/GStreamer+amcvideodec(2319): 0:00:28.046864000<br>
> > 0x69d96860<br>
> > gstamcvideodec.c:1025:gst_amc_video_dec_loop:<amcvideodec-omxnvidiah264decode0><br>
> > Frame is too late, dropping (deadline 0:00:00.194772226)<br>
<br>
</div>That would mean that in the beginning decoding happens a bit too slow.<br>
If you lower the latency on rtspsrc it will happen more often in the<br>
beginning probably.<br>
<br>
This could be because the nvidia hardware decoder also introduces some<br>
delay but does not advertise it (and we have no way to know it<br>
unfortunately because the Android APIs don't expose that).<br>
<span><font color="#888888"><br>
--<br>
Sebastian Dröge, Centricular Ltd - <a href="http://www.centricular.com" target="_blank">http://www.centricular.com</a><br>
Expertise, Straight from the Source<br>
</font></span><br>_______________________________________________<br>
gstreamer-android mailing list<br>
<a href="mailto:gstreamer-android@lists.freedesktop.org">gstreamer-android@lists.freedesktop.org</a><br>
<a href="http://lists.freedesktop.org/mailman/listinfo/gstreamer-android" target="_blank">http://lists.freedesktop.org/mailman/listinfo/gstreamer-android</a><br>
<br></blockquote></div><br></div></div>