From: Jan Schmidt Date: Thu, 2 Jan 2014 15:18:20 +0000 (+1100) Subject: audiobasesrc: Avoid unnecessary configuration X-Git-Tag: 1.19.3~511^2~4820 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=f0b655e1ad2af1d1d6c1944a63e1b7040c1e0251;p=platform%2Fupstream%2Fgstreamer.git audiobasesrc: Avoid unnecessary configuration Port a change from audiobasesink from def07410, to ignore setcaps when the caps don't actually change, and avoid a reconfiguration and reset of the ringbuffer in that case. --- diff --git a/gst-libs/gst/audio/gstaudiobasesrc.c b/gst-libs/gst/audio/gstaudiobasesrc.c index db2f462..872116b 100644 --- a/gst-libs/gst/audio/gstaudiobasesrc.c +++ b/gst-libs/gst/audio/gstaudiobasesrc.c @@ -536,11 +536,17 @@ gst_audio_base_src_setcaps (GstBaseSrc * bsrc, GstCaps * caps) GstAudioRingBufferSpec *spec; gint bpf, rate; + spec = &src->ringbuffer->spec; + + if (G_UNLIKELY (spec->caps && gst_caps_is_equal (spec->caps, caps))) { + GST_DEBUG_OBJECT (src, + "Ringbuffer caps haven't changed, skipping reconfiguration"); + return TRUE; + } + GST_DEBUG ("release old ringbuffer"); gst_audio_ring_buffer_release (src->ringbuffer); - spec = &src->ringbuffer->spec; - spec->buffer_time = src->buffer_time; spec->latency_time = src->latency_time;