GStreamer SRT + rtpstreamdepay + rtpptdemux останавливается с сообщением «потоковая передача остановлена, причина не свяC++

Программы на C++. Форум разработчиков
Ответить
Anonymous
 GStreamer SRT + rtpstreamdepay + rtpptdemux останавливается с сообщением «потоковая передача остановлена, причина не свя

Сообщение Anonymous »

Я осуществляю потоковую передачу RTP через SRT через приложение C++. Несколько типов полезной нагрузки RTP (видео H264 + приложение/метаданные) используются через SRT с использованием rtpstreampay на стороне отправителя.

Теперь я хочу демультиплексировать по типу полезной нагрузки RTP с помощью gst-launch-1.0.
SDP нет; поток пакетируется с использованием rtpstreampay / rtpstreamdepay.
Сведения об отправителе:

Видео передается по протоколу RTP/H264 с использованием rtph264pay pt=96 config-interval=1 (тактовая частота 90000).

Метаданные отправляются с использованием rtpgstpay pt=97 (тактовая частота) 90000, кодовое имя X-GST).

Обе ветки объединены через воронку! rtpstreampay ! srtsink.
Конвейер получателя
gst-launch-1.0 -v \
srtsrc uri="srt://127.0.0.1:9000?mode=listener" \
! "application/x-rtp-stream" \
! rtpstreamdepay \
! rtpptdemux name=demux \
demux.src_97 \
! queue max-size-buffers=2 leaky=downstream \
! "application/x-rtp,media=application,encoding-name=X-GST,payload=97,clock-rate=90000" \
! rtpgstdepay \
! fakesink dump=true sync=true

Вывод/ошибка выполнения
Use Windows high-resolution clock, precision: 1 ms
Setting pipeline to PAUSED ...
Pipeline is live and does not need PREROLL ...
Pipeline is PREROLLED ...
Setting pipeline to PLAYING ...
New clock: GstSystemClock
/GstPipeline:pipeline0/GstCapsFilter:capsfilter0.GstPad:src: caps = application/x-rtp-stream
ERROR: from element /GstPipeline:pipeline0/GstSRTSrc:srtsrc0: Internal data stream error.
/GstPipeline:pipeline0/GstRtpStreamDepay:rtpstreamdepay0.GstPad:src: caps = application/x-rtp
Additional debug info:
../libs/gst/base/gstbasesrc.c(3187): gst_base_src_loop ():
/GstPipeline:pipeline0/GstSRTSrc:srtsrc0:
streaming stopped, reason not-linked (-1)
/GstPipeline:pipeline0/GstRtpPtDemux:demux.GstPad:sink: caps = application/x-rtp
Details:
details, flow-return=(int)-1;
Execution ended after 0:00:00.306006000

Получатель получает данные (конвейер достигает PLAYING), но сразу же происходит сбой при запуске потоковой передачи. Я связал только demux.src_97, потому что в настоящее время видеопоток мне не нужен.
Если я удалю rtpptdemux и напрямую выгружу поток метаданных, я смогу успешно получать и сбрасывать метаданные:
gst-launch-1.0 -v \
srtsrc uri="srt://127.0.0.1:9000?mode=listener" \
! "application/x-rtp-stream" \
! rtpstreamdepay \
! "application/x-rtp,media=application,encoding-name=X-GST,payload=97,clock-rate=90000" \
! rtpgstdepay \
! fakesink dump=true sync=true


Подробнее здесь: https://stackoverflow.com/questions/798 ... pped-reaso
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C++»