Search code examples
video-streaminggstreamerh.264

WebRTC H.264 no picture with x264enc


I am trying to stream some video to a browser using WebRTC. To accomplish this, I have a gstreamer instance that encodes the video and sends it to a server via RTP which simply packs it into WebRTC to display. If I use VP8 (vp8enc), this works as expected. However, when using H.264, my browser does not decode any frames:

gst-launch-1.0 videotestsrc ! videoscale ! video/x-raw,width=640,height=360 ! x264enc ! rtph264pay ! udpsink host=127.0.0.1 port=6001 # < my forwarding server

Furthermore, if I run my pipeline on my Khadas VIM4 and use its hardware H.264 encoder (amlvenc) instead of x264 with the exact same pipeline otherwise, the video is displayed (at least in Firefox).

What could be the difference between these two encoders (which both output H.264 video), or how could I find the cause for this problem? I tried looking through the browser WebRTC debugging pages, but this did not really help me...


Solution

  • Most likely the problem is coming from SPS/PPS not being sent with each IDR frame from x264enc, whereas amlvenc most likely does that by default.

    There are 2 things you can try adjusting if this is the case:

    1. set config-interval=-1 on your rtph264pay. See documentation of config-interval.
    2. force x264enc to emit SPS/PPS with each IDR frame. It seems that this option is not directly exposed via gstreamer options, but you can try setting the underlying x264 option named repeat-headers via option-string. So try adding option-string=\"repeat-headers=1\" to your x264enc node. See option-string and the relevant x264 option repeat-headers

    I think either of these should help, if not, then you can also inspect the a=fmtp:96 profile-level-id=42e01f; packetization-mode=1 line in the SDP to see if both encoders use drastically different profiles, but i don't think this should be the case.