diff options
-rw-r--r-- | ChangeLog | 11 | ||||
-rw-r--r-- | ext/ladspa/gstsignalprocessor.c | 94 |
2 files changed, 66 insertions, 39 deletions
@@ -1,3 +1,14 @@ +2007-01-12 Andy Wingo <wingo@pobox.com> + + * ext/ladspa/gstsignalprocessor.c (gst_signal_processor_fixate) + (gst_signal_processor_ouija_caps, gst_signal_processor_prepare): + Remove fixate/ouija stuff, thankfully, due to the new + part-negotiation.txt pull-mode negotiation scheme. + (gst_signal_processor_setcaps_pull) + (gst_signal_processor_setcaps): Implement upstream set_caps pull + proxying for pull mode. Now this works: ladspa-sine-fcac ! + audioconvert ! alsasink. + 2007-01-12 Edgard Lima <edgard.lima@indt.org.br> Patch by: Rosfran Borges <rosfran.borges@indt.org.br> diff --git a/ext/ladspa/gstsignalprocessor.c b/ext/ladspa/gstsignalprocessor.c index e0b92397..5c0fff83 100644 --- a/ext/ladspa/gstsignalprocessor.c +++ b/ext/ladspa/gstsignalprocessor.c @@ -156,7 +156,6 @@ static GstFlowReturn gst_signal_processor_getrange (GstPad * pad, static GstFlowReturn gst_signal_processor_chain (GstPad * pad, GstBuffer * buffer); static gboolean gst_signal_processor_setcaps (GstPad * pad, GstCaps * caps); -static void gst_signal_processor_fixate (GstPad * pad, GstCaps * caps); static void @@ -199,8 +198,6 @@ gst_signal_processor_add_pad_from_template (GstSignalProcessor * self, gst_pad_set_setcaps_function (new, GST_DEBUG_FUNCPTR (gst_signal_processor_setcaps)); - gst_pad_set_fixatecaps_function (new, - GST_DEBUG_FUNCPTR (gst_signal_processor_fixate)); if (templ->direction == GST_PAD_SINK) { GST_DEBUG ("added new sink pad"); @@ -373,12 +370,62 @@ gst_signal_processor_cleanup (GstSignalProcessor * self) } static gboolean +gst_signal_processor_setcaps_pull (GstSignalProcessor * self, GstPad * pad, + GstCaps * caps) +{ + if (GST_PAD_IS_SRC (pad)) { + GList *l; + + for (l = GST_ELEMENT (self)->sinkpads; l; l = l->next) + if (!gst_pad_set_caps (GST_PAD (l->data), caps)) + goto src_setcaps_failed; + } else { + GstPad *peer; + gboolean res; + + peer = gst_pad_get_peer (pad); + if (!peer) + goto unlinked_sink; + + res = gst_pad_set_caps (peer, caps); + gst_object_unref (peer); + + if (!res) + goto peer_setcaps_failed; + } + + return TRUE; + +src_setcaps_failed: + { + /* not logging, presumably the sink pad already logged */ + return FALSE; + } +unlinked_sink: + { + GST_WARNING_OBJECT (self, "unlinked sink pad %" GST_PTR_FORMAT ", I wonder " + "how we passed activate_pull()", pad); + return FALSE; + } +peer_setcaps_failed: + { + GST_INFO_OBJECT (self, "peer of %" GST_PTR_FORMAT " did not accept caps", + pad); + return FALSE; + } +} + +static gboolean gst_signal_processor_setcaps (GstPad * pad, GstCaps * caps) { GstSignalProcessor *self; self = GST_SIGNAL_PROCESSOR (gst_pad_get_parent (pad)); + if (self->mode == GST_ACTIVATE_PULL && !gst_caps_is_equal (caps, self->caps) + && !gst_signal_processor_setcaps_pull (self, pad, caps)) + goto setcaps_pull_failed; + /* the whole processor has one caps; if the sample rate changes, let subclass implementations know */ if (!gst_caps_is_equal (caps, self->caps)) { @@ -430,6 +477,11 @@ start_failed: gst_object_unref (self); return FALSE; } +setcaps_pull_failed: + { + gst_object_unref (self); + return FALSE; + } impossible: { g_critical ("something impossible happened"); @@ -438,14 +490,6 @@ impossible: } } -static void -gst_signal_processor_fixate (GstPad * pad, GstCaps * caps) -{ - /* last-ditch attempt at sanity */ - gst_structure_fixate_field_nearest_int - (gst_caps_get_structure (caps, 0), "rate", 44100); -} - static gboolean gst_signal_processor_event (GstPad * pad, GstEvent * event) { @@ -478,32 +522,6 @@ gst_signal_processor_event (GstPad * pad, GstEvent * event) return ret; } -static void -gst_signal_processor_ouija_caps (GstSignalProcessor * self) -{ - GstElement *element; - GstPad *srcpad; - GstCaps *srccaps, *peercaps, *caps; - - /* we have no sink pads, no way to know what caps we should be producing. - guess! */ - - element = GST_ELEMENT (self); - g_return_if_fail (element->sinkpads == NULL); - g_return_if_fail (element->srcpads != NULL); - srcpad = GST_PAD (element->srcpads->data); - - srccaps = gst_pad_get_caps (srcpad); - peercaps = gst_pad_peer_get_caps (srcpad); - caps = gst_caps_intersect (srccaps, peercaps); - gst_caps_unref (srccaps); - gst_caps_unref (peercaps); - gst_caps_truncate (caps); - gst_pad_fixate_caps (srcpad, caps); - gst_signal_processor_setcaps (srcpad, caps); - gst_caps_unref (caps); -} - static guint gst_signal_processor_prepare (GstSignalProcessor * self, guint nframes) { @@ -552,8 +570,6 @@ gst_signal_processor_prepare (GstSignalProcessor * self, guint nframes) } } - if (!self->caps) - gst_signal_processor_ouija_caps (self); g_return_val_if_fail (GST_SIGNAL_PROCESSOR_IS_RUNNING (self), 0); /* now allocate for any remaining outputs */ |