mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-02-20 04:56:24 +00:00
ext/dirac/: Do something. Don't actually know if this works because I don't have a demuxer yet.
Original commit message from CVS: * ext/dirac/Makefile.am: * ext/dirac/gstdirac.cc: * ext/dirac/gstdiracdec.cc: * ext/dirac/gstdiracdec.h: Do something. Don't actually know if this works because I don't have a demuxer yet. * ext/gsm/gstgsmdec.c: (gst_gsmdec_getcaps): Add channels=1 to caps returned from _getcaps(). * ext/ogg/gstogmparse.c: (gst_ogm_audio_parse_get_type), (gst_ogm_video_parse_get_type), (gst_ogm_audio_parse_base_init), (gst_ogm_video_parse_base_init), (gst_ogm_parse_init), (gst_ogm_audio_parse_init), (gst_ogm_video_parse_init), (gst_ogm_parse_sink_convert), (gst_ogm_parse_chain), (gst_ogm_parse_change_state): Separate between audio/video so ogmaudioparse actually uses the audio pad templates. Both audio and video work now, including autoplugging. Also use sometimes-srcpad hack. * gst-libs/gst/riff/riff-read.c: (gst_riff_read_seek): Handle events better. Don't hang on infinite loops. * gst/avi/gstavidemux.c: (gst_avi_demux_class_init), (gst_avi_demux_init), (gst_avi_demux_reset), (gst_avi_demux_src_convert), (gst_avi_demux_handle_src_query), (gst_avi_demux_stream_header), (gst_avi_demux_stream_data), (gst_avi_demux_change_state): * gst/avi/gstavidemux.h: Improve A/V sync. Still not perfect. * gst/matroska/ebml-read.c: (gst_ebml_read_seek), (gst_ebml_read_skip): Handle events better. * gst/qtdemux/qtdemux.c: (gst_qtdemux_handle_sink_event), (gst_qtdemux_loop_header), (qtdemux_parse_trak), (qtdemux_audio_caps): Add IMA4. Improve event handling. Save offset after a seek when the headers are at the end of the file so that we don't end up in an infinite loop. * gst/typefind/gsttypefindfunctions.c: (qt_type_find): Add low-priority typefind support for files with no length.
This commit is contained in:
parent
18c8223577
commit
0771c17fed
8 changed files with 347 additions and 94 deletions
40
ChangeLog
40
ChangeLog
|
@ -1,3 +1,43 @@
|
||||||
|
2004-09-23 Ronald S. Bultje <rbultje@ronald.bitfreak.net>
|
||||||
|
|
||||||
|
* ext/dirac/Makefile.am:
|
||||||
|
* ext/dirac/gstdirac.cc:
|
||||||
|
* ext/dirac/gstdiracdec.cc:
|
||||||
|
* ext/dirac/gstdiracdec.h:
|
||||||
|
Do something. Don't actually know if this works because I don't
|
||||||
|
have a demuxer yet.
|
||||||
|
* ext/gsm/gstgsmdec.c: (gst_gsmdec_getcaps):
|
||||||
|
Add channels=1 to caps returned from _getcaps().
|
||||||
|
* ext/ogg/gstogmparse.c: (gst_ogm_audio_parse_get_type),
|
||||||
|
(gst_ogm_video_parse_get_type), (gst_ogm_audio_parse_base_init),
|
||||||
|
(gst_ogm_video_parse_base_init), (gst_ogm_parse_init),
|
||||||
|
(gst_ogm_audio_parse_init), (gst_ogm_video_parse_init),
|
||||||
|
(gst_ogm_parse_sink_convert), (gst_ogm_parse_chain),
|
||||||
|
(gst_ogm_parse_change_state):
|
||||||
|
Separate between audio/video so ogmaudioparse actually uses the
|
||||||
|
audio pad templates. Both audio and video work now, including
|
||||||
|
autoplugging. Also use sometimes-srcpad hack.
|
||||||
|
* gst-libs/gst/riff/riff-read.c: (gst_riff_read_seek):
|
||||||
|
Handle events better. Don't hang on infinite loops.
|
||||||
|
* gst/avi/gstavidemux.c: (gst_avi_demux_class_init),
|
||||||
|
(gst_avi_demux_init), (gst_avi_demux_reset),
|
||||||
|
(gst_avi_demux_src_convert), (gst_avi_demux_handle_src_query),
|
||||||
|
(gst_avi_demux_stream_header), (gst_avi_demux_stream_data),
|
||||||
|
(gst_avi_demux_change_state):
|
||||||
|
* gst/avi/gstavidemux.h:
|
||||||
|
Improve A/V sync. Still not perfect.
|
||||||
|
* gst/matroska/ebml-read.c: (gst_ebml_read_seek),
|
||||||
|
(gst_ebml_read_skip):
|
||||||
|
Handle events better.
|
||||||
|
* gst/qtdemux/qtdemux.c: (gst_qtdemux_handle_sink_event),
|
||||||
|
(gst_qtdemux_loop_header), (qtdemux_parse_trak),
|
||||||
|
(qtdemux_audio_caps):
|
||||||
|
Add IMA4. Improve event handling. Save offset after a seek when
|
||||||
|
the headers are at the end of the file so that we don't end up in
|
||||||
|
an infinite loop.
|
||||||
|
* gst/typefind/gsttypefindfunctions.c: (qt_type_find):
|
||||||
|
Add low-priority typefind support for files with no length.
|
||||||
|
|
||||||
2004-09-23 Zaheer Abbas Merali <zaheerabbas at merali dot org>
|
2004-09-23 Zaheer Abbas Merali <zaheerabbas at merali dot org>
|
||||||
|
|
||||||
* testsuite/multifilesink/Makefile.am:
|
* testsuite/multifilesink/Makefile.am:
|
||||||
|
|
|
@ -1,9 +1,12 @@
|
||||||
|
|
||||||
plugin_LTLIBRARIES = libgstdirac.la
|
plugin_LTLIBRARIES = libgstdirac.la
|
||||||
|
|
||||||
libgstdirac_la_SOURCES = gstdirac.cc gstdiracdec.cc
|
libgstdirac_la_SOURCES = \
|
||||||
#gstdiracenc.c
|
gstdirac.cc \
|
||||||
|
gstdiracdec.cc
|
||||||
|
|
||||||
libgstdirac_la_CXXFLAGS = $(GST_CFLAGS) $(DIRAC_CFLAGS)
|
libgstdirac_la_CXXFLAGS = $(GST_CFLAGS) $(DIRAC_CFLAGS)
|
||||||
libgstdirac_la_LIBADD = $(DIRAC_LIBS)
|
libgstdirac_la_LIBADD = $(DIRAC_LIBS) -lz -lm
|
||||||
libgstdirac_la_LDFLAGS = $(GST_PLUGIN_LDFLAGS)
|
libgstdirac_la_LDFLAGS = $(GST_PLUGIN_LDFLAGS)
|
||||||
|
|
||||||
|
noinst_HEADERS = \
|
||||||
|
gstdiracdec.h
|
||||||
|
|
|
@ -16,16 +16,14 @@
|
||||||
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
#ifdef HAVE_CONFIG_H
|
||||||
#include <config.h>
|
#include "config.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
||||||
|
#include "gstdiracdec.h"
|
||||||
extern GType gst_diracdec_get_type (void);
|
|
||||||
|
|
||||||
//extern GType gst_diracenc_get_type (void);
|
|
||||||
|
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
plugin_init (GstPlugin * plugin)
|
plugin_init (GstPlugin * plugin)
|
||||||
|
@ -38,7 +36,7 @@ plugin_init (GstPlugin * plugin)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (!gst_element_register (plugin, "diracdec", GST_RANK_PRIMARY,
|
if (!gst_element_register (plugin, "diracdec", GST_RANK_PRIMARY,
|
||||||
gst_diracdec_get_type ())) {
|
GST_TYPE_DIRACDEC)) {
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
/* GStreamer
|
/* GStreamer
|
||||||
* Copyright (C) 2004 David A. Schleef <ds@schleef.org>
|
* Copyright (C) 2004 David A. Schleef <ds@schleef.org>
|
||||||
|
* Copyright (C) 2004 Ronald S. Bultje <rbultje@ronald.bitfreak.net>
|
||||||
*
|
*
|
||||||
* This library is free software; you can redistribute it and/or
|
* This library is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU Library General Public
|
* modify it under the terms of the GNU Library General Public
|
||||||
|
@ -22,54 +23,19 @@
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <gst/gst.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include <gst/video/video.h>
|
#include <gst/video/video.h>
|
||||||
|
|
||||||
#include <libdirac_decoder/seq_decompress.h>
|
#include "gstdiracdec.h"
|
||||||
#include <libdirac_common/pic_io.h>
|
|
||||||
|
|
||||||
#define GST_TYPE_DIRACDEC \
|
|
||||||
(gst_diracdec_get_type())
|
|
||||||
#define GST_DIRACDEC(obj) \
|
|
||||||
(G_TYPE_CHECK_INSTANCE_CAST((obj),GST_TYPE_DIRACDEC,GstDiracDec))
|
|
||||||
#define GST_DIRACDEC_CLASS(klass) \
|
|
||||||
(G_TYPE_CHECK_CLASS_CAST((klass),GST_TYPE_DIRACDEC,GstDiracDec))
|
|
||||||
#define GST_IS_DIRACDEC(obj) \
|
|
||||||
(G_TYPE_CHECK_INSTANCE_TYPE((obj),GST_TYPE_DIRACDEC))
|
|
||||||
#define GST_IS_DIRACDEC_CLASS(obj) \
|
|
||||||
(G_TYPE_CHECK_CLASS_TYPE((klass),GST_TYPE_DIRACDEC))
|
|
||||||
|
|
||||||
typedef struct _GstDiracDec GstDiracDec;
|
|
||||||
typedef struct _GstDiracDecClass GstDiracDecClass;
|
|
||||||
|
|
||||||
struct _GstDiracDec
|
|
||||||
{
|
|
||||||
GstElement element;
|
|
||||||
|
|
||||||
/* pads */
|
|
||||||
GstPad *sinkpad, *srcpad;
|
|
||||||
|
|
||||||
SequenceDecompressor *decompress;
|
|
||||||
|
|
||||||
std::istream * input_stream;
|
|
||||||
PicOutput *output_image;
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
struct _GstDiracDecClass
|
|
||||||
{
|
|
||||||
GstElementClass parent_class;
|
|
||||||
};
|
|
||||||
|
|
||||||
GType gst_diracdec_get_type (void);
|
|
||||||
|
|
||||||
|
|
||||||
/* elementfactory information */
|
/* elementfactory information */
|
||||||
GstElementDetails gst_diracdec_details = {
|
static GstElementDetails gst_diracdec_details = {
|
||||||
"Dirac stream decoder",
|
"Dirac stream decoder",
|
||||||
"Codec/Decoder/Video",
|
"Codec/Decoder/Video",
|
||||||
"Decode DIRAC streams",
|
"Decode DIRAC streams",
|
||||||
"David Schleef <ds@schleef.org>",
|
"David Schleef <ds@schleef.org>\n"
|
||||||
|
"Ronald Bultje <rbultje@ronald.bitfreak.net>",
|
||||||
};
|
};
|
||||||
|
|
||||||
GST_DEBUG_CATEGORY (diracdec_debug);
|
GST_DEBUG_CATEGORY (diracdec_debug);
|
||||||
|
@ -90,9 +56,10 @@ enum
|
||||||
static void gst_diracdec_base_init (gpointer g_class);
|
static void gst_diracdec_base_init (gpointer g_class);
|
||||||
static void gst_diracdec_class_init (GstDiracDec * klass);
|
static void gst_diracdec_class_init (GstDiracDec * klass);
|
||||||
static void gst_diracdec_init (GstDiracDec * diracdec);
|
static void gst_diracdec_init (GstDiracDec * diracdec);
|
||||||
|
static void gst_diracdec_dispose (GObject * object);
|
||||||
|
|
||||||
static void gst_diracdec_chain (GstPad * pad, GstData * _data);
|
static void gst_diracdec_chain (GstPad * pad, GstData * data);
|
||||||
static GstPadLinkReturn gst_diracdec_link (GstPad * pad, const GstCaps * caps);
|
static GstElementStateReturn gst_diracdec_change_state (GstElement * element);
|
||||||
|
|
||||||
static GstElementClass *parent_class = NULL;
|
static GstElementClass *parent_class = NULL;
|
||||||
|
|
||||||
|
@ -120,6 +87,7 @@ gst_diracdec_get_type (void)
|
||||||
g_type_register_static (GST_TYPE_ELEMENT, "GstDiracDec", &diracdec_info,
|
g_type_register_static (GST_TYPE_ELEMENT, "GstDiracDec", &diracdec_info,
|
||||||
(GTypeFlags) 0);
|
(GTypeFlags) 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
return diracdec_type;
|
return diracdec_type;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -127,16 +95,15 @@ static GstStaticPadTemplate gst_diracdec_src_pad_template =
|
||||||
GST_STATIC_PAD_TEMPLATE ("src",
|
GST_STATIC_PAD_TEMPLATE ("src",
|
||||||
GST_PAD_SRC,
|
GST_PAD_SRC,
|
||||||
GST_PAD_ALWAYS,
|
GST_PAD_ALWAYS,
|
||||||
GST_STATIC_CAPS (GST_VIDEO_CAPS_YUV ("I420"))
|
/* FIXME: 444 (planar? packed?), 411 (Y41B? Y41P?) */
|
||||||
|
GST_STATIC_CAPS (GST_VIDEO_CAPS_YUV ("{ I420, YUY2, Y800 }"))
|
||||||
);
|
);
|
||||||
|
|
||||||
static GstStaticPadTemplate gst_diracdec_sink_pad_template =
|
static GstStaticPadTemplate gst_diracdec_sink_pad_template =
|
||||||
GST_STATIC_PAD_TEMPLATE ("sink",
|
GST_STATIC_PAD_TEMPLATE ("sink",
|
||||||
GST_PAD_SINK,
|
GST_PAD_SINK,
|
||||||
GST_PAD_ALWAYS,
|
GST_PAD_ALWAYS,
|
||||||
GST_STATIC_CAPS ("image/dirac, "
|
GST_STATIC_CAPS ("video/x-dirac")
|
||||||
"width = (int) [ 16, 4096 ], "
|
|
||||||
"height = (int) [ 16, 4096 ], " "framerate = (double) [ 1, MAX ]")
|
|
||||||
);
|
);
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -154,29 +121,34 @@ gst_diracdec_base_init (gpointer g_class)
|
||||||
static void
|
static void
|
||||||
gst_diracdec_class_init (GstDiracDec * klass)
|
gst_diracdec_class_init (GstDiracDec * klass)
|
||||||
{
|
{
|
||||||
GstElementClass *gstelement_class;
|
GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
|
||||||
|
GstElementClass *element_class = GST_ELEMENT_CLASS (klass);
|
||||||
gstelement_class = (GstElementClass *) klass;
|
|
||||||
|
|
||||||
parent_class = GST_ELEMENT_CLASS (g_type_class_ref (GST_TYPE_ELEMENT));
|
parent_class = GST_ELEMENT_CLASS (g_type_class_ref (GST_TYPE_ELEMENT));
|
||||||
|
|
||||||
|
gobject_class->dispose = gst_diracdec_dispose;
|
||||||
|
element_class->change_state = gst_diracdec_change_state;
|
||||||
|
|
||||||
GST_DEBUG_CATEGORY_INIT (diracdec_debug, "diracdec", 0, "DIRAC decoder");
|
GST_DEBUG_CATEGORY_INIT (diracdec_debug, "diracdec", 0, "DIRAC decoder");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
gst_diracdec_dispose (GObject * object)
|
||||||
|
{
|
||||||
|
G_OBJECT_CLASS (parent_class)->dispose (object);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_diracdec_init (GstDiracDec * diracdec)
|
gst_diracdec_init (GstDiracDec * diracdec)
|
||||||
{
|
{
|
||||||
SeqParams params;
|
|
||||||
|
|
||||||
GST_DEBUG ("gst_diracdec_init: initializing");
|
GST_DEBUG ("gst_diracdec_init: initializing");
|
||||||
/* create the sink and src pads */
|
/* create the sink and src pads */
|
||||||
|
|
||||||
diracdec->sinkpad =
|
diracdec->sinkpad =
|
||||||
gst_pad_new_from_template (gst_static_pad_template_get
|
gst_pad_new_from_template (gst_static_pad_template_get
|
||||||
(&gst_diracdec_sink_pad_template), "sink");
|
(&gst_diracdec_sink_pad_template), "sink");
|
||||||
gst_element_add_pad (GST_ELEMENT (diracdec), diracdec->sinkpad);
|
|
||||||
gst_pad_set_chain_function (diracdec->sinkpad, gst_diracdec_chain);
|
gst_pad_set_chain_function (diracdec->sinkpad, gst_diracdec_chain);
|
||||||
gst_pad_set_link_function (diracdec->sinkpad, gst_diracdec_link);
|
gst_element_add_pad (GST_ELEMENT (diracdec), diracdec->sinkpad);
|
||||||
|
|
||||||
diracdec->srcpad =
|
diracdec->srcpad =
|
||||||
gst_pad_new_from_template (gst_static_pad_template_get
|
gst_pad_new_from_template (gst_static_pad_template_get
|
||||||
|
@ -184,37 +156,204 @@ gst_diracdec_init (GstDiracDec * diracdec)
|
||||||
gst_pad_use_explicit_caps (diracdec->srcpad);
|
gst_pad_use_explicit_caps (diracdec->srcpad);
|
||||||
gst_element_add_pad (GST_ELEMENT (diracdec), diracdec->srcpad);
|
gst_element_add_pad (GST_ELEMENT (diracdec), diracdec->srcpad);
|
||||||
|
|
||||||
//diracdec->input_stream = new std::istream ();
|
/* no capsnego done yet */
|
||||||
diracdec->input_stream = NULL;
|
diracdec->width = -1;
|
||||||
diracdec->decompress =
|
diracdec->height = -1;
|
||||||
new SequenceDecompressor (diracdec->input_stream, FALSE);
|
diracdec->fps = 0;
|
||||||
diracdec->output_image = new PicOutput ("moo", params, (bool) FALSE);
|
diracdec->fcc = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static GstPadLinkReturn
|
static guint32
|
||||||
gst_diracdec_link (GstPad * pad, const GstCaps * caps)
|
gst_diracdec_chroma_to_fourcc (dirac_chroma_t chroma)
|
||||||
{
|
{
|
||||||
//GstDiracDec *diracdec = GST_DIRACDEC (gst_pad_get_parent (pad));
|
guint32 fourcc = 0;
|
||||||
GstStructure *structure;
|
|
||||||
|
|
||||||
//GstCaps *srccaps;
|
switch (chroma) {
|
||||||
|
case Yonly:
|
||||||
|
fourcc = GST_MAKE_FOURCC ('Y', '8', '0', '0');
|
||||||
|
break;
|
||||||
|
case format422:
|
||||||
|
fourcc = GST_MAKE_FOURCC ('Y', 'U', 'Y', '2');
|
||||||
|
break;
|
||||||
|
/* planar? */
|
||||||
|
case format420:
|
||||||
|
case format444:
|
||||||
|
case format411:
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
structure = gst_caps_get_structure (caps, 0);
|
return fourcc;
|
||||||
|
}
|
||||||
|
|
||||||
return GST_PAD_LINK_OK;
|
static gboolean
|
||||||
|
gst_diracdec_link (GstDiracDec * diracdec,
|
||||||
|
gint width, gint height, gdouble fps, guint32 fourcc)
|
||||||
|
{
|
||||||
|
GstCaps *caps;
|
||||||
|
|
||||||
|
if (width == diracdec->width &&
|
||||||
|
height == diracdec->height &&
|
||||||
|
fps == diracdec->fps && fourcc == diracdec->fcc) {
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!fourcc) {
|
||||||
|
g_warning ("Chroma not supported\n");
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
caps = gst_caps_new_simple ("video/x-raw-yuv",
|
||||||
|
"width", G_TYPE_INT, width,
|
||||||
|
"height", G_TYPE_INT, height,
|
||||||
|
"format", GST_TYPE_FOURCC, fourcc, "framerate", G_TYPE_DOUBLE, fps, NULL);
|
||||||
|
|
||||||
|
if (gst_pad_set_explicit_caps (diracdec->srcpad, caps)) {
|
||||||
|
diracdec->width = width;
|
||||||
|
diracdec->height = height;
|
||||||
|
switch (fourcc) {
|
||||||
|
case GST_MAKE_FOURCC ('Y', 'U', 'Y', '2'):
|
||||||
|
diracdec->size = width * height * 2;
|
||||||
|
break;
|
||||||
|
case GST_MAKE_FOURCC ('Y', '8', '0', '0'):
|
||||||
|
diracdec->size = width * height;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
diracdec->fcc = fourcc;
|
||||||
|
diracdec->fps = fps;
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_diracdec_chain (GstPad * pad, GstData * _data)
|
gst_diracdec_chain (GstPad * pad, GstData * _data)
|
||||||
{
|
{
|
||||||
GstBuffer *buf = GST_BUFFER (_data);
|
GstDiracDec *diracdec = GST_DIRACDEC (gst_pad_get_parent (pad));
|
||||||
GstDiracDec *diracdec;
|
GstBuffer *buf = GST_BUFFER (_data), *out;
|
||||||
|
gboolean c = TRUE;
|
||||||
|
|
||||||
g_return_if_fail (pad != NULL);
|
/* get state and do something */
|
||||||
g_return_if_fail (GST_IS_PAD (pad));
|
while (c) {
|
||||||
g_return_if_fail (buf != NULL);
|
switch (dirac_parse (diracdec->decoder)) {
|
||||||
|
case STATE_BUFFER:
|
||||||
|
if (buf) {
|
||||||
|
/* provide data to decoder */
|
||||||
|
dirac_buffer (diracdec->decoder, GST_BUFFER_DATA (buf),
|
||||||
|
GST_BUFFER_DATA (buf) + GST_BUFFER_SIZE (buf));
|
||||||
|
gst_buffer_unref (buf);
|
||||||
|
buf = NULL;
|
||||||
|
} else {
|
||||||
|
/* need more data */
|
||||||
|
c = FALSE;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
diracdec = GST_DIRACDEC (GST_OBJECT_PARENT (pad));
|
case STATE_SEQUENCE:{
|
||||||
|
guint8 *buf[3];
|
||||||
|
|
||||||
gst_buffer_unref (buf);
|
/* start-of-sequence - allocate buffer */
|
||||||
|
if (!gst_diracdec_link (diracdec,
|
||||||
|
diracdec->decoder->seq_params.width,
|
||||||
|
diracdec->decoder->seq_params.height,
|
||||||
|
gst_diracdec_chroma_to_fourcc (diracdec->decoder->seq_params.
|
||||||
|
chroma), diracdec->decoder->seq_params.frame_rate)) {
|
||||||
|
GST_ELEMENT_ERROR (diracdec, CORE, NEGOTIATION, (NULL),
|
||||||
|
("Failed to set caps to %dx%d @ %d fps (format=" GST_FOURCC_FORMAT
|
||||||
|
"/%d)", diracdec->decoder->seq_params.width,
|
||||||
|
diracdec->decoder->seq_params.height,
|
||||||
|
diracdec->decoder->seq_params.frame_rate,
|
||||||
|
gst_diracdec_chroma_to_fourcc (diracdec->decoder->seq_params.
|
||||||
|
chroma), diracdec->decoder->seq_params.chroma));
|
||||||
|
c = FALSE;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_free (diracdec->decoder->fbuf->buf[0]);
|
||||||
|
g_free (diracdec->decoder->fbuf->buf[1]);
|
||||||
|
g_free (diracdec->decoder->fbuf->buf[2]);
|
||||||
|
buf[0] = (guchar *) g_malloc (diracdec->decoder->seq_params.width *
|
||||||
|
diracdec->decoder->seq_params.height);
|
||||||
|
if (diracdec->decoder->seq_params.chroma != Yonly) {
|
||||||
|
buf[1] =
|
||||||
|
(guchar *) g_malloc (diracdec->decoder->seq_params.chroma_width *
|
||||||
|
diracdec->decoder->seq_params.chroma_height);
|
||||||
|
buf[2] =
|
||||||
|
(guchar *) g_malloc (diracdec->decoder->seq_params.chroma_width *
|
||||||
|
diracdec->decoder->seq_params.chroma_height);
|
||||||
|
}
|
||||||
|
dirac_set_buf (diracdec->decoder, buf, NULL);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case STATE_SEQUENCE_END:
|
||||||
|
/* end-of-sequence - free buffer */
|
||||||
|
g_free (diracdec->decoder->fbuf->buf[0]);
|
||||||
|
diracdec->decoder->fbuf->buf[0] = NULL;
|
||||||
|
g_free (diracdec->decoder->fbuf->buf[1]);
|
||||||
|
diracdec->decoder->fbuf->buf[1] = NULL;
|
||||||
|
g_free (diracdec->decoder->fbuf->buf[2]);
|
||||||
|
diracdec->decoder->fbuf->buf[2] = NULL;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case STATE_PICTURE_START:
|
||||||
|
/* start of one picture */
|
||||||
|
break;
|
||||||
|
|
||||||
|
case STATE_PICTURE_AVAIL:
|
||||||
|
/* one picture is decoded */
|
||||||
|
out = gst_pad_alloc_buffer (diracdec->srcpad, 0, diracdec->size);
|
||||||
|
memcpy (GST_BUFFER_DATA (out), diracdec->decoder->fbuf->buf[0],
|
||||||
|
diracdec->width * diracdec->height);
|
||||||
|
if (diracdec->fcc != GST_MAKE_FOURCC ('Y', '8', '0', '0')) {
|
||||||
|
memcpy (GST_BUFFER_DATA (out) + (diracdec->width *
|
||||||
|
diracdec->height), diracdec->decoder->fbuf->buf[1],
|
||||||
|
diracdec->decoder->seq_params.chroma_width *
|
||||||
|
diracdec->decoder->seq_params.chroma_height);
|
||||||
|
memcpy (GST_BUFFER_DATA (out) +
|
||||||
|
(diracdec->decoder->seq_params.chroma_width *
|
||||||
|
diracdec->decoder->seq_params.chroma_height) +
|
||||||
|
(diracdec->width * diracdec->height),
|
||||||
|
diracdec->decoder->fbuf->buf[2],
|
||||||
|
diracdec->decoder->seq_params.chroma_width *
|
||||||
|
diracdec->decoder->seq_params.chroma_height);
|
||||||
|
}
|
||||||
|
GST_BUFFER_TIMESTAMP (out) = (guint64) (GST_SECOND *
|
||||||
|
diracdec->decoder->frame_params.fnum / diracdec->fps);
|
||||||
|
GST_BUFFER_DURATION (out) = (guint64) (GST_SECOND / diracdec->fps);
|
||||||
|
gst_pad_push (diracdec->srcpad, GST_DATA (out));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case STATE_INVALID:
|
||||||
|
default:
|
||||||
|
GST_ELEMENT_ERROR (diracdec, LIBRARY, TOO_LAZY, (NULL), (NULL));
|
||||||
|
c = FALSE;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static GstElementStateReturn
|
||||||
|
gst_diracdec_change_state (GstElement * element)
|
||||||
|
{
|
||||||
|
GstDiracDec *diracdec = GST_DIRACDEC (element);
|
||||||
|
|
||||||
|
switch (GST_STATE_TRANSITION (element)) {
|
||||||
|
case GST_STATE_NULL_TO_READY:
|
||||||
|
if (!(diracdec->decoder = dirac_decoder_init (0)))
|
||||||
|
return GST_STATE_FAILURE;
|
||||||
|
break;
|
||||||
|
case GST_STATE_READY_TO_NULL:
|
||||||
|
dirac_decoder_close (diracdec->decoder);
|
||||||
|
diracdec->width = diracdec->height = -1;
|
||||||
|
diracdec->fps = 0.;
|
||||||
|
diracdec->fcc = 0;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return parent_class->change_state (element);
|
||||||
}
|
}
|
||||||
|
|
69
ext/dirac/gstdiracdec.h
Normal file
69
ext/dirac/gstdiracdec.h
Normal file
|
@ -0,0 +1,69 @@
|
||||||
|
/* GStreamer
|
||||||
|
* Copyright (C) 2004 David A. Schleef <ds@schleef.org>
|
||||||
|
* Copyright (C) 2004 Ronald S. Bultje <rbultje@ronald.bitfreak.net>
|
||||||
|
*
|
||||||
|
* This library is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Library General Public
|
||||||
|
* License as published by the Free Software Foundation; either
|
||||||
|
* version 2 of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This library is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* Library General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Library General Public
|
||||||
|
* License along with this library; if not, write to the
|
||||||
|
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
||||||
|
* Boston, MA 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __GST_DIRACDEC_H__
|
||||||
|
#define __GST_DIRACDEC_H__
|
||||||
|
|
||||||
|
#include <gst/gst.h>
|
||||||
|
|
||||||
|
#include <libdirac_decoder/decoder_types.h>
|
||||||
|
#include <libdirac_decoder/dirac_parser.h>
|
||||||
|
|
||||||
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
|
#define GST_TYPE_DIRACDEC \
|
||||||
|
(gst_diracdec_get_type())
|
||||||
|
#define GST_DIRACDEC(obj) \
|
||||||
|
(G_TYPE_CHECK_INSTANCE_CAST((obj),GST_TYPE_DIRACDEC,GstDiracDec))
|
||||||
|
#define GST_DIRACDEC_CLASS(klass) \
|
||||||
|
(G_TYPE_CHECK_CLASS_CAST((klass),GST_TYPE_DIRACDEC,GstDiracDec))
|
||||||
|
#define GST_IS_DIRACDEC(obj) \
|
||||||
|
(G_TYPE_CHECK_INSTANCE_TYPE((obj),GST_TYPE_DIRACDEC))
|
||||||
|
#define GST_IS_DIRACDEC_CLASS(obj) \
|
||||||
|
(G_TYPE_CHECK_CLASS_TYPE((klass),GST_TYPE_DIRACDEC))
|
||||||
|
|
||||||
|
typedef struct _GstDiracDec GstDiracDec;
|
||||||
|
typedef struct _GstDiracDecClass GstDiracDecClass;
|
||||||
|
|
||||||
|
struct _GstDiracDec
|
||||||
|
{
|
||||||
|
GstElement element;
|
||||||
|
|
||||||
|
/* pads */
|
||||||
|
GstPad *sinkpad, *srcpad;
|
||||||
|
|
||||||
|
dirac_decoder_t *decoder;
|
||||||
|
|
||||||
|
/* size is size of buf */
|
||||||
|
gint width, height, size;
|
||||||
|
gdouble fps;
|
||||||
|
guint32 fcc;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct _GstDiracDecClass
|
||||||
|
{
|
||||||
|
GstElementClass parent_class;
|
||||||
|
};
|
||||||
|
|
||||||
|
GType gst_diracdec_get_type (void);
|
||||||
|
|
||||||
|
G_END_DECLS
|
||||||
|
|
||||||
|
#endif /* __GST_DIRACDEC_H__ */
|
|
@ -173,6 +173,7 @@ gst_gsmdec_getcaps (GstPad * pad)
|
||||||
0), "rate");
|
0), "rate");
|
||||||
gst_structure_set_value (gst_caps_get_structure (basecaps, 0), "rate",
|
gst_structure_set_value (gst_caps_get_structure (basecaps, 0), "rate",
|
||||||
rate_value);
|
rate_value);
|
||||||
|
gst_caps_set_simple (basecaps, "channels", G_TYPE_INT, 1, NULL);
|
||||||
|
|
||||||
return basecaps;
|
return basecaps;
|
||||||
}
|
}
|
||||||
|
|
|
@ -304,7 +304,7 @@ gst_riff_read_seek (GstRiffRead * riff, guint64 offset)
|
||||||
GstEventType type = GST_EVENT_TYPE (event);
|
GstEventType type = GST_EVENT_TYPE (event);
|
||||||
|
|
||||||
gst_pad_event_default (riff->sinkpad, event);
|
gst_pad_event_default (riff->sinkpad, event);
|
||||||
if (type == GST_EVENT_EOS)
|
if (type == GST_EVENT_EOS || type == GST_EVENT_INTERRUPT)
|
||||||
return NULL;
|
return NULL;
|
||||||
event = NULL;
|
event = NULL;
|
||||||
}
|
}
|
||||||
|
@ -890,8 +890,7 @@ gst_riff_read_info (GstRiffRead * riff)
|
||||||
|
|
||||||
if (name && name[0] != '\0') {
|
if (name && name[0] != '\0') {
|
||||||
GValue src = { 0 }
|
GValue src = { 0 }
|
||||||
, dest =
|
, dest = {
|
||||||
{
|
|
||||||
0};
|
0};
|
||||||
GType dest_type = gst_tag_get_type (type);
|
GType dest_type = gst_tag_get_type (type);
|
||||||
|
|
||||||
|
|
|
@ -474,6 +474,7 @@ GST_PLUGIN_DEFINE (GST_VERSION_MAJOR,
|
||||||
static gboolean
|
static gboolean
|
||||||
gst_qtdemux_handle_sink_event (GstQTDemux * qtdemux)
|
gst_qtdemux_handle_sink_event (GstQTDemux * qtdemux)
|
||||||
{
|
{
|
||||||
|
gboolean res = TRUE;
|
||||||
guint32 remaining;
|
guint32 remaining;
|
||||||
GstEvent *event;
|
GstEvent *event;
|
||||||
GstEventType type;
|
GstEventType type;
|
||||||
|
@ -495,12 +496,13 @@ gst_qtdemux_handle_sink_event (GstQTDemux * qtdemux)
|
||||||
//gst_bytestream_flush_fast(qtdemux->bs, remaining);
|
//gst_bytestream_flush_fast(qtdemux->bs, remaining);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
res = FALSE;
|
||||||
g_warning ("unhandled event %d", type);
|
g_warning ("unhandled event %d", type);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
gst_event_unref (event);
|
gst_event_unref (event);
|
||||||
return TRUE;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
static GstElementStateReturn
|
static GstElementStateReturn
|
||||||
|
@ -713,6 +715,7 @@ gst_qtdemux_loop_header (GstElement * element)
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
g_warning ("seek failed");
|
g_warning ("seek failed");
|
||||||
}
|
}
|
||||||
|
qtdemux->offset = offset;
|
||||||
GST_DEBUG ("seek returned %d", ret);
|
GST_DEBUG ("seek returned %d", ret);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -780,7 +783,6 @@ gst_qtdemux_loop_header (GstElement * element)
|
||||||
/* unreached */
|
/* unreached */
|
||||||
g_assert (0);
|
g_assert (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -2024,7 +2026,8 @@ qtdemux_parse_trak (GstQTDemux * qtdemux, GNode * trak)
|
||||||
GST_FOURCC_ARGS (QTDEMUX_FOURCC_GET (stsd->data + 16 + 4)),
|
GST_FOURCC_ARGS (QTDEMUX_FOURCC_GET (stsd->data + 16 + 4)),
|
||||||
stream->caps);
|
stream->caps);
|
||||||
} else {
|
} else {
|
||||||
GST_INFO ("unknown subtype");
|
GST_INFO ("unknown subtype " GST_FOURCC_FORMAT,
|
||||||
|
GST_FOURCC_ARGS (stream->subtype));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2156,7 +2159,7 @@ qtdemux_parse_trak (GstQTDemux * qtdemux, GNode * trak)
|
||||||
samples_per_chunk * stream->bytes_per_frame /
|
samples_per_chunk * stream->bytes_per_frame /
|
||||||
stream->samples_per_packet / stream->compression;
|
stream->samples_per_packet / stream->compression;
|
||||||
else
|
else
|
||||||
samples[j].size = 0;
|
samples[j].size = stream->bytes_per_frame;
|
||||||
samples[j].duration =
|
samples[j].duration =
|
||||||
samples_per_chunk * GST_SECOND / (stream->rate / 2);
|
samples_per_chunk * GST_SECOND / (stream->rate / 2);
|
||||||
samples[j].timestamp = timestamp;
|
samples[j].timestamp = timestamp;
|
||||||
|
@ -2208,7 +2211,6 @@ done2:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
gst_qtdemux_add_stream (qtdemux, stream);
|
gst_qtdemux_add_stream (qtdemux, stream);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2573,12 +2575,14 @@ qtdemux_audio_caps (GstQTDemux * qtdemux, guint32 fourcc, const guint8 * data,
|
||||||
case GST_MAKE_FOURCC ('a', 'g', 's', 'm'):
|
case GST_MAKE_FOURCC ('a', 'g', 's', 'm'):
|
||||||
/* GSM */
|
/* GSM */
|
||||||
return gst_caps_new_simple ("audio/x-gsm", NULL);
|
return gst_caps_new_simple ("audio/x-gsm", NULL);
|
||||||
|
case GST_MAKE_FOURCC ('i', 'm', 'a', '4'):
|
||||||
|
/* IMA 4:1 */
|
||||||
|
return gst_caps_new_simple ("audio/x-adpcm",
|
||||||
|
"layout", G_TYPE_STRING, "quicktime", NULL);
|
||||||
case GST_MAKE_FOURCC ('q', 't', 'v', 'r'):
|
case GST_MAKE_FOURCC ('q', 't', 'v', 'r'):
|
||||||
/* ? */
|
/* ? */
|
||||||
case GST_MAKE_FOURCC ('Q', 'D', 'M', 'C'):
|
case GST_MAKE_FOURCC ('Q', 'D', 'M', 'C'):
|
||||||
/* QDesign music */
|
/* QDesign music */
|
||||||
case GST_MAKE_FOURCC ('i', 'm', 'a', '4'):
|
|
||||||
/* IMA 4:1 */
|
|
||||||
case GST_MAKE_FOURCC ('Q', 'c', 'l', 'p'):
|
case GST_MAKE_FOURCC ('Q', 'c', 'l', 'p'):
|
||||||
/* QUALCOMM PureVoice */
|
/* QUALCOMM PureVoice */
|
||||||
default:
|
default:
|
||||||
|
|
Loading…
Reference in a new issue