Ffmpeg works but gstreamer does not work for rtsp camera
Olivier Crête
olivier.crete at collabora.com
Wed Jan 6 15:53:14 UTC 2021
Hi,
You may want to try with rtspt:// as a URL, this will force rtspsrc to
use the TCP transport (analog to -rtsp_transport tcp in ffmpeg).
Olivier
On Tue, 2021-01-05 at 19:08 -0600, jinmc wrote:
> I’m using Nvidia Jetson Tx2 device.
>
> With the following command, I can connect and capture an image with
> ffmpeg.
>
> $/usr/bin/ffmpeg -y -frames 1 snapshot.png -rtsp_transport tcp -i
> rtsp://admin:admin@192.168.10.132/1/profile
> ffmpeg version 3.4.8-0ubuntu0.2 Copyright (c) 2000-2020 the FFmpeg
> developers
> built with gcc 7 (Ubuntu/Linaro 7.5.0-3ubuntu1~18.04)
> configuration: --prefix=/usr --extra-version=0ubuntu0.2
> --toolchain=hardened --libdir=/usr/lib/aarch64-linux-gnu
> --incdir=/usr/include/aarch64-linux-gnu --enable-gpl --disable-
> stripping
> --enable-avresample --enable-avisynth --enable-gnutls --enable-ladspa
> --enable-libass --enable-libbluray --enable-libbs2b --enable-libcaca
> --enable-libcdio --enable-libflite --enable-libfontconfig
> --enable-libfreetype --enable-libfribidi --enable-libgme --enable-
> libgsm
> --enable-libmp3lame --enable-libmysofa --enable-libopenjpeg
> --enable-libopenmpt --enable-libopus --enable-libpulse
> --enable-librubberband --enable-librsvg --enable-libshine --enable-
> libsnappy
> --enable-libsoxr --enable-libspeex --enable-libssh --enable-libtheora
> --enable-libtwolame --enable-libvorbis --enable-libvpx --enable-
> libwavpack
> --enable-libwebp --enable-libx265 --enable-libxml2 --enable-libxvid
> --enable-libzmq --enable-libzvbi --enable-omx --enable-openal
> --enable-opengl --enable-sdl2 --enable-libdc1394 --enable-libdrm
> --enable-libiec61883 --enable-chromaprint --enable-frei0r --enable-
> libopencv
> --enable-libx264 --enable-shared
> libavutil 55. 78.100 / 55. 78.100
> libavcodec 57.107.100 / 57.107.100
> libavformat 57. 83.100 / 57. 83.100
> libavdevice 57. 10.100 / 57. 10.100
> libavfilter 6.107.100 / 6.107.100
> libavresample 3. 7. 0 / 3. 7. 0
> libswscale 4. 8.100 / 4. 8.100
> libswresample 2. 9.100 / 2. 9.100
> libpostproc 54. 7.100 / 54. 7.100
> Guessed Channel Layout for Input Stream #0.1 : mono
> Input #0, rtsp, from 'rtsp://admin:admin@192.168.10.131/1/profile':
> Metadata:
> title : SDP Descrption
> comment : SDP Description
> Duration: N/A, start: 0.000000, bitrate: N/A
> Stream #0:0: Video: h264 (High), yuvj420p(pc, bt709,
> progressive),
> 1920x1080, 25 fps, 30 tbr, 90k tbn, 50 tbc
> Stream #0:1: Audio: pcm_alaw, 8000 Hz, mono, s16, 64 kb/s
> Stream #0:2: Data: none
> Stream mapping:
> Stream #0:0 -> #0:0 (h264 (native) -> png (native))
> Press [q] to stop, [?] for help
> [swscaler @ 0x55a8f70c70] deprecated pixel format used, make sure you
> did
> set range correctly
> [swscaler @ 0x55a8f70c70] No accelerated colorspace conversion found
> from
> yuv420p to rgb24.
> Output #0, image2, to 'snapshot.png':
> Metadata:
> title : SDP Descrption
> comment : SDP Description
> encoder : Lavf57.83.100
> Stream #0:0: Video: png, rgb24, 1920x1080, q=2-31, 200 kb/s, 30
> fps, 30
> tbn, 30 tbc
> Metadata:
> encoder : Lavc57.107.100 png
> frame= 1 fps=0.0 q=-0.0 Lsize=N/A time=00:00:00.03 bitrate=N/A
> dup=1
> drop=1 speed=0.066x
> video:1982kB audio:0kB subtitle:0kB other streams:0kB global
> headers:0kB
> muxing overhead: unknown
>
>
> But with gstreamer, (I’m using version 1.14.5) I am not able to
> access the
> rtsp feed.
> I am pretty sure this is a Gstreamer issue because I can get the
> screenshot
> image when using ffmpeg.
>
>
> $gst-launch-1.0 uridecodebin
> uri=rtsp://admin:admin@192.168.10.131/1/profile
> ! fakesink
> Setting pipeline to PAUSED ...
> Pipeline is live and does not need PREROLL ...
> Progress: (open) Opening Stream
> Progress: (connect) Connecting to
> rtsp://admin:admin@192.168.10.131/1/profile
> Progress: (open) Retrieving server options
> Progress: (open) Retrieving media info
> Progress: (request) SETUP stream 0
> Progress: (request) SETUP stream 1
> Progress: (request) SETUP stream 2
> ERROR: from element
> /GstPipeline:pipeline0/GstURIDecodeBin:uridecodebin0/GstRTSPSrc:sourc
> e:
> Could not read from resource.
> Additional debug info:
> gstrtspsrc.c(5917): gst_rtsp_src_receive_response ():
> /GstPipeline:pipeline0/GstURIDecodeBin:uridecodebin0/GstRTSPSrc:sourc
> e:
> Could not receive message. (Timeout while waiting for server
> response)
> ERROR: pipeline doesn't want to preroll.
> Setting pipeline to PAUSED ...
> Setting pipeline to READY ...
> Setting pipeline to NULL ...
> Freeing pipeline ...
>
> I found this post that says that the ugly plugin might be the problem
> and
> uninstalled it but it still does not work. Reference Url :
> https://forums.developer.nvidia.com/t/rtsp-gstreamer-simple-recieve-and-store-in-file/157535/12
>
> Any help will be appreciated. Thanks!
>
>
>
>
> --
> Sent from: http://gstreamer-devel.966125.n4.nabble.com/
> _______________________________________________
> gstreamer-devel mailing list
> gstreamer-devel at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel
--
Olivier Crête
olivier.crete at collabora.com
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.freedesktop.org/archives/gstreamer-devel/attachments/20210106/69d3fa06/attachment-0001.htm>
More information about the gstreamer-devel
mailing list