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:
Hans de Goede 2009-08-14 12:44:06 +01:00 committed by Tim-Philipp Müller
parent a3a61f8940
commit 10d41286d5

View file

@ -916,14 +916,15 @@ 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) {
GstClockTime latency;
latency = gst_util_uint64_scale_int (GST_SECOND, v4l2src->fps_d,
v4l2src->fps_n); v4l2src->fps_n);
if (timestamp > latency) if (timestamp > latency)
@ -931,6 +932,7 @@ gst_v4l2src_create (GstPushSrc * src, GstBuffer ** buf)
else else
timestamp = 0; timestamp = 0;
} }
}
/* FIXME: use the timestamp from the buffer itself! */ /* FIXME: use the timestamp from the buffer itself! */
GST_BUFFER_TIMESTAMP (*buf) = timestamp; GST_BUFFER_TIMESTAMP (*buf) = timestamp;