<html dir="ltr"><head><meta http-equiv="Content-Type" content="text/html; charset=us-ascii"></head><body class="" style="text-align:left; direction:ltr;"><div>Hi,</div><div><br></div><div>I can reproduce this issue, can you file this into our issue tracking system please ?</div><div><br></div><div><a href="https://gitlab.freedesktop.org/gstreamer/gst-plugins-good/issues/new">https://gitlab.freedesktop.org/gstreamer/gst-plugins-good/issues/new</a></div><div><br></div><div>Just a note, the received and depayloaded data is fine, but could be badly framed by the depayloader or some other issues in the packaging of the data. To demonstrate:</div><div><br></div><div>gst-launch-1.0 -v udpsrc port=55002 ! application/x-rtp,clock-rate=90000,payload=96 ! rtpjitterbuffer ! rtph264depay ! video/x-h264,stream-format=byte-stream ! filesink location=test.h264</div><div><br></div><div>And then you can playback cleanly:</div><div><br></div><div>gst-launch-1.0 filesrc location=test.h264 ! video/x-h264,framerate=10/1 ! h264parse ! avdec_h264 ! glimagesink</div><div><br></div><div>Le samedi 26 janvier 2019 à 21:38 +0000, Joe Palmer a écrit :</div><blockquote type="cite" style="margin:0 0 0 .8ex; border-left:2px #729fcf solid;padding-left:1ex"><span style="font-family: HelveticaNeue;" class="">Safari 12 now encodes WebRTC video using the H264 high profile which is causing the frames in my pipeline to get corrupted (it works fine with videos from Safari 11 which uses the baseline profile).</span><br class=""><div style="font-family: HelveticaNeue;" class=""><br></div><div style="font-family: HelveticaNeue;" class="">Here is my Gstreamer pipeline:</div><div style="font-family: HelveticaNeue;" class=""><br class=""></div><div style="font-family: HelveticaNeue;" class="">gst-launch-1.0 -v udpsrc port=55002 ! application/x-rtp,clock-rate=90000,payload=96 ! rtpjitterbuffer mode=0 ! rtph264depay ! h264parse ! avdec_h264 ! videoconvert ! pngenc ! multifilesink location=frame%03d.png <br class=""><div class=""><br class=""></div><div class="">However, if I use FFmpeg like this, the frames get saved fine:</div><div class=""><br class=""></div><div class="">ffmpeg -r 30 -an -protocol_whitelist file,udp,rtp -i video.sdp frame%3d.png</div><div class=""><br class=""></div><div class="">Here is the SDP:</div><div class=""><br class=""></div><div class=""><div class="">v=0</div><div class="">o=- 0 0 IN IP4 127.0.0.1</div><div class="">s=iProov HTML5 Client</div><div class="">c=IN IP4 127.0.0.1</div><div class="">t=0 0</div><div class="">m=video 55002 RTP/AVP 96</div><div class="">a=rtpmap:96 H264/90000</div><div class="">a=fmtp:96 packetization-mode=1</div></div><div class=""><br class=""></div><div class="">I have saved a copy of the RTP stream using rtpdump:</div><div class=""><br class=""></div><div class=""><a href="https://www.cs.columbia.edu/irt/software/rtptools/" class="">https://www.cs.columbia.edu/irt/software/rtptools/</a></div><div class=""><br class=""></div><div class="">This allows the stream to be replayed with rtpplay:</div><div class=""><br class=""></div><div class="">rtpplay -v -T -f video.rtp localhost/55002</div><div class=""><br class=""></div><div class="">And here is the rtp dump file I am using:</div><div class=""><br class=""></div><div class=""><a href="https://drive.google.com/file/d/1j3yrYP00RxHTWobD450Ar3fzO8ZIQuas/view?usp=sharing" class="">https://drive.google.com/file/d/1j3yrYP00RxHTWobD450Ar3fzO8ZIQuas/view?usp=sharing</a></div><div class=""><br class=""></div><div class="">Restreaming this file in this way to FFmpeg works great but to Gstreamer produces corrupted frames with the above commands. </div><div class=""><br class=""></div><div class="">If I turn up the RTP log level, I see many "illegal short term buffer state detected" errors like this:</div><div class=""><br class=""></div><div class=""><div class="">0:00:07.425906669 31333      0x27669e0 DEBUG        rtpjitterbuffer gstrtpjitterbuffer.c:3055:gst_rtp_jitter_buffer_chain:<rtpjitterbuffer0> expected #70, got #70, gap of 0</div><div class="">0:00:07.425939062 31333      0x27669e0 DEBUG        rtpjitterbuffer gstrtpjitterbuffer.c:3084:gst_rtp_jitter_buffer_chain:<rtpjitterbuffer0> Clearing gap packets</div><div class="">0:00:07.425968309 31333      0x27669e0 DEBUG        rtpjitterbuffer gstrtpjitterbuffer.c:3230:gst_rtp_jitter_buffer_chain:<rtpjitterbuffer0> Pushed packet #70, now 10 packets, head: 0, percent -1</div><div class="">0:00:07.430274718 31333      0x27669e0 DEBUG        rtpjitterbuffer gstrtpjitterbuffer.c:2957:gst_rtp_jitter_buffer_chain:<rtpjitterbuffer0> Received packet #71 at time 0:00:07.370746462, discont 0, rtx 0</div></div><div class=""><div class="">0:00:07.430316978 31333      0x27669e0 LOG          rtpjitterbuffer gstrtpjitterbuffer.c:2662:calculate_jitter:<rtpjitterbuffer0> dtsdiff 0:00:00.004545914 rtptime 0:00:00.054000000, clock-rate 90000, diff 0:00:00.049454086, jitter: 0:00:00.050701297</div><div class="">0:00:07.430336648 31333      0x27669e0 DEBUG        rtpjitterbuffer gstrtpjitterbuffer.c:3055:gst_rtp_jitter_buffer_chain:<rtpjitterbuffer0> expected #71, got #71, gap of 0</div><div class="">0:00:07.430347687 31333      0x27669e0 DEBUG        rtpjitterbuffer gstrtpjitterbuffer.c:3084:gst_rtp_jitter_buffer_chain:<rtpjitterbuffer0> Clearing gap packets</div><div class="">0:00:07.430368877 31333      0x27669e0 DEBUG        rtpjitterbuffer rtpjitterbuffer.c:785:rtp_jitter_buffer_calculate_pts: extrtp 306540, gstrtp 0:00:03.406000000, base 0:00:02.651000000, send_diff 0:00:00.755000000</div><div class="">0:00:07.430388707 31333      0x27669e0 DEBUG        rtpjitterbuffer rtpjitterbuffer.c:563:calculate_skew: time 0:00:07.370746462, base 0:00:07.248430817, recv_diff 0:00:00.122315645, slope 49</div><div class="">0:00:07.430401151 31333      0x27669e0 DEBUG        rtpjitterbuffer rtpjitterbuffer.c:580:calculate_skew: filling 2, delta -632684355</div><div class="">0:00:07.430415334 31333      0x27669e0 DEBUG        rtpjitterbuffer rtpjitterbuffer.c:664:calculate_skew: skew -195415049, out 0:00:07.808015768</div><div class="">0:00:07.430424474 31333      0x27669e0 DEBUG        rtpjitterbuffer rtpjitterbuffer.c:916:rtp_jitter_buffer_calculate_pts: backwards timestamps, using previous time</div><div class="">0:00:07.430451918 31333      0x27669e0 DEBUG        rtpjitterbuffer gstrtpjitterbuffer.c:3230:gst_rtp_jitter_buffer_chain:<rtpjitterbuffer0> Pushed packet #71, now 11 packets, head: 0, percent -1</div><div class="">0:00:07.464803911 31333      0x26d80a0 DEBUG        rtpjitterbuffer gstrtpjitterbuffer.c:3517:pop_and_push_next:<rtpjitterbuffer0> Pushing buffer 61, dts 0:00:07.248430817, pts 0:00:07.248430817</div><div class="">0:00:07.464827595 31333      0x26d80a0 LOG         rtpbasedepayload gstrtpbasedepayload.c:359:gst_rtp_base_depayload_handle_buffer:<rtph264depay0> discont 0, seqnum 61, rtptime 238590, pts 0:00:07.248430817, dts 0:00:07.248430817</div><div class="">0:00:07.464837300 31333      0x26d80a0 DEBUG           rtph264depay gstrtph264depay.c:1026:gst_rtp_h264_depay_process:<rtph264depay0> receiving 811 bytes</div><div class="">0:00:07.464843846 31333      0x26d80a0 DEBUG           rtph264depay gstrtph264depay.c:1046:gst_rtp_h264_depay_process:<rtph264depay0> NRI 1, Type 24</div><div class="">0:00:07.464853441 31333      0x26d80a0 DEBUG           rtph264depay gstrtph264depay.c:844:gst_rtp_h264_depay_handle_nal:<rtph264depay0> handle NAL type 1</div><div class="">0:00:07.464859635 31333      0x26d80a0 DEBUG           rtph264depay gstrtph264depay.c:904:gst_rtp_h264_depay_handle_nal:<rtph264depay0> start 1, complete 1</div><div class="">0:00:07.464864758 31333      0x26d80a0 DEBUG           rtph264depay gstrtph264depay.c:913:gst_rtp_h264_depay_handle_nal:<rtph264depay0> adding NAL to picture adapter</div><div class="">0:00:07.464873130 31333      0x26d80a0 DEBUG           rtph264depay gstrtph264depay.c:844:gst_rtp_h264_depay_handle_nal:<rtph264depay0> handle NAL type 1</div><div class="">0:00:07.464878908 31333      0x26d80a0 DEBUG           rtph264depay gstrtph264depay.c:904:gst_rtp_h264_depay_handle_nal:<rtph264depay0> start 1, complete 0</div><div class="">0:00:07.464884010 31333      0x26d80a0 DEBUG           rtph264depay gstrtph264depay.c:913:gst_rtp_h264_depay_handle_nal:<rtph264depay0> adding NAL to picture adapter</div><div class="">0:00:07.464895585 31333      0x26d80a0 DEBUG        rtpjitterbuffer gstrtpjitterbuffer.c:3517:pop_and_push_next:<rtpjitterbuffer0> Pushing buffer 62, dts 0:00:07.248753067, pts 0:00:07.248430817</div><div class="">0:00:07.464906056 31333      0x26d80a0 LOG         rtpbasedepayload gstrtpbasedepayload.c:359:gst_rtp_base_depayload_handle_buffer:<rtph264depay0> discont 0, seqnum 62, rtptime 238590, pts 0:00:07.248430817, dts 0:00:07.248753067</div><div class="">0:00:07.464912715 31333      0x26d80a0 DEBUG           rtph264depay gstrtph264depay.c:1026:gst_rtp_h264_depay_process:<rtph264depay0> receiving 1058 bytes</div><div class="">0:00:07.464918633 31333      0x26d80a0 DEBUG           rtph264depay gstrtph264depay.c:1046:gst_rtp_h264_depay_process:<rtph264depay0> NRI 1, Type 24</div><div class="">0:00:07.464925747 31333      0x26d80a0 DEBUG           rtph264depay gstrtph264depay.c:844:gst_rtp_h264_depay_handle_nal:<rtph264depay0> handle NAL type 1</div><div class="">0:00:07.464930885 31333      0x26d80a0 DEBUG           rtph264depay gstrtph264depay.c:913:gst_rtp_h264_depay_handle_nal:<rtph264depay0> adding NAL to picture adapter</div><div class="">0:00:07.464936129 31333      0x26d80a0 DEBUG           rtph264depay gstrtph264depay.c:778:gst_rtp_h264_complete_au:<rtph264depay0> taking completed AU</div><div class="">0:00:07.464941830 31333      0x26d80a0 LOG             rtph264depay gstrtph264depay.c:756:gst_rtp_h264_depay_allocate_output_buffer:<rtph264depay0> want output buffer of 1458 bytes</div><div class="">0:00:07.466015023 31333      0x26d80a0 DEBUG           rtph264depay gstrtph264depay.c:844:gst_rtp_h264_depay_handle_nal:<rtph264depay0> handle NAL type 1</div><div class="">0:00:07.466031013 31333      0x26d80a0 DEBUG           rtph264depay gstrtph264depay.c:913:gst_rtp_h264_depay_handle_nal:<rtph264depay0> adding NAL to picture adapter</div><div class="">0:00:07.466037063 31333      0x26d80a0 DEBUG           rtph264depay gstrtph264depay.c:778:gst_rtp_h264_complete_au:<rtph264depay0> taking completed AU</div><div class="">0:00:07.466043230 31333      0x26d80a0 LOG             rtph264depay gstrtph264depay.c:756:gst_rtp_h264_depay_allocate_output_buffer:<rtph264depay0> want output buffer of 417 bytes</div><div class="">0:00:07.466361384 31333      0x26d80a0 ERROR                  libav :0:: illegal short term buffer state detected</div></div><div class=""><br class=""></div><div class="">I have tried changing many different properties of rtpjitterbuffer but it has no effect.</div><div class=""><br class=""></div><div class="">Does anyone know why this is happening? Is there a problem with my pipeline or could this be a bug (I am using GStreamer v1.14.4)?</div><div class=""><br class=""></div><div class="">Any help would be greatly appreciated as I have already spend a long time trying to solve this.</div><div class=""><br class=""></div><div class="">Thanks</div></div><pre>_______________________________________________</pre><pre>gstreamer-devel mailing list</pre><a href="mailto:gstreamer-devel@lists.freedesktop.org"><pre>gstreamer-devel@lists.freedesktop.org</pre></a><pre><br></pre><a href="https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel"><pre>https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel</pre></a><pre><br></pre></blockquote></body></html>