Revert "alsasrc: fail gracefully when ALSA does not give timestamps"

This reverts commit c7282a5718.
This commit is contained in:
Tim-Philipp Müller 2011-11-30 23:15:03 +00:00
parent d11849114c
commit 1290f7de0e
2 changed files with 5 additions and 36 deletions

View file

@ -254,63 +254,37 @@ gst_alsasrc_get_timestamp (GstAlsaSrc * src)
snd_htimestamp_t tstamp; snd_htimestamp_t tstamp;
GstClockTime timestamp; GstClockTime timestamp;
snd_pcm_uframes_t availmax; snd_pcm_uframes_t availmax;
gint64 offset;
GST_DEBUG_OBJECT (src, "Getting alsa timestamp!"); GST_DEBUG_OBJECT (src, "Getting alsa timestamp!");
if (!src) { if (!src) {
GST_ERROR_OBJECT (src, "No alsa handle created yet !"); GST_ERROR_OBJECT (src, "No alsa handle created yet !");
return GST_CLOCK_TIME_NONE; return 0;
} }
if (snd_pcm_status_malloc (&status) != 0) { if (snd_pcm_status_malloc (&status) != 0) {
GST_ERROR_OBJECT (src, "snd_pcm_status_malloc failed"); GST_ERROR_OBJECT (src, "snd_pcm_status_malloc failed");
return GST_CLOCK_TIME_NONE;
} }
if (snd_pcm_status (src->handle, status) != 0) { if (snd_pcm_status (src->handle, status) != 0) {
GST_ERROR_OBJECT (src, "snd_pcm_status failed"); GST_ERROR_OBJECT (src, "snd_pcm_status failed");
snd_pcm_status_free (status);
return GST_CLOCK_TIME_NONE;
} }
/* get high resolution time stamp from driver */ /* get high resolution time stamp from driver */
snd_pcm_status_get_htstamp (status, &tstamp); snd_pcm_status_get_htstamp (status, &tstamp);
timestamp = GST_TIMESPEC_TO_TIME (tstamp); timestamp = GST_TIMESPEC_TO_TIME (tstamp);
GST_DEBUG_OBJECT (src, "Base ts: %" GST_TIME_FORMAT,
GST_TIME_ARGS (timestamp));
if (timestamp == 0) {
/* This timestamp is supposed to represent the last sample, so 0 (which
can be returned on some ALSA setups (such as mine)) must mean that it
is invalid, unless there's just one sample, but we'll ignore that. */
GST_WARNING_OBJECT (src,
"No timestamp returned from snd_pcm_status_get_htstamp");
return GST_CLOCK_TIME_NONE;
}
/* Max available frames sets the depth of the buffer */ /* Max available frames sets the depth of the buffer */
availmax = snd_pcm_status_get_avail_max (status); availmax = snd_pcm_status_get_avail_max (status);
/* Compensate the fact that the timestamp references the last sample */ /* Compensate the fact that the timestamp references the last sample */
offset = -gst_util_uint64_scale_int (availmax * 2, GST_SECOND, src->rate); timestamp -= gst_util_uint64_scale_int (availmax * 2, GST_SECOND, src->rate);
/* Compensate for the delay until the package is available */ /* Compensate for the delay until the package is available */
offset += gst_util_uint64_scale_int (snd_pcm_status_get_delay (status), timestamp += gst_util_uint64_scale_int (snd_pcm_status_get_delay (status),
GST_SECOND, src->rate); GST_SECOND, src->rate);
snd_pcm_status_free (status); snd_pcm_status_free (status);
/* just in case, should not happen */
if (-offset > timestamp)
timestamp = 0;
else
timestamp -= offset;
/* Take first ts into account */
if (src->first_alsa_ts == GST_CLOCK_TIME_NONE) {
src->first_alsa_ts = timestamp;
}
timestamp -= src->first_alsa_ts;
GST_DEBUG_OBJECT (src, "ALSA timestamp : %" GST_TIME_FORMAT, GST_DEBUG_OBJECT (src, "ALSA timestamp : %" GST_TIME_FORMAT,
GST_TIME_ARGS (timestamp)); GST_TIME_ARGS (timestamp));
return timestamp; return timestamp;
@ -410,10 +384,8 @@ gst_alsasrc_create (GstBaseSrc * bsrc, guint64 offset, guint length,
ret = ret =
GST_BASE_SRC_CLASS (parent_class)->create (bsrc, offset, length, outbuf); GST_BASE_SRC_CLASS (parent_class)->create (bsrc, offset, length, outbuf);
if (asrc->driver_timestamps == TRUE && *outbuf) { if (asrc->driver_timestamps == TRUE && *outbuf) {
GstClockTime ts = gst_alsasrc_get_timestamp (asrc); GST_BUFFER_TIMESTAMP (*outbuf) =
if (GST_CLOCK_TIME_IS_VALID (ts)) { gst_alsasrc_get_timestamp ((GstAlsaSrc *) bsrc);
GST_BUFFER_TIMESTAMP (*outbuf) = ts;
}
} }
return ret; return ret;
@ -427,7 +399,6 @@ gst_alsasrc_init (GstAlsaSrc * alsasrc, GstAlsaSrcClass * g_class)
alsasrc->device = g_strdup (DEFAULT_PROP_DEVICE); alsasrc->device = g_strdup (DEFAULT_PROP_DEVICE);
alsasrc->cached_caps = NULL; alsasrc->cached_caps = NULL;
alsasrc->driver_timestamps = FALSE; alsasrc->driver_timestamps = FALSE;
alsasrc->first_alsa_ts = GST_CLOCK_TIME_NONE;
alsasrc->alsa_lock = g_mutex_new (); alsasrc->alsa_lock = g_mutex_new ();
} }
@ -972,7 +943,6 @@ gst_alsasrc_reset (GstAudioSrc * asrc)
GST_DEBUG_OBJECT (alsa, "prepare"); GST_DEBUG_OBJECT (alsa, "prepare");
CHECK (snd_pcm_prepare (alsa->handle), prepare_error); CHECK (snd_pcm_prepare (alsa->handle), prepare_error);
GST_DEBUG_OBJECT (alsa, "reset done"); GST_DEBUG_OBJECT (alsa, "reset done");
alsa->first_alsa_ts = GST_CLOCK_TIME_NONE;
GST_ALSA_SRC_UNLOCK (asrc); GST_ALSA_SRC_UNLOCK (asrc);
return; return;

View file

@ -65,7 +65,6 @@ struct _GstAlsaSrc {
guint channels; guint channels;
gint bytes_per_sample; gint bytes_per_sample;
gboolean driver_timestamps; gboolean driver_timestamps;
GstClockTime first_alsa_ts;
guint buffer_time; guint buffer_time;
guint period_time; guint period_time;