summaryrefslogtreecommitdiffstats
path: root/ext/faac
diff options
context:
space:
mode:
Diffstat (limited to 'ext/faac')
-rw-r--r--ext/faac/gstfaac.c50
1 files changed, 20 insertions, 30 deletions
diff --git a/ext/faac/gstfaac.c b/ext/faac/gstfaac.c
index 58b93716..96c650e6 100644
--- a/ext/faac/gstfaac.c
+++ b/ext/faac/gstfaac.c
@@ -81,8 +81,7 @@ static void gst_faac_get_property (GObject * object,
static GstPadLinkReturn
gst_faac_sinkconnect (GstPad * pad, const GstCaps * caps);
-static GstPadLinkReturn
-gst_faac_srcconnect (GstPad * pad, const GstCaps * caps);
+static GstPadLinkReturn gst_faac_srcconnect (GstPad * pad);
static void gst_faac_chain (GstPad * pad, GstData * data);
static GstElementStateReturn gst_faac_change_state (GstElement * element);
@@ -248,15 +247,15 @@ gst_faac_init (GstFaac * faac)
faac->sinkpad =
gst_pad_new_from_template (gst_static_pad_template_get (&sink_template),
"sink");
- gst_element_add_pad (GST_ELEMENT (faac), faac->sinkpad);
gst_pad_set_chain_function (faac->sinkpad, gst_faac_chain);
gst_pad_set_link_function (faac->sinkpad, gst_faac_sinkconnect);
+ gst_element_add_pad (GST_ELEMENT (faac), faac->sinkpad);
faac->srcpad =
gst_pad_new_from_template (gst_static_pad_template_get (&src_template),
"src");
+ gst_pad_use_explicit_caps (faac->srcpad);
gst_element_add_pad (GST_ELEMENT (faac), faac->srcpad);
- gst_pad_set_link_function (faac->srcpad, gst_faac_srcconnect);
/* default properties */
faac->bitrate = 1024 * 128;
@@ -326,37 +325,29 @@ gst_faac_sinkconnect (GstPad * pad, const GstCaps * caps)
/* if the other side was already set-up, redo that */
if (GST_PAD_CAPS (faac->srcpad))
- return gst_faac_srcconnect (faac->srcpad,
- gst_pad_get_allowed_caps (faac->srcpad));
+ return gst_faac_srcconnect (faac->srcpad);
/* else, that'll be done later */
return GST_PAD_LINK_OK;
}
static GstPadLinkReturn
-gst_faac_srcconnect (GstPad * pad, const GstCaps * caps)
+gst_faac_srcconnect (GstPad * pad)
{
GstFaac *faac = GST_FAAC (gst_pad_get_parent (pad));
+ GstCaps *caps;
gint n;
if (!faac->handle || (faac->samplerate == -1 || faac->channels == -1)) {
return GST_PAD_LINK_DELAYED;
}
- /* we do samplerate/channels ourselves */
- for (n = 0; n < gst_caps_get_size (caps); n++) {
- GstStructure *structure = gst_caps_get_structure (caps, n);
-
- gst_structure_remove_field (structure, "rate");
- gst_structure_remove_field (structure, "channels");
- }
-
/* go through list */
- caps = gst_caps_normalize (caps);
+ caps = gst_pad_get_allowed_caps (pad);
for (n = 0; n < gst_caps_get_size (caps); n++) {
GstStructure *structure = gst_caps_get_structure (caps, n);
faacEncConfiguration *conf;
- gint mpegversion = 0;
+ gint mpegversion = 4;
GstCaps *newcaps;
GstPadLinkReturn ret;
guint8 *c_data;
@@ -384,26 +375,26 @@ gst_faac_srcconnect (GstPad * pad, const GstCaps * caps)
"mpegversion", G_TYPE_INT, mpegversion,
"channels", G_TYPE_INT, faac->channels,
"rate", G_TYPE_INT, faac->samplerate, NULL);
- if (faacEncGetDecoderSpecificInfo (faac->handle, &c_data, &c_size) == 0) {
+ if ((ret =
+ faacEncGetDecoderSpecificInfo (faac->handle, &c_data,
+ &c_size)) == 0) {
GstBuffer *data = gst_buffer_new_and_alloc (c_size);
memcpy (GST_BUFFER_DATA (data), c_data, c_size);
gst_caps_set_simple (newcaps, "codec_data", GST_TYPE_BUFFER, data, NULL);
gst_buffer_unref (data);
}
- ret = gst_pad_try_set_caps (faac->srcpad, newcaps);
-
- switch (ret) {
- case GST_PAD_LINK_OK:
- case GST_PAD_LINK_DONE:
- return GST_PAD_LINK_DONE;
- case GST_PAD_LINK_DELAYED:
- return GST_PAD_LINK_DELAYED;
- default:
- break;
+ if (gst_pad_set_explicit_caps (faac->srcpad, newcaps)) {
+ gst_caps_free (caps);
+ gst_caps_free (newcaps);
+ return GST_PAD_LINK_OK;
}
+
+ gst_caps_free (newcaps);
}
+ gst_caps_free (caps);
+
return GST_PAD_LINK_REFUSED;
}
@@ -461,8 +452,7 @@ gst_faac_chain (GstPad * pad, GstData * data)
}
if (!GST_PAD_CAPS (faac->srcpad)) {
- if (gst_faac_srcconnect (faac->srcpad,
- gst_pad_get_allowed_caps (faac->srcpad)) <= 0) {
+ if (gst_faac_srcconnect (faac->srcpad) <= 0) {
GST_ELEMENT_ERROR (faac, CORE, NEGOTIATION, (NULL),
("failed to negotiate MPEG/AAC format with next element"));
gst_buffer_unref (inbuf);