summaryrefslogtreecommitdiffstats
path: root/gst
diff options
context:
space:
mode:
Diffstat (limited to 'gst')
-rw-r--r--gst/flv/gstflvmux.c31
-rw-r--r--gst/flv/gstflvmux.h1
-rw-r--r--gst/flv/gstflvparse.c4
3 files changed, 28 insertions, 8 deletions
diff --git a/gst/flv/gstflvmux.c b/gst/flv/gstflvmux.c
index 401a0741..2a7c9169 100644
--- a/gst/flv/gstflvmux.c
+++ b/gst/flv/gstflvmux.c
@@ -59,7 +59,8 @@ static GstStaticPadTemplate audiosink_templ = GST_STATIC_PAD_TEMPLATE ("audio",
"audio/x-raw-int, endianness = (int) LITTLE_ENDIAN, channels = (int) { 1, 2 }, width = (int) 8, depth = (int) 8, rate = (int) { 5512, 11025, 22050, 44100 }, signed = (boolean) FALSE; "
"audio/x-raw-int, endianness = (int) LITTLE_ENDIAN, channels = (int) { 1, 2 }, width = (int) 16, depth = (int) 16, rate = (int) { 5512, 11025, 22050, 44100 }, signed = (boolean) TRUE; "
"audio/x-alaw, channels = (int) { 1, 2 }, rate = (int) { 5512, 11025, 22050, 44100 }; "
- "audio/x-mulaw, channels = (int) { 1, 2 }, rate = (int) { 5512, 11025, 22050, 44100 };")
+ "audio/x-mulaw, channels = (int) { 1, 2 }, rate = (int) { 5512, 11025, 22050, 44100 }; "
+ "audio/x-speex, channels = (int) { 1, 2 }, rate = (int) { 5512, 11025, 22050, 44100 };")
);
GST_BOILERPLATE (GstFlvMux, gst_flv_mux, GstElement, GST_TYPE_ELEMENT);
@@ -313,6 +314,8 @@ gst_flv_mux_audio_pad_setcaps (GstPad * pad, GstCaps * caps)
cpad->audio_codec = 7;
} else if (strcmp (gst_structure_get_name (s), "audio/x-mulaw") == 0) {
cpad->audio_codec = 8;
+ } else if (strcmp (gst_structure_get_name (s), "audio/x-speex") == 0) {
+ cpad->audio_codec = 11;
} else {
ret = FALSE;
}
@@ -456,6 +459,8 @@ gst_flv_mux_request_new_pad (GstElement * element,
cpad->sent_codec_data = FALSE;
+ cpad->last_timestamp = 0;
+
/* FIXME: hacked way to override/extend the event function of
* GstCollectPads; because it sets its own event function giving the
* element no access to events.
@@ -521,8 +526,11 @@ gst_flv_mux_write_buffer (GstFlvMux * mux, GstFlvPad * cpad)
guint size;
GstBuffer *buffer =
gst_collect_pads_pop (mux->collect, (GstCollectData *) cpad);
- guint32 timestamp = GST_BUFFER_TIMESTAMP (buffer) / GST_MSECOND;
+ guint32 timestamp =
+ (GST_BUFFER_TIMESTAMP_IS_VALID (buffer)) ? GST_BUFFER_TIMESTAMP (buffer) /
+ GST_MSECOND : cpad->last_timestamp / GST_MSECOND;
gboolean second_run = FALSE;
+ GstFlowReturn ret;
next:
size = 11;
@@ -617,8 +625,6 @@ next:
gst_buffer_set_caps (tag, GST_PAD_CAPS (mux->srcpad));
if (second_run) {
- GstFlowReturn ret;
-
second_run = FALSE;
cpad->sent_codec_data = TRUE;
@@ -628,6 +634,8 @@ next:
return ret;
}
+ cpad->last_timestamp = timestamp;
+
tag = NULL;
goto next;
}
@@ -638,7 +646,12 @@ next:
gst_buffer_unref (buffer);
- return gst_pad_push (mux->srcpad, tag);
+ ret = gst_pad_push (mux->srcpad, tag);
+
+ if (ret == GST_FLOW_OK)
+ cpad->last_timestamp = timestamp;
+
+ return ret;
}
static GstFlowReturn
@@ -684,11 +697,13 @@ gst_flv_mux_collected (GstCollectPads * pads, gpointer user_data)
time = GST_BUFFER_TIMESTAMP (buffer);
gst_buffer_unref (buffer);
+ /* Use buffers without valid timestamp first */
if (!GST_CLOCK_TIME_IS_VALID (time)) {
- GST_WARNING_OBJECT (pads, "Buffer without valid timestamp, dropping");
+ GST_WARNING_OBJECT (pads, "Buffer without valid timestamp");
- gst_buffer_unref (gst_collect_pads_pop (pads, (GstCollectData *) cpad));
- continue;
+ best_time = cpad->last_timestamp;
+ best = cpad;
+ break;
}
diff --git a/gst/flv/gstflvmux.h b/gst/flv/gstflvmux.h
index 9ec0e5df..c0af8e8f 100644
--- a/gst/flv/gstflvmux.h
+++ b/gst/flv/gstflvmux.h
@@ -53,6 +53,7 @@ typedef struct
GstBuffer *video_codec_data;
gboolean sent_codec_data;
+ GstClockTime last_timestamp;
} GstFlvPad;
typedef enum
diff --git a/gst/flv/gstflvparse.c b/gst/flv/gstflvparse.c
index 87d7f689..d9cdb239 100644
--- a/gst/flv/gstflvparse.c
+++ b/gst/flv/gstflvparse.c
@@ -442,6 +442,10 @@ gst_flv_parse_audio_negotiate (GstFLVDemux * demux, guint32 codec_tag,
caps = gst_caps_new_simple ("audio/x-mulaw", NULL);
codec_name = "Mu-Law";
break;
+ case 11:
+ caps = gst_caps_new_simple ("audio/x-speex", NULL);
+ codec_name = "Speex";
+ break;
default:
GST_WARNING_OBJECT (demux, "unsupported audio codec tag %u", codec_tag);
}