- Frequently Asked Questions and Troubleshooting Guide
- App causes Jetson Orin Nano to freeze and reboot
- Using new gst-nvstreammux
- Git clone fails due to Gstreamer repo access error
- Application fails to work with mp4 stream
- Ctrl-C does not stop the app during engine file generation
- Application fails to create gst elements
- GStreamer debugging
- Application stuck with no playback
- Error on setting string field
- Pipeline unable to perform at real time
- Triton container problems with multi-GPU setup
- ModuleNotFoundError: No module named 'pyds'
Most of the DeepStream Python apps are written to use hardware encoders. The Jetson Orin Nano does not have any hardware encoders, so the app must be modified to use software encoders in the pipeline. Please see deepstream-test1-rtsp-out:
if codec == "H264":
encoder = Gst.ElementFactory.make("nvv4l2h264enc", "encoder")
if enc_type == 0: # HW encoder
encoder = Gst.ElementFactory.make("nvv4l2h264enc", "encoder")
else: # SW encoder
encoder = Gst.ElementFactory.make("x264enc", "encoder")
Most DeepStream Python apps are written to use the default nvstreammux and have lines of code written to set nvstreammux properties which are deprecated in the new gst-nvstreammux. See the DeepStream documentation for more information on the new gst-nvstreammux plugin. To use the new nvstreammux, set the USE_NEW_NVSTREAMMUX
environment variable before running the app. For example:
$ export USE_NEW_NVSTREAMMUX="yes"
$ python3 deepstream_test_1.py ../../../../samples/streams/sample_720p.h264
The app itself must be modified not to set deprecated properties when using the new nvstreammux. See deepstream-test1:
if os.environ.get('USE_NEW_NVSTREAMMUX') != 'yes': # Only set these properties if not using new gst-nvstreammux
streammux.set_property('width', 1920)
streammux.set_property('height', 1080)
streammux.set_property('batched-push-timeout', 4000000)
Running apps without this modification will result in such an error:
Traceback (most recent call last):
File "deepstream_test_1.py", line 255, in <module>
sys.exit(main(sys.argv))
File "deepstream_test_1.py", line 194, in main
streammux.set_property('width', 1920)
TypeError: object of type `GstNvStreamMux' does not have property `width'
If the following error is encountered while cloning:
fatal: unable to access 'https://gitlab.freedesktop.org/gstreamer/common.git/': server certificate verification failed. CAfile: /etc/ssl/certs/ca-certificates.crt CRLfile: none
fatal: clone of 'https://gitlab.freedesktop.org/gstreamer/common.git' into submodule path '/opt/nvidia/deepstream/deepstream/sources/ds_python/3rdparty/gst-python/common' failed
Temporarily disable git SSL verification by:
export GIT_SSL_NO_VERIFY=true
before cloning the repo. Unset the variable after cloning.
Deepstream-test1,2 and 4 apps only work with H264 elementary streams such as sample_720p.h264 provided with the DeepStream SDK. These include test apps 1, 2 and 4. Attempting to use other such types of streams will result in the following error:
Error: gst-stream-error-quark: Internal data stream error. (1): gstbaseparse.c(3611): gst_base_parse_loop (): /GstPipeline:pipeline0/GstH264Parse:h264-parser:
streaming stopped, reason not-negotiated (-4)
Deepstream-test3 supports various stream types including mp4 and RTSP. Please see the app README for usage.
This is a limitation of Python signal handling:
https://docs.python.org/3/library/signal.html
"A long-running calculation implemented purely in C (such as regular expression matching on a large body of text) may run uninterrupted for an arbitrary amount of time, regardless of any signals received. The Python signal handlers will be called when the calculation finishes."
To work around this:
- Use ctrl-z to bg the process
- Optionally run "jobs" if there are potentially multiple bg processes:
$ jobs [1]- Stopped python3 deepstream_test_1.py /opt/nvidia/deepstream/deepstream/samples/streams/sample_720p.h264 (wd: /opt/nvidia/deepstream/deepstream-4.0/sources/apps/python/deepstream-test1) [2]+ Stopped python3 deepstream_test_2.py /opt/nvidia/deepstream/deepstream/samples/streams/sample_720p.h264 - Kill the bg job:
$ kill %<job number, 1 or 2 from above. e.g. kill %1>
As with DeepStream SDK, if the application runs into errors, cannot create gst elements, try again after removing gstreamer cache:
rm ${HOME}/.cache/gstreamer-1.0/registry.x86_64.bin
General GStreamer debugging: set debug level on the command line:
GST_DEBUG=<level> python3 <app> [options]
The application appears to be stuck without any playback activity.
One possible cause is incompatible input type. Some of the sample apps only support H264 elementary streams.
terminate called after throwing an instance of 'pybind11::error_already_set'
what(): TypeError: (): incompatible function arguments. The following argument types are supported:
1. (arg0: pyds.<struct, e.g. NvDsEventMsgMeta>, arg1: str) -> None
Invoked with: <pyds.<struct, e.g. NvDsEventMsgMeta> object at 0x7ffa93d2fce0>, <int, e.g. 140710457366960>
This can happen if the string field is being set with another string field, e.g.:
dstmeta.sensorStr = srcmeta.sensorStr
Remember from the String Access section above that reading srcmeta.sensorStr
directly returns an int, not string.
The proper way to copy the string field in this case is:
dstmeta.sensorStr = pyds.get_string(srcmeta.sensorStr)
WARNING: A lot of buffers are being dropped. (13): gstbasesink.c(2902):
gst_base_sink_is_too_late (): /GstPipeline:pipeline0/GstEglGlesSink:nvvideo-renderer:
There may be a timestamping problem, or this computer is too slow.
Answer:
This could be thrown from any GStreamer app when the pipeline through-put is low
resulting in late buffers at the sink plugin.
This could be a hardware capability limitation or expensive software calls
that hinder pipeline buffer flow.
With python, there is a possibility for such an induced delay in software.
This is with regards to the probe() callbacks an user could leverage
for metadata extraction and other use-cases as demonstrated in our test-apps.
Please NOTE:
a) probe() callbacks are synchronous and thus holds the buffer
(info.get_buffer()) from traversing the pipeline until user return.
b) loops inside probe() callback could be costly in python.
The Triton Inference Server plugin currently only supports single-GPU usage.
When running the docker, please specify
--gpus device=<GPU ID>
e.g.: --gpus device=0
The pyds wheel installs the pyds.so library where all the pip packages are stored. Make sure the wheel installation succeeds and the pyds.so is present in the correct path (which should be /home//.local/lib/python/site-packages/pyds.so)
Command to install the pyds wheel is:
$ pip3 install ./pyds-1.2.0*.whl