mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-04 22:48:49 +00:00
v4l2src: fix 'hang' with some cameras caused by bad timestamping if no framerate is available
For cameras/drivers that don't support e.g. VIDIOC_G_PARM we'd end up without a framerate and would try to divide by 0, causing run-time warnings and all frames to be timestamped with 0, which makes sinks that sync against the clock drop them, causing 'hangs' (observed with the pwc driver and a Logitech QuickCam Pro 4000). So if we do not know the framerate, simply don't adjust the timestamps. Fixes #591451.
This commit is contained in:
parent
a3a61f8940
commit
10d41286d5
1 changed files with 11 additions and 9 deletions
|
@ -916,20 +916,22 @@ gst_v4l2src_create (GstPushSrc * src, GstBuffer ** buf)
|
||||||
GST_OBJECT_UNLOCK (v4l2src);
|
GST_OBJECT_UNLOCK (v4l2src);
|
||||||
|
|
||||||
if (clock) {
|
if (clock) {
|
||||||
GstClockTime latency;
|
|
||||||
|
|
||||||
/* the time now is the time of the clock minus the base time */
|
/* the time now is the time of the clock minus the base time */
|
||||||
timestamp = gst_clock_get_time (clock) - timestamp;
|
timestamp = gst_clock_get_time (clock) - timestamp;
|
||||||
gst_object_unref (clock);
|
gst_object_unref (clock);
|
||||||
|
|
||||||
latency =
|
/* if we have a framerate adjust timestamp for frame latency */
|
||||||
gst_util_uint64_scale_int (GST_SECOND, v4l2src->fps_d,
|
if (v4l2src->fps_n > 0 && v4l2src->fps_d > 0) {
|
||||||
v4l2src->fps_n);
|
GstClockTime latency;
|
||||||
|
|
||||||
if (timestamp > latency)
|
latency = gst_util_uint64_scale_int (GST_SECOND, v4l2src->fps_d,
|
||||||
timestamp -= latency;
|
v4l2src->fps_n);
|
||||||
else
|
|
||||||
timestamp = 0;
|
if (timestamp > latency)
|
||||||
|
timestamp -= latency;
|
||||||
|
else
|
||||||
|
timestamp = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* FIXME: use the timestamp from the buffer itself! */
|
/* FIXME: use the timestamp from the buffer itself! */
|
||||||
|
|
Loading…
Reference in a new issue