summaryrefslogtreecommitdiffstats
path: root/ext/ladspa
diff options
context:
space:
mode:
Diffstat (limited to 'ext/ladspa')
-rw-r--r--ext/ladspa/gstladspa.c67
-rw-r--r--ext/ladspa/gstladspa.h7
2 files changed, 43 insertions, 31 deletions
diff --git a/ext/ladspa/gstladspa.c b/ext/ladspa/gstladspa.c
index 0f1982f8..56986b2e 100644
--- a/ext/ladspa/gstladspa.c
+++ b/ext/ladspa/gstladspa.c
@@ -113,6 +113,7 @@ gst_ladspa_base_init (GstLADSPAClass * klass)
klass->numsrcpads++;
}
+ g_free (name);
gst_element_class_add_pad_template (element_class, templ);
}
}
@@ -416,6 +417,22 @@ gst_ladspa_init (GstLADSPA * ladspa)
ladspa->controls = g_new (gfloat, oclass->numcontrols);
ladspa->dpman = gst_dpman_new ("ladspa_dpman", GST_ELEMENT (ladspa));
+ if (oclass->numsinkpads > 0) {
+ ladspa->data_in = g_new0 (LADSPA_Data *, oclass->numsinkpads);
+ ladspa->buffers_in = g_new0 (GstBuffer *, oclass->numsinkpads);
+ } else {
+ ladspa->data_in = NULL;
+ ladspa->buffers_in = NULL;
+ }
+
+ if (oclass->numsrcpads > 0) {
+ ladspa->buffers_out = g_new0 (GstBuffer *, oclass->numsrcpads);
+ ladspa->data_out = g_new0 (LADSPA_Data *, oclass->numsrcpads);
+ } else {
+ ladspa->buffers_out = NULL;
+ ladspa->data_out = NULL;
+ }
+
/* set up pads */
sinkcount = 0;
srccount = 0;
@@ -524,7 +541,8 @@ gst_ladspa_link (GstPad * pad, const GstCaps * caps)
/* if this fails in some other plugin, the graph is left in an inconsistent
state */
for (l = gst_element_get_pad_list (element); l; l = l->next)
- if (pad != (GstPad *) l->data)
+ if ((pad != (GstPad *) l->data)
+ && !GST_PAD_IS_NEGOTIATING ((GstPad *) l->data))
if (gst_pad_try_set_caps ((GstPad *) l->data, caps) <= 0)
return GST_PAD_LINK_REFUSED;
@@ -740,12 +758,10 @@ gst_ladspa_loop (GstElement * element)
numsinkpads = oclass->numsinkpads;
numsrcpads = oclass->numsrcpads;
-
- /* fixme: these mallocs need to die */
- data_in = g_new0 (LADSPA_Data *, numsinkpads);
- data_out = g_new0 (LADSPA_Data *, numsrcpads);
- buffers_in = g_new0 (GstBuffer *, numsinkpads);
- buffers_out = g_new0 (GstBuffer *, numsrcpads);
+ data_in = ladspa->data_in;
+ data_out = ladspa->data_out;
+ buffers_in = ladspa->buffers_in;
+ buffers_out = ladspa->buffers_out;
largest_buffer = -1;
@@ -775,7 +791,8 @@ gst_ladspa_loop (GstElement * element)
MIN (GST_BUFFER_SIZE (buffers_in[i]) / sizeof (gfloat),
largest_buffer);
data_in[i] = (LADSPA_Data *) GST_BUFFER_DATA (buffers_in[i]);
- GST_BUFFER_TIMESTAMP (buffers_in[i]) = ladspa->timestamp;
+ if (GST_CLOCK_TIME_IS_VALID (GST_BUFFER_TIMESTAMP (buffers_in[i])))
+ ladspa->timestamp = GST_BUFFER_TIMESTAMP (buffers_in[i]);
}
i = 0;
@@ -837,18 +854,12 @@ gst_ladspa_loop (GstElement * element)
ladspa->timestamp += ladspa->buffer_frames * GST_SECOND / ladspa->samplerate;
- /* FIXME: move these mallocs and frees to the state-change handler */
-
- g_free (buffers_out);
- g_free (buffers_in);
- g_free (data_out);
- g_free (data_in);
}
static void
gst_ladspa_chain (GstPad * pad, GstData * _data)
{
- GstBuffer *buffer_in = GST_BUFFER (_data);
+ GstBuffer *buffer_in;
LADSPA_Descriptor *desc;
LADSPA_Data *data_in, **data_out = NULL;
GstBuffer **buffers_out = NULL;
@@ -857,6 +868,10 @@ gst_ladspa_chain (GstPad * pad, GstData * _data)
GstLADSPA *ladspa;
GstLADSPAClass *oclass;
+ /* we shouldn't get events here... */
+ g_return_if_fail (GST_IS_BUFFER (_data));
+ buffer_in = GST_BUFFER (_data);
+
ladspa = (GstLADSPA *) GST_OBJECT_PARENT (pad);
oclass = (GstLADSPAClass *) (G_OBJECT_GET_CLASS (ladspa));
data_in = (LADSPA_Data *) GST_BUFFER_DATA (buffer_in);
@@ -864,19 +879,15 @@ gst_ladspa_chain (GstPad * pad, GstData * _data)
numsrcpads = oclass->numsrcpads;
desc = ladspa->descriptor;
- /* we shouldn't get events here... */
- g_return_if_fail (GST_IS_BUFFER (buffer_in));
-
- /* FIXME: this function shouldn't need to malloc() anything */
- if (numsrcpads > 0) {
- buffers_out = g_new (GstBuffer *, numsrcpads);
- data_out = g_new (LADSPA_Data *, numsrcpads);
- }
+ buffers_out = ladspa->buffers_out;
+ data_out = ladspa->data_out;
+ if (GST_CLOCK_TIME_IS_VALID (GST_BUFFER_TIMESTAMP (buffer_in)))
+ ladspa->timestamp = GST_BUFFER_TIMESTAMP (buffer_in);
i = 0;
if (!ladspa->inplace_broken && numsrcpads) {
/* reuse the first (chained) buffer */
- buffers_out[i] = buffer_in;
+ buffers_out[i] = gst_buffer_copy_on_write (buffer_in);
GST_DEBUG ("reuse: %d", GST_BUFFER_SIZE (buffer_in));
data_out[i] = data_in;
i++;
@@ -888,8 +899,7 @@ gst_ladspa_chain (GstPad * pad, GstData * _data)
data_out[i] = (LADSPA_Data *) GST_BUFFER_DATA (buffers_out[i]);
}
- GST_DPMAN_PREPROCESS (ladspa->dpman, num_samples,
- GST_BUFFER_TIMESTAMP (buffer_in));
+ GST_DPMAN_PREPROCESS (ladspa->dpman, num_samples, ladspa->timestamp);
num_processed = 0;
/* split up processing of the buffer into chunks so that dparams can
@@ -923,9 +933,6 @@ gst_ladspa_chain (GstPad * pad, GstData * _data)
GST_BUFFER_SIZE (buffers_out[i]), i);
gst_pad_push (ladspa->srcpads[i], GST_DATA (buffers_out[i]));
}
-
- g_free (buffers_out);
- g_free (data_out);
}
}
@@ -945,8 +952,8 @@ gst_ladspa_get (GstPad * pad)
/* 4096 is arbitrary */
buf = gst_buffer_new_and_alloc (4096);
- GST_BUFFER_TIMESTAMP (buf) = ladspa->timestamp;
data = (LADSPA_Data *) GST_BUFFER_DATA (buf);
+ GST_BUFFER_TIMESTAMP (buf) = ladspa->timestamp;
GST_DPMAN_PREPROCESS (ladspa->dpman, ladspa->buffer_frames,
ladspa->timestamp);
diff --git a/ext/ladspa/gstladspa.h b/ext/ladspa/gstladspa.h
index f3556f74..231871cd 100644
--- a/ext/ladspa/gstladspa.h
+++ b/ext/ladspa/gstladspa.h
@@ -59,10 +59,15 @@ struct _GstLADSPA {
GstPad **sinkpads,
**srcpads;
+ LADSPA_Data **data_in;
+ LADSPA_Data **data_out;
+ GstBuffer **buffers_in;
+ GstBuffer **buffers_out;
+
gboolean activated;
gint samplerate, buffer_frames;
- gint64 timestamp;
+ GstClockTime timestamp;
gboolean inplace_broken;
};