summaryrefslogtreecommitdiffstats
path: root/gst/mpeg4videoparse
diff options
context:
space:
mode:
authorSjoerd Simons <sjoerd@luon.net>2008-06-02 07:37:31 +0000
committerSebastian Dröge <slomo@circular-chaos.org>2008-06-02 07:37:31 +0000
commitd0d99f937b45a655d3112bf75b60719557a4fa1c (patch)
tree9a0d21ea5f1fc9cac356ff8058ee4198032c79a4 /gst/mpeg4videoparse
parent2f38368c05ce6d7771c69b31ddf1fc14b91fce38 (diff)
downloadgst-plugins-bad-d0d99f937b45a655d3112bf75b60719557a4fa1c.tar.gz
gst-plugins-bad-d0d99f937b45a655d3112bf75b60719557a4fa1c.tar.bz2
gst-plugins-bad-d0d99f937b45a655d3112bf75b60719557a4fa1c.zip
gst/mpeg4videoparse/mpeg4videoparse.c: Fix mpeg4videoparse on big endian architectures. Fixes bug #536042.
Original commit message from CVS: Patch by: Sjoerd Simons <sjoerd at luon dot net> * gst/mpeg4videoparse/mpeg4videoparse.c: (gst_mpeg4vparse_handle_vos): Fix mpeg4videoparse on big endian architectures. Fixes bug #536042.
Diffstat (limited to 'gst/mpeg4videoparse')
-rw-r--r--gst/mpeg4videoparse/mpeg4videoparse.c24
1 files changed, 21 insertions, 3 deletions
diff --git a/gst/mpeg4videoparse/mpeg4videoparse.c b/gst/mpeg4videoparse/mpeg4videoparse.c
index ce027ee7..08790908 100644
--- a/gst/mpeg4videoparse/mpeg4videoparse.c
+++ b/gst/mpeg4videoparse/mpeg4videoparse.c
@@ -224,11 +224,17 @@ gst_mpeg4vparse_handle_vos (GstMpeg4VParse * parse, const guint8 * data,
{
/* Skip the startcode */
guint32 bits;
+
guint16 time_increment_resolution = 0;
+
guint16 fixed_time_increment = 0;
+
gint aspect_ratio_width = -1, aspect_ratio_height = -1;
+
gint height = -1, width = -1;
+
guint8 profile;
+
gboolean equal;
bitstream_t bs = { data, 0, 0, size };
@@ -264,7 +270,7 @@ gst_mpeg4vparse_handle_vos (GstMpeg4VParse * parse, const guint8 * data,
/* Expect Visual Object startcode */
GET_BITS (&bs, 32, &bits);
- if (GUINT32_FROM_LE (bits) != VISUAL_OBJECT_STARTCODE_MARKER)
+ if (bits != VISUAL_OBJECT_STARTCODE_MARKER)
goto failed;
GET_BITS (&bs, 1, &bits);
@@ -297,12 +303,12 @@ gst_mpeg4vparse_handle_vos (GstMpeg4VParse * parse, const guint8 * data,
/* expecting a video object startcode */
GET_BITS (&bs, 32, &bits);
- if (GUINT32_FROM_LE (bits) > 0x11F)
+ if (bits > 0x11F)
goto failed;
/* expecting a video object layer startcode */
GET_BITS (&bs, 32, &bits);
- if (GUINT32_FROM_LE (bits) < 0x120 || (GUINT32_FROM_LE (bits) > 0x12F))
+ if (bits < 0x120 || bits > 0x12F)
goto failed;
/* ignore random accessible vol and video object type indication */
@@ -422,7 +428,9 @@ static GstFlowReturn
gst_mpeg4vparse_drain (GstMpeg4VParse * parse, GstBuffer * last_buffer)
{
GstFlowReturn ret = GST_FLOW_OK;
+
const guint8 *data = NULL;
+
guint available = 0;
available = gst_adapter_available (parse->adapter);
@@ -523,6 +531,7 @@ static GstFlowReturn
gst_mpeg4vparse_chain (GstPad * pad, GstBuffer * buffer)
{
GstMpeg4VParse *parse = GST_MPEG4VIDEOPARSE (gst_pad_get_parent (pad));
+
GstFlowReturn ret = GST_FLOW_OK;
GST_DEBUG_OBJECT (parse, "received buffer of %u bytes with ts %"
@@ -544,8 +553,11 @@ static gboolean
gst_mpeg4vparse_sink_setcaps (GstPad * pad, GstCaps * caps)
{
gboolean res = TRUE;
+
GstMpeg4VParse *parse = GST_MPEG4VIDEOPARSE (gst_pad_get_parent (pad));
+
GstStructure *s;
+
const GValue *value;
GST_DEBUG_OBJECT (parse, "setcaps called with %" GST_PTR_FORMAT, caps);
@@ -572,6 +584,7 @@ static gboolean
gst_mpeg4vparse_sink_event (GstPad * pad, GstEvent * event)
{
gboolean res = TRUE;
+
GstMpeg4VParse *parse = GST_MPEG4VIDEOPARSE (gst_pad_get_parent (pad));
GST_DEBUG_OBJECT (parse, "handling event type %s",
@@ -601,6 +614,7 @@ static gboolean
gst_mpeg4vparse_src_query (GstPad * pad, GstQuery * query)
{
GstMpeg4VParse *parse = GST_MPEG4VIDEOPARSE (gst_pad_get_parent (pad));
+
gboolean res;
switch (GST_QUERY_TYPE (query)) {
@@ -609,7 +623,9 @@ gst_mpeg4vparse_src_query (GstPad * pad, GstQuery * query)
/* We need to send the query upstream and add the returned latency to our
* own */
GstClockTime min_latency, max_latency;
+
gboolean us_live;
+
GstClockTime our_latency;
if ((res = gst_pad_peer_query (parse->sinkpad, query))) {
@@ -662,6 +678,7 @@ static GstStateChangeReturn
gst_mpeg4vparse_change_state (GstElement * element, GstStateChange transition)
{
GstMpeg4VParse *parse = GST_MPEG4VIDEOPARSE (element);
+
GstStateChangeReturn ret;
ret = GST_ELEMENT_CLASS (parent_class)->change_state (element, transition);
@@ -736,6 +753,7 @@ static void
gst_mpeg4vparse_class_init (GstMpeg4VParseClass * klass)
{
GObjectClass *gobject_class;
+
GstElementClass *gstelement_class;
gstelement_class = (GstElementClass *) klass;