mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-23 15:48:23 +00:00
compatibility fix for new GST_DEBUG stuff.
Original commit message from CVS: compatibility fix for new GST_DEBUG stuff. Includes fixes for missing includes for config.h and unistd.h I only ensured for plugins I can build that they work, so if some of them are still broken, you gotta fix them yourselves unfortunately.
This commit is contained in:
parent
7519af569b
commit
90da904f1e
65 changed files with 515 additions and 350 deletions
2
common
2
common
|
@ -1 +1 @@
|
||||||
Subproject commit 4e379694ae9ff9843d65cf08928642eea44abdf8
|
Subproject commit 2a3efdc282fb1ecfd2720dea40523b3441f10fed
|
|
@ -968,8 +968,6 @@ dnl ######################################################################
|
||||||
dnl # Check command line parameters, and set shell variables accordingly #
|
dnl # Check command line parameters, and set shell variables accordingly #
|
||||||
dnl ######################################################################
|
dnl ######################################################################
|
||||||
|
|
||||||
GST_DEBUGINFO
|
|
||||||
|
|
||||||
AC_ARG_ENABLE(libmmx,
|
AC_ARG_ENABLE(libmmx,
|
||||||
AC_HELP_STRING([--enable-libmmx],[use libmmx, if available]),
|
AC_HELP_STRING([--enable-libmmx],[use libmmx, if available]),
|
||||||
[case "${enableval}" in
|
[case "${enableval}" in
|
||||||
|
|
|
@ -17,6 +17,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <config.h>
|
#include <config.h>
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
@ -246,7 +249,7 @@ gst_aasink_sinkconnect (GstPad *pad, GstCaps *caps)
|
||||||
|
|
||||||
/* FIXME aasink->format is never set */
|
/* FIXME aasink->format is never set */
|
||||||
|
|
||||||
GST_DEBUG (0, "aasink: setting %08lx (" GST_FOURCC_FORMAT ")",
|
GST_DEBUG ("aasink: setting %08lx (" GST_FOURCC_FORMAT ")",
|
||||||
aasink->format, GST_FOURCC_ARGS(aasink->format));
|
aasink->format, GST_FOURCC_ARGS(aasink->format));
|
||||||
|
|
||||||
g_signal_emit( G_OBJECT (aasink), gst_aasink_signals[SIGNAL_HAVE_SIZE], 0,
|
g_signal_emit( G_OBJECT (aasink), gst_aasink_signals[SIGNAL_HAVE_SIZE], 0,
|
||||||
|
@ -346,7 +349,7 @@ gst_aasink_chain (GstPad *pad, GstBuffer *buf)
|
||||||
aa_imgwidth (aasink->context), /* dw */
|
aa_imgwidth (aasink->context), /* dw */
|
||||||
aa_imgheight (aasink->context)); /* dh */
|
aa_imgheight (aasink->context)); /* dh */
|
||||||
|
|
||||||
GST_DEBUG (0,"videosink: clock wait: %" G_GUINT64_FORMAT, GST_BUFFER_TIMESTAMP(buf));
|
GST_DEBUG ("videosink: clock wait: %" G_GUINT64_FORMAT, GST_BUFFER_TIMESTAMP(buf));
|
||||||
|
|
||||||
if (aasink->clock) {
|
if (aasink->clock) {
|
||||||
GstClockID id = gst_clock_new_single_shot_id (aasink->clock, GST_BUFFER_TIMESTAMP(buf));
|
GstClockID id = gst_clock_new_single_shot_id (aasink->clock, GST_BUFFER_TIMESTAMP(buf));
|
||||||
|
|
|
@ -17,6 +17,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
/* First, include the header file for the plugin, to bring in the
|
/* First, include the header file for the plugin, to bring in the
|
||||||
|
|
|
@ -20,8 +20,12 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
#include <esd.h>
|
#include <esd.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
#define GST_TYPE_ESDMON \
|
#define GST_TYPE_ESDMON \
|
||||||
(gst_esdmon_get_type())
|
(gst_esdmon_get_type())
|
||||||
|
@ -278,7 +282,7 @@ gst_esdmon_get (GstPad *pad)
|
||||||
g_return_val_if_fail (pad != NULL, NULL);
|
g_return_val_if_fail (pad != NULL, NULL);
|
||||||
esdmon = GST_ESDMON(gst_pad_get_parent (pad));
|
esdmon = GST_ESDMON(gst_pad_get_parent (pad));
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO, "attempting to read something from esdmon");
|
GST_DEBUG ("attempting to read something from esdmon");
|
||||||
|
|
||||||
buf = gst_buffer_new ();
|
buf = gst_buffer_new ();
|
||||||
g_return_val_if_fail (buf, NULL);
|
g_return_val_if_fail (buf, NULL);
|
||||||
|
@ -324,7 +328,7 @@ gst_esdmon_get (GstPad *pad)
|
||||||
if (esdmon->depth == 16) readsamples /= 2;
|
if (esdmon->depth == 16) readsamples /= 2;
|
||||||
esdmon->samples_since_basetime += readsamples;
|
esdmon->samples_since_basetime += readsamples;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO, "pushed buffer from esdmon of %ld bytes, timestamp %" G_GINT64_FORMAT, readbytes, GST_BUFFER_TIMESTAMP (buf));
|
GST_DEBUG ("pushed buffer from esdmon of %ld bytes, timestamp %" G_GINT64_FORMAT, readbytes, GST_BUFFER_TIMESTAMP (buf));
|
||||||
return buf;
|
return buf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -442,21 +446,21 @@ gst_esdmon_open_audio (GstEsdmon *src)
|
||||||
if (src->depth == 16) esdformat |= ESD_BITS16;
|
if (src->depth == 16) esdformat |= ESD_BITS16;
|
||||||
else if (src->depth == 8) esdformat |= ESD_BITS8;
|
else if (src->depth == 8) esdformat |= ESD_BITS8;
|
||||||
else {
|
else {
|
||||||
GST_DEBUG (0, "esdmon: invalid bit depth (%d)", src->depth);
|
GST_DEBUG ("esdmon: invalid bit depth (%d)", src->depth);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (src->channels == 2) esdformat |= ESD_STEREO;
|
if (src->channels == 2) esdformat |= ESD_STEREO;
|
||||||
else if (src->channels == 1) esdformat |= ESD_MONO;
|
else if (src->channels == 1) esdformat |= ESD_MONO;
|
||||||
else {
|
else {
|
||||||
GST_DEBUG (0, "esdmon: invalid number of channels (%d)", src->channels);
|
GST_DEBUG ("esdmon: invalid number of channels (%d)", src->channels);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (0, "esdmon: attempting to open connection to esound server");
|
GST_DEBUG ("esdmon: attempting to open connection to esound server");
|
||||||
src->fd = esd_monitor_stream(esdformat, src->frequency, src->host, connname);
|
src->fd = esd_monitor_stream(esdformat, src->frequency, src->host, connname);
|
||||||
if ( src->fd < 0 ) {
|
if ( src->fd < 0 ) {
|
||||||
GST_DEBUG (0, "esdmon: can't open connection to esound server");
|
GST_DEBUG ("esdmon: can't open connection to esound server");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -475,7 +479,7 @@ gst_esdmon_close_audio (GstEsdmon *src)
|
||||||
|
|
||||||
GST_FLAG_UNSET (src, GST_ESDMON_OPEN);
|
GST_FLAG_UNSET (src, GST_ESDMON_OPEN);
|
||||||
|
|
||||||
GST_DEBUG (0, "esdmon: closed sound device");
|
GST_DEBUG ("esdmon: closed sound device");
|
||||||
}
|
}
|
||||||
|
|
||||||
static GstElementStateReturn
|
static GstElementStateReturn
|
||||||
|
|
|
@ -20,8 +20,12 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include "esdsink.h"
|
#include "esdsink.h"
|
||||||
#include <esd.h>
|
#include <esd.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
/* elementfactory information */
|
/* elementfactory information */
|
||||||
static GstElementDetails esdsink_details = {
|
static GstElementDetails esdsink_details = {
|
||||||
|
@ -197,7 +201,7 @@ gst_esdsink_chain (GstPad *pad, GstBuffer *buf)
|
||||||
|
|
||||||
if (GST_BUFFER_DATA (buf) != NULL) {
|
if (GST_BUFFER_DATA (buf) != NULL) {
|
||||||
if (!esdsink->mute && esdsink->fd >= 0) {
|
if (!esdsink->mute && esdsink->fd >= 0) {
|
||||||
GST_DEBUG (0, "esdsink: fd=%d data=%p size=%d",
|
GST_DEBUG ("esdsink: fd=%d data=%p size=%d",
|
||||||
esdsink->fd, GST_BUFFER_DATA (buf), GST_BUFFER_SIZE (buf));
|
esdsink->fd, GST_BUFFER_DATA (buf), GST_BUFFER_SIZE (buf));
|
||||||
write (esdsink->fd, GST_BUFFER_DATA (buf), GST_BUFFER_SIZE (buf));
|
write (esdsink->fd, GST_BUFFER_DATA (buf), GST_BUFFER_SIZE (buf));
|
||||||
}
|
}
|
||||||
|
@ -288,21 +292,21 @@ gst_esdsink_open_audio (GstEsdsink *sink)
|
||||||
if (sink->depth == 16) esdformat |= ESD_BITS16;
|
if (sink->depth == 16) esdformat |= ESD_BITS16;
|
||||||
else if (sink->depth == 8) esdformat |= ESD_BITS8;
|
else if (sink->depth == 8) esdformat |= ESD_BITS8;
|
||||||
else {
|
else {
|
||||||
GST_DEBUG (0, "esdsink: invalid bit depth (%d)", sink->depth);
|
GST_DEBUG ("esdsink: invalid bit depth (%d)", sink->depth);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (sink->channels == 2) esdformat |= ESD_STEREO;
|
if (sink->channels == 2) esdformat |= ESD_STEREO;
|
||||||
else if (sink->channels == 1) esdformat |= ESD_MONO;
|
else if (sink->channels == 1) esdformat |= ESD_MONO;
|
||||||
else {
|
else {
|
||||||
GST_DEBUG (0, "esdsink: invalid number of channels (%d)", sink->channels);
|
GST_DEBUG ("esdsink: invalid number of channels (%d)", sink->channels);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (0, "esdsink: attempting to open connection to esound server");
|
GST_DEBUG ("esdsink: attempting to open connection to esound server");
|
||||||
sink->fd = esd_play_stream_fallback(esdformat, sink->frequency, sink->host, connname);
|
sink->fd = esd_play_stream_fallback(esdformat, sink->frequency, sink->host, connname);
|
||||||
if ( sink->fd < 0 ) {
|
if ( sink->fd < 0 ) {
|
||||||
GST_DEBUG (0, "esdsink: can't open connection to esound server");
|
GST_DEBUG ("esdsink: can't open connection to esound server");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -318,7 +322,7 @@ gst_esdsink_close_audio (GstEsdsink *sink)
|
||||||
close(sink->fd);
|
close(sink->fd);
|
||||||
sink->fd = -1;
|
sink->fd = -1;
|
||||||
|
|
||||||
GST_DEBUG (0, "esdsink: closed sound device");
|
GST_DEBUG ("esdsink: closed sound device");
|
||||||
}
|
}
|
||||||
|
|
||||||
static GstElementStateReturn
|
static GstElementStateReturn
|
||||||
|
|
|
@ -17,6 +17,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <sys/soundcard.h>
|
#include <sys/soundcard.h>
|
||||||
|
|
||||||
|
@ -211,7 +214,7 @@ gst_flacdec_update_metadata (FlacDec *flacdec, const FLAC__StreamMetadata *metad
|
||||||
|
|
||||||
number_of_comments = metadata->data.vorbis_comment.num_comments;
|
number_of_comments = metadata->data.vorbis_comment.num_comments;
|
||||||
value = NULL;
|
value = NULL;
|
||||||
GST_DEBUG (GST_CAT_CAPS, "%d tag(s) found", number_of_comments);
|
GST_DEBUG ("%d tag(s) found", number_of_comments);
|
||||||
for (cursor = 0; cursor < number_of_comments; cursor++)
|
for (cursor = 0; cursor < number_of_comments; cursor++)
|
||||||
{
|
{
|
||||||
str_ptr = metadata->data.vorbis_comment.comments[cursor].entry;
|
str_ptr = metadata->data.vorbis_comment.comments[cursor].entry;
|
||||||
|
@ -225,7 +228,7 @@ gst_flacdec_update_metadata (FlacDec *flacdec, const FLAC__StreamMetadata *metad
|
||||||
entry = gst_props_entry_new (name, GST_PROPS_STRING_TYPE, value);
|
entry = gst_props_entry_new (name, GST_PROPS_STRING_TYPE, value);
|
||||||
gst_props_add_entry (props, (GstPropsEntry *) entry);
|
gst_props_add_entry (props, (GstPropsEntry *) entry);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_CAPS, "%s : %s", name, value);
|
GST_DEBUG ("%s : %s", name, value);
|
||||||
|
|
||||||
g_free (name);
|
g_free (name);
|
||||||
g_free (value);
|
g_free (value);
|
||||||
|
@ -286,7 +289,7 @@ gst_flacdec_error_callback (const FLAC__SeekableStreamDecoder *decoder,
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (0, error);
|
GST_DEBUG (error);
|
||||||
|
|
||||||
gst_element_error (GST_ELEMENT (flacdec), error);
|
gst_element_error (GST_ELEMENT (flacdec), error);
|
||||||
}
|
}
|
||||||
|
@ -299,7 +302,7 @@ gst_flacdec_seek (const FLAC__SeekableStreamDecoder *decoder,
|
||||||
|
|
||||||
flacdec = GST_FLACDEC (client_data);
|
flacdec = GST_FLACDEC (client_data);
|
||||||
|
|
||||||
GST_DEBUG (0, "seek %" G_GINT64_FORMAT, position);
|
GST_DEBUG ("seek %" G_GINT64_FORMAT, position);
|
||||||
if (!gst_bytestream_seek (flacdec->bs, position, GST_SEEK_METHOD_SET)) {
|
if (!gst_bytestream_seek (flacdec->bs, position, GST_SEEK_METHOD_SET)) {
|
||||||
return FLAC__SEEKABLE_STREAM_DECODER_SEEK_STATUS_ERROR;
|
return FLAC__SEEKABLE_STREAM_DECODER_SEEK_STATUS_ERROR;
|
||||||
}
|
}
|
||||||
|
@ -318,7 +321,7 @@ gst_flacdec_tell (const FLAC__SeekableStreamDecoder *decoder,
|
||||||
if (*position == -1)
|
if (*position == -1)
|
||||||
return FLAC__SEEKABLE_STREAM_DECODER_TELL_STATUS_ERROR;
|
return FLAC__SEEKABLE_STREAM_DECODER_TELL_STATUS_ERROR;
|
||||||
|
|
||||||
GST_DEBUG (0, "tell %" G_GINT64_FORMAT, *position);
|
GST_DEBUG ("tell %" G_GINT64_FORMAT, *position);
|
||||||
|
|
||||||
return FLAC__SEEKABLE_STREAM_DECODER_TELL_STATUS_OK;
|
return FLAC__SEEKABLE_STREAM_DECODER_TELL_STATUS_OK;
|
||||||
}
|
}
|
||||||
|
@ -335,7 +338,7 @@ gst_flacdec_length (const FLAC__SeekableStreamDecoder *decoder,
|
||||||
if (*length == -1)
|
if (*length == -1)
|
||||||
return FLAC__SEEKABLE_STREAM_DECODER_TELL_STATUS_ERROR;
|
return FLAC__SEEKABLE_STREAM_DECODER_TELL_STATUS_ERROR;
|
||||||
|
|
||||||
GST_DEBUG (0, "length %" G_GINT64_FORMAT, *length);
|
GST_DEBUG ("length %" G_GINT64_FORMAT, *length);
|
||||||
|
|
||||||
return FLAC__SEEKABLE_STREAM_DECODER_LENGTH_STATUS_OK;
|
return FLAC__SEEKABLE_STREAM_DECODER_LENGTH_STATUS_OK;
|
||||||
}
|
}
|
||||||
|
@ -347,7 +350,7 @@ gst_flacdec_eof (const FLAC__SeekableStreamDecoder *decoder,
|
||||||
FlacDec *flacdec;
|
FlacDec *flacdec;
|
||||||
|
|
||||||
flacdec = GST_FLACDEC (client_data);
|
flacdec = GST_FLACDEC (client_data);
|
||||||
GST_DEBUG (0, "eof %d", flacdec->eos);
|
GST_DEBUG ("eof %d", flacdec->eos);
|
||||||
|
|
||||||
return flacdec->eos;
|
return flacdec->eos;
|
||||||
}
|
}
|
||||||
|
@ -375,7 +378,7 @@ gst_flacdec_read (const FLAC__SeekableStreamDecoder *decoder,
|
||||||
|
|
||||||
switch (GST_EVENT_TYPE (event)) {
|
switch (GST_EVENT_TYPE (event)) {
|
||||||
case GST_EVENT_EOS:
|
case GST_EVENT_EOS:
|
||||||
GST_DEBUG (0, "eos");
|
GST_DEBUG ("eos");
|
||||||
flacdec->eos = TRUE;
|
flacdec->eos = TRUE;
|
||||||
gst_event_unref (event);
|
gst_event_unref (event);
|
||||||
if (avail == 0) {
|
if (avail == 0) {
|
||||||
|
@ -383,7 +386,7 @@ gst_flacdec_read (const FLAC__SeekableStreamDecoder *decoder,
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case GST_EVENT_DISCONTINUOUS:
|
case GST_EVENT_DISCONTINUOUS:
|
||||||
GST_DEBUG (0, "discont");
|
GST_DEBUG ("discont");
|
||||||
|
|
||||||
/* we are not yet sending the discont, we'll do that in the next write operation */
|
/* we are not yet sending the discont, we'll do that in the next write operation */
|
||||||
flacdec->need_discont = TRUE;
|
flacdec->need_discont = TRUE;
|
||||||
|
@ -435,7 +438,7 @@ gst_flacdec_write (const FLAC__SeekableStreamDecoder *decoder,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (GST_PAD_IS_USABLE (flacdec->srcpad)) {
|
if (GST_PAD_IS_USABLE (flacdec->srcpad)) {
|
||||||
GST_DEBUG (0, "send discont");
|
GST_DEBUG ("send discont");
|
||||||
|
|
||||||
format = GST_FORMAT_TIME;
|
format = GST_FORMAT_TIME;
|
||||||
gst_pad_convert (flacdec->srcpad, GST_FORMAT_DEFAULT,
|
gst_pad_convert (flacdec->srcpad, GST_FORMAT_DEFAULT,
|
||||||
|
@ -516,39 +519,39 @@ gst_flacdec_loop (GstElement *element)
|
||||||
|
|
||||||
flacdec = GST_FLACDEC (element);
|
flacdec = GST_FLACDEC (element);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO, "flacdec: entering loop");
|
GST_DEBUG ("flacdec: entering loop");
|
||||||
if (flacdec->init) {
|
if (flacdec->init) {
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO, "flacdec: initializing decoder");
|
GST_DEBUG ("flacdec: initializing decoder");
|
||||||
FLAC__seekable_stream_decoder_init (flacdec->decoder);
|
FLAC__seekable_stream_decoder_init (flacdec->decoder);
|
||||||
/* FLAC__seekable_stream_decoder_process_metadata (flacdec->decoder); */
|
/* FLAC__seekable_stream_decoder_process_metadata (flacdec->decoder); */
|
||||||
flacdec->init = FALSE;
|
flacdec->init = FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (flacdec->seek_pending) {
|
if (flacdec->seek_pending) {
|
||||||
GST_DEBUG (GST_CAT_EVENT, "perform seek to sample %" G_GINT64_FORMAT,
|
GST_DEBUG ("perform seek to sample %" G_GINT64_FORMAT,
|
||||||
flacdec->seek_value);
|
flacdec->seek_value);
|
||||||
|
|
||||||
if (FLAC__seekable_stream_decoder_seek_absolute (flacdec->decoder,
|
if (FLAC__seekable_stream_decoder_seek_absolute (flacdec->decoder,
|
||||||
flacdec->seek_value))
|
flacdec->seek_value))
|
||||||
{
|
{
|
||||||
flacdec->total_samples = flacdec->seek_value;
|
flacdec->total_samples = flacdec->seek_value;
|
||||||
GST_DEBUG (GST_CAT_EVENT, "seek done");
|
GST_DEBUG ("seek done");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
GST_DEBUG (GST_CAT_EVENT, "seek failed");
|
GST_DEBUG ("seek failed");
|
||||||
}
|
}
|
||||||
flacdec->seek_pending = FALSE;
|
flacdec->seek_pending = FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO, "flacdec: processing single");
|
GST_DEBUG ("flacdec: processing single");
|
||||||
res = FLAC__seekable_stream_decoder_process_single (flacdec->decoder);
|
res = FLAC__seekable_stream_decoder_process_single (flacdec->decoder);
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO, "flacdec: checking for EOS");
|
GST_DEBUG ("flacdec: checking for EOS");
|
||||||
if (FLAC__seekable_stream_decoder_get_state (flacdec->decoder) ==
|
if (FLAC__seekable_stream_decoder_get_state (flacdec->decoder) ==
|
||||||
FLAC__SEEKABLE_STREAM_DECODER_END_OF_STREAM)
|
FLAC__SEEKABLE_STREAM_DECODER_END_OF_STREAM)
|
||||||
{
|
{
|
||||||
GstEvent *event;
|
GstEvent *event;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO, "flacdec: sending EOS event");
|
GST_DEBUG ("flacdec: sending EOS event");
|
||||||
FLAC__seekable_stream_decoder_finish(flacdec->decoder);
|
FLAC__seekable_stream_decoder_finish(flacdec->decoder);
|
||||||
flacdec->init = TRUE;
|
flacdec->init = TRUE;
|
||||||
|
|
||||||
|
@ -558,7 +561,7 @@ gst_flacdec_loop (GstElement *element)
|
||||||
}
|
}
|
||||||
gst_element_set_eos (element);
|
gst_element_set_eos (element);
|
||||||
}
|
}
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO, "flacdec: _loop end");
|
GST_DEBUG ("flacdec: _loop end");
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_PAD_FORMATS_FUNCTION (gst_flacdec_get_src_formats,
|
GST_PAD_FORMATS_FUNCTION (gst_flacdec_get_src_formats,
|
||||||
|
|
|
@ -18,6 +18,9 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
|
|
@ -20,6 +20,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
#include <gdk-pixbuf/gdk-pixbuf.h>
|
#include <gdk-pixbuf/gdk-pixbuf.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
|
@ -18,6 +18,9 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
/*#define DEBUG_ENABLED*/
|
/*#define DEBUG_ENABLED*/
|
||||||
|
@ -88,38 +91,38 @@ gst_jpegdec_class_init (GstJpegDec *klass)
|
||||||
static void
|
static void
|
||||||
gst_jpegdec_init_source (j_decompress_ptr cinfo)
|
gst_jpegdec_init_source (j_decompress_ptr cinfo)
|
||||||
{
|
{
|
||||||
GST_DEBUG (0,"gst_jpegdec_chain: init_source");
|
GST_DEBUG ("gst_jpegdec_chain: init_source");
|
||||||
}
|
}
|
||||||
static gboolean
|
static gboolean
|
||||||
gst_jpegdec_fill_input_buffer (j_decompress_ptr cinfo)
|
gst_jpegdec_fill_input_buffer (j_decompress_ptr cinfo)
|
||||||
{
|
{
|
||||||
GST_DEBUG (0,"gst_jpegdec_chain: fill_input_buffer");
|
GST_DEBUG ("gst_jpegdec_chain: fill_input_buffer");
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_jpegdec_skip_input_data (j_decompress_ptr cinfo, glong num_bytes)
|
gst_jpegdec_skip_input_data (j_decompress_ptr cinfo, glong num_bytes)
|
||||||
{
|
{
|
||||||
GST_DEBUG (0,"gst_jpegdec_chain: skip_input_data");
|
GST_DEBUG ("gst_jpegdec_chain: skip_input_data");
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
gst_jpegdec_resync_to_restart (j_decompress_ptr cinfo, gint desired)
|
gst_jpegdec_resync_to_restart (j_decompress_ptr cinfo, gint desired)
|
||||||
{
|
{
|
||||||
GST_DEBUG (0,"gst_jpegdec_chain: resync_to_start");
|
GST_DEBUG ("gst_jpegdec_chain: resync_to_start");
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_jpegdec_term_source (j_decompress_ptr cinfo)
|
gst_jpegdec_term_source (j_decompress_ptr cinfo)
|
||||||
{
|
{
|
||||||
GST_DEBUG (0,"gst_jpegdec_chain: term_source");
|
GST_DEBUG ("gst_jpegdec_chain: term_source");
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_jpegdec_init (GstJpegDec *jpegdec)
|
gst_jpegdec_init (GstJpegDec *jpegdec)
|
||||||
{
|
{
|
||||||
GST_DEBUG (0,"gst_jpegdec_init: initializing");
|
GST_DEBUG ("gst_jpegdec_init: initializing");
|
||||||
/* create the sink and src pads */
|
/* create the sink and src pads */
|
||||||
jpegdec->sinkpad = gst_pad_new_from_template (jpegdec_sink_template, "sink");
|
jpegdec->sinkpad = gst_pad_new_from_template (jpegdec_sink_template, "sink");
|
||||||
gst_element_add_pad(GST_ELEMENT(jpegdec),jpegdec->sinkpad);
|
gst_element_add_pad(GST_ELEMENT(jpegdec),jpegdec->sinkpad);
|
||||||
|
@ -265,7 +268,7 @@ static void guarantee_huff_tables(j_decompress_ptr dinfo)
|
||||||
(dinfo->dc_huff_tbl_ptrs[1] == NULL) &&
|
(dinfo->dc_huff_tbl_ptrs[1] == NULL) &&
|
||||||
(dinfo->ac_huff_tbl_ptrs[0] == NULL) &&
|
(dinfo->ac_huff_tbl_ptrs[0] == NULL) &&
|
||||||
(dinfo->ac_huff_tbl_ptrs[1] == NULL) ) {
|
(dinfo->ac_huff_tbl_ptrs[1] == NULL) ) {
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO,
|
GST_DEBUG (
|
||||||
"Generating standard Huffman tables for this frame.");
|
"Generating standard Huffman tables for this frame.");
|
||||||
std_huff_tables(dinfo);
|
std_huff_tables(dinfo);
|
||||||
}
|
}
|
||||||
|
@ -298,14 +301,14 @@ gst_jpegdec_chain (GstPad *pad, GstBuffer *buf)
|
||||||
|
|
||||||
data = (guchar *)GST_BUFFER_DATA(buf);
|
data = (guchar *)GST_BUFFER_DATA(buf);
|
||||||
size = GST_BUFFER_SIZE(buf);
|
size = GST_BUFFER_SIZE(buf);
|
||||||
GST_DEBUG (0,"gst_jpegdec_chain: got buffer of %ld bytes in '%s'",size,
|
GST_DEBUG ("gst_jpegdec_chain: got buffer of %ld bytes in '%s'",size,
|
||||||
GST_OBJECT_NAME (jpegdec));
|
GST_OBJECT_NAME (jpegdec));
|
||||||
|
|
||||||
jpegdec->jsrc.next_input_byte = data;
|
jpegdec->jsrc.next_input_byte = data;
|
||||||
jpegdec->jsrc.bytes_in_buffer = size;
|
jpegdec->jsrc.bytes_in_buffer = size;
|
||||||
|
|
||||||
|
|
||||||
GST_DEBUG (0,"gst_jpegdec_chain: reading header %08lx", *(gulong *)data);
|
GST_DEBUG ("gst_jpegdec_chain: reading header %08lx", *(gulong *)data);
|
||||||
jpeg_read_header(&jpegdec->cinfo, TRUE);
|
jpeg_read_header(&jpegdec->cinfo, TRUE);
|
||||||
|
|
||||||
r_h = jpegdec->cinfo.cur_comp_info[0]->h_samp_factor;
|
r_h = jpegdec->cinfo.cur_comp_info[0]->h_samp_factor;
|
||||||
|
@ -320,12 +323,12 @@ gst_jpegdec_chain (GstPad *pad, GstBuffer *buf)
|
||||||
jpegdec->cinfo.out_color_space = JCS_YCbCr;
|
jpegdec->cinfo.out_color_space = JCS_YCbCr;
|
||||||
jpegdec->cinfo.dct_method = JDCT_IFAST;
|
jpegdec->cinfo.dct_method = JDCT_IFAST;
|
||||||
jpegdec->cinfo.raw_data_out = TRUE;
|
jpegdec->cinfo.raw_data_out = TRUE;
|
||||||
GST_DEBUG (0,"gst_jpegdec_chain: starting decompress");
|
GST_DEBUG ("gst_jpegdec_chain: starting decompress");
|
||||||
guarantee_huff_tables(&jpegdec->cinfo);
|
guarantee_huff_tables(&jpegdec->cinfo);
|
||||||
jpeg_start_decompress(&jpegdec->cinfo);
|
jpeg_start_decompress(&jpegdec->cinfo);
|
||||||
width = jpegdec->cinfo.output_width;
|
width = jpegdec->cinfo.output_width;
|
||||||
height = jpegdec->cinfo.output_height;
|
height = jpegdec->cinfo.output_height;
|
||||||
GST_DEBUG (0,"gst_jpegdec_chain: width %d, height %d", width, height);
|
GST_DEBUG ("gst_jpegdec_chain: width %d, height %d", width, height);
|
||||||
|
|
||||||
outbuf = gst_buffer_new();
|
outbuf = gst_buffer_new();
|
||||||
outsize = GST_BUFFER_SIZE(outbuf) = width*height +
|
outsize = GST_BUFFER_SIZE(outbuf) = width*height +
|
||||||
|
@ -356,7 +359,7 @@ gst_jpegdec_chain (GstPad *pad, GstBuffer *buf)
|
||||||
|
|
||||||
width2 = width >> 1;
|
width2 = width >> 1;
|
||||||
|
|
||||||
GST_DEBUG (0,"gst_jpegdec_chain: decompressing %u", jpegdec->cinfo.rec_outbuf_height);
|
GST_DEBUG ("gst_jpegdec_chain: decompressing %u", jpegdec->cinfo.rec_outbuf_height);
|
||||||
for (i = 0; i < height; i += r_v*DCTSIZE) {
|
for (i = 0; i < height; i += r_v*DCTSIZE) {
|
||||||
for (j=0, k=0; j< (r_v*DCTSIZE); j += r_v, k++) {
|
for (j=0, k=0; j< (r_v*DCTSIZE); j += r_v, k++) {
|
||||||
jpegdec->line[0][j] = base[0]; base[0] += width;
|
jpegdec->line[0][j] = base[0]; base[0] += width;
|
||||||
|
@ -373,10 +376,10 @@ gst_jpegdec_chain (GstPad *pad, GstBuffer *buf)
|
||||||
jpeg_read_raw_data(&jpegdec->cinfo, jpegdec->line, r_v*DCTSIZE);
|
jpeg_read_raw_data(&jpegdec->cinfo, jpegdec->line, r_v*DCTSIZE);
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (0,"gst_jpegdec_chain: decompressing finished");
|
GST_DEBUG ("gst_jpegdec_chain: decompressing finished");
|
||||||
jpeg_finish_decompress(&jpegdec->cinfo);
|
jpeg_finish_decompress(&jpegdec->cinfo);
|
||||||
|
|
||||||
GST_DEBUG (0,"gst_jpegdec_chain: sending buffer");
|
GST_DEBUG ("gst_jpegdec_chain: sending buffer");
|
||||||
gst_pad_push(jpegdec->srcpad, outbuf);
|
gst_pad_push(jpegdec->srcpad, outbuf);
|
||||||
|
|
||||||
gst_buffer_unref(buf);
|
gst_buffer_unref(buf);
|
||||||
|
|
|
@ -18,6 +18,9 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include "gstjpegenc.h"
|
#include "gstjpegenc.h"
|
||||||
|
@ -98,19 +101,19 @@ gst_jpegenc_class_init (GstJpegEnc *klass)
|
||||||
static void
|
static void
|
||||||
gst_jpegenc_init_destination (j_compress_ptr cinfo)
|
gst_jpegenc_init_destination (j_compress_ptr cinfo)
|
||||||
{
|
{
|
||||||
GST_DEBUG (0,"gst_jpegenc_chain: init_destination");
|
GST_DEBUG ("gst_jpegenc_chain: init_destination");
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
gst_jpegenc_flush_destination (j_compress_ptr cinfo)
|
gst_jpegenc_flush_destination (j_compress_ptr cinfo)
|
||||||
{
|
{
|
||||||
GST_DEBUG (0,"gst_jpegenc_chain: flush_destination: buffer too small !!!");
|
GST_DEBUG ("gst_jpegenc_chain: flush_destination: buffer too small !!!");
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void gst_jpegenc_term_destination (j_compress_ptr cinfo)
|
static void gst_jpegenc_term_destination (j_compress_ptr cinfo)
|
||||||
{
|
{
|
||||||
GST_DEBUG (0,"gst_jpegenc_chain: term_source");
|
GST_DEBUG ("gst_jpegenc_chain: term_source");
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -134,7 +137,7 @@ gst_jpegenc_init (GstJpegEnc *jpegenc)
|
||||||
jpegenc->cinfo.err = jpeg_std_error(&jpegenc->jerr);
|
jpegenc->cinfo.err = jpeg_std_error(&jpegenc->jerr);
|
||||||
jpeg_create_compress(&jpegenc->cinfo);
|
jpeg_create_compress(&jpegenc->cinfo);
|
||||||
|
|
||||||
GST_DEBUG (0,"gst_jpegenc_init: setting line buffers");
|
GST_DEBUG ("gst_jpegenc_init: setting line buffers");
|
||||||
jpegenc->line[0] = NULL;
|
jpegenc->line[0] = NULL;
|
||||||
jpegenc->line[1] = NULL;
|
jpegenc->line[1] = NULL;
|
||||||
jpegenc->line[2] = NULL;
|
jpegenc->line[2] = NULL;
|
||||||
|
@ -154,13 +157,13 @@ gst_jpegenc_resync (GstJpegEnc *jpegenc)
|
||||||
guint size = 0;
|
guint size = 0;
|
||||||
gint width, height;
|
gint width, height;
|
||||||
|
|
||||||
GST_DEBUG (0,"gst_jpegenc_resync: resync");
|
GST_DEBUG ("gst_jpegenc_resync: resync");
|
||||||
|
|
||||||
jpegenc->cinfo.image_width = width = jpegenc->width;
|
jpegenc->cinfo.image_width = width = jpegenc->width;
|
||||||
jpegenc->cinfo.image_height = height = jpegenc->height;
|
jpegenc->cinfo.image_height = height = jpegenc->height;
|
||||||
jpegenc->cinfo.input_components = 3;
|
jpegenc->cinfo.input_components = 3;
|
||||||
|
|
||||||
GST_DEBUG (0,"gst_jpegenc_resync: wdith %d, height %d", width, height);
|
GST_DEBUG ("gst_jpegenc_resync: wdith %d, height %d", width, height);
|
||||||
|
|
||||||
jpeg_set_defaults(&jpegenc->cinfo);
|
jpeg_set_defaults(&jpegenc->cinfo);
|
||||||
jpegenc->cinfo.dct_method = JDCT_FASTEST;
|
jpegenc->cinfo.dct_method = JDCT_FASTEST;
|
||||||
|
@ -172,7 +175,7 @@ gst_jpegenc_resync (GstJpegEnc *jpegenc)
|
||||||
switch (jpegenc->format) {
|
switch (jpegenc->format) {
|
||||||
case GST_COLORSPACE_RGB24:
|
case GST_COLORSPACE_RGB24:
|
||||||
size = 3;
|
size = 3;
|
||||||
GST_DEBUG (0,"gst_jpegenc_resync: setting format to RGB24");
|
GST_DEBUG ("gst_jpegenc_resync: setting format to RGB24");
|
||||||
jpegenc->cinfo.in_color_space = JCS_RGB;
|
jpegenc->cinfo.in_color_space = JCS_RGB;
|
||||||
jpegenc->cinfo.raw_data_in = FALSE;
|
jpegenc->cinfo.raw_data_in = FALSE;
|
||||||
break;
|
break;
|
||||||
|
@ -180,7 +183,7 @@ gst_jpegenc_resync (GstJpegEnc *jpegenc)
|
||||||
size = 2;
|
size = 2;
|
||||||
jpegenc->cinfo.raw_data_in = TRUE;
|
jpegenc->cinfo.raw_data_in = TRUE;
|
||||||
jpegenc->cinfo.in_color_space = JCS_YCbCr;
|
jpegenc->cinfo.in_color_space = JCS_YCbCr;
|
||||||
GST_DEBUG (0,"gst_jpegenc_resync: setting format to YUV420P");
|
GST_DEBUG ("gst_jpegenc_resync: setting format to YUV420P");
|
||||||
jpegenc->cinfo.comp_info[0].h_samp_factor = 2;
|
jpegenc->cinfo.comp_info[0].h_samp_factor = 2;
|
||||||
jpegenc->cinfo.comp_info[0].v_samp_factor = 2;
|
jpegenc->cinfo.comp_info[0].v_samp_factor = 2;
|
||||||
jpegenc->cinfo.comp_info[1].h_samp_factor = 1;
|
jpegenc->cinfo.comp_info[1].h_samp_factor = 1;
|
||||||
|
@ -194,7 +197,7 @@ gst_jpegenc_resync (GstJpegEnc *jpegenc)
|
||||||
jpegenc->line[2] = g_realloc(jpegenc->line[2], height*sizeof(char*)/2);
|
jpegenc->line[2] = g_realloc(jpegenc->line[2], height*sizeof(char*)/2);
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (0,"gst_jpegenc_resync: setting format done");
|
GST_DEBUG ("gst_jpegenc_resync: setting format done");
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
printf("gst_jpegenc_resync: unsupported colorspace, using RGB\n");
|
printf("gst_jpegenc_resync: unsupported colorspace, using RGB\n");
|
||||||
|
@ -209,7 +212,7 @@ gst_jpegenc_resync (GstJpegEnc *jpegenc)
|
||||||
jpeg_suppress_tables(&jpegenc->cinfo, TRUE);
|
jpeg_suppress_tables(&jpegenc->cinfo, TRUE);
|
||||||
|
|
||||||
jpegenc->buffer = NULL;
|
jpegenc->buffer = NULL;
|
||||||
GST_DEBUG (0,"gst_jpegenc_resync: resync done");
|
GST_DEBUG ("gst_jpegenc_resync: resync done");
|
||||||
}
|
}
|
||||||
|
|
||||||
static GstBuffer*
|
static GstBuffer*
|
||||||
|
@ -218,7 +221,7 @@ gst_jpegenc_get (GstPad *pad)
|
||||||
GstJpegEnc *jpegenc;
|
GstJpegEnc *jpegenc;
|
||||||
GstBuffer *newbuf;
|
GstBuffer *newbuf;
|
||||||
|
|
||||||
GST_DEBUG (0,"gst_jpegenc_chain: pull buffer");
|
GST_DEBUG ("gst_jpegenc_chain: pull buffer");
|
||||||
|
|
||||||
g_return_val_if_fail (pad != NULL, NULL);
|
g_return_val_if_fail (pad != NULL, NULL);
|
||||||
g_return_val_if_fail (GST_IS_PAD (pad), NULL);
|
g_return_val_if_fail (GST_IS_PAD (pad), NULL);
|
||||||
|
@ -227,7 +230,7 @@ gst_jpegenc_get (GstPad *pad)
|
||||||
|
|
||||||
if (jpegenc->buffer == NULL || GST_BUFFER_REFCOUNT_VALUE(jpegenc->buffer) != 1) {
|
if (jpegenc->buffer == NULL || GST_BUFFER_REFCOUNT_VALUE(jpegenc->buffer) != 1) {
|
||||||
if (jpegenc->buffer) gst_buffer_unref(jpegenc->buffer);
|
if (jpegenc->buffer) gst_buffer_unref(jpegenc->buffer);
|
||||||
GST_DEBUG (0,"gst_jpegenc_chain: new buffer");
|
GST_DEBUG ("gst_jpegenc_chain: new buffer");
|
||||||
newbuf = jpegenc->buffer = gst_buffer_new();
|
newbuf = jpegenc->buffer = gst_buffer_new();
|
||||||
GST_BUFFER_DATA(newbuf) = g_malloc(jpegenc->bufsize);
|
GST_BUFFER_DATA(newbuf) = g_malloc(jpegenc->bufsize);
|
||||||
GST_BUFFER_SIZE(newbuf) = jpegenc->bufsize;
|
GST_BUFFER_SIZE(newbuf) = jpegenc->bufsize;
|
||||||
|
@ -260,7 +263,7 @@ gst_jpegenc_chain (GstPad *pad, GstBuffer *buf)
|
||||||
data = GST_BUFFER_DATA(buf);
|
data = GST_BUFFER_DATA(buf);
|
||||||
size = GST_BUFFER_SIZE(buf);
|
size = GST_BUFFER_SIZE(buf);
|
||||||
|
|
||||||
GST_DEBUG (0,"gst_jpegenc_chain: got buffer of %ld bytes in '%s'",size,
|
GST_DEBUG ("gst_jpegenc_chain: got buffer of %ld bytes in '%s'",size,
|
||||||
GST_OBJECT_NAME (jpegenc));
|
GST_OBJECT_NAME (jpegenc));
|
||||||
|
|
||||||
outbuf = gst_buffer_new();
|
outbuf = gst_buffer_new();
|
||||||
|
@ -281,7 +284,7 @@ gst_jpegenc_chain (GstPad *pad, GstBuffer *buf)
|
||||||
jpeg_start_compress(&jpegenc->cinfo, TRUE);
|
jpeg_start_compress(&jpegenc->cinfo, TRUE);
|
||||||
|
|
||||||
width2 = width>>1;
|
width2 = width>>1;
|
||||||
GST_DEBUG (0,"gst_jpegdec_chain: compressing");
|
GST_DEBUG ("gst_jpegdec_chain: compressing");
|
||||||
|
|
||||||
for (i = 0; i < height; i += 2*DCTSIZE) {
|
for (i = 0; i < height; i += 2*DCTSIZE) {
|
||||||
for (j=0, k=0; j<2*DCTSIZE;j+=2, k++) {
|
for (j=0, k=0; j<2*DCTSIZE;j+=2, k++) {
|
||||||
|
@ -293,7 +296,7 @@ gst_jpegenc_chain (GstPad *pad, GstBuffer *buf)
|
||||||
jpeg_write_raw_data(&jpegenc->cinfo, jpegenc->line, 2*DCTSIZE);
|
jpeg_write_raw_data(&jpegenc->cinfo, jpegenc->line, 2*DCTSIZE);
|
||||||
}
|
}
|
||||||
jpeg_finish_compress(&jpegenc->cinfo);
|
jpeg_finish_compress(&jpegenc->cinfo);
|
||||||
GST_DEBUG (0,"gst_jpegdec_chain: compressing done");
|
GST_DEBUG ("gst_jpegdec_chain: compressing done");
|
||||||
|
|
||||||
GST_BUFFER_SIZE(outbuf) = (((outsize - jpegenc->jdest.free_in_buffer)+3)&~3);
|
GST_BUFFER_SIZE(outbuf) = (((outsize - jpegenc->jdest.free_in_buffer)+3)&~3);
|
||||||
|
|
||||||
|
|
|
@ -170,19 +170,19 @@ gst_ladspa_class_init (GstLADSPAClass *klass)
|
||||||
for (i=0;i<desc->PortCount;i++) {
|
for (i=0;i<desc->PortCount;i++) {
|
||||||
if (LADSPA_IS_PORT_AUDIO(desc->PortDescriptors[i]) &&
|
if (LADSPA_IS_PORT_AUDIO(desc->PortDescriptors[i]) &&
|
||||||
LADSPA_IS_PORT_INPUT(desc->PortDescriptors[i])){
|
LADSPA_IS_PORT_INPUT(desc->PortDescriptors[i])){
|
||||||
GST_DEBUG (0, "input port %d", i);
|
GST_DEBUG ("input port %d", i);
|
||||||
klass->sinkpad_portnums[sinkcount++] = i;
|
klass->sinkpad_portnums[sinkcount++] = i;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (LADSPA_IS_PORT_AUDIO(desc->PortDescriptors[i]) &&
|
if (LADSPA_IS_PORT_AUDIO(desc->PortDescriptors[i]) &&
|
||||||
LADSPA_IS_PORT_OUTPUT(desc->PortDescriptors[i])){
|
LADSPA_IS_PORT_OUTPUT(desc->PortDescriptors[i])){
|
||||||
GST_DEBUG (0, "output port %d", i);
|
GST_DEBUG ("output port %d", i);
|
||||||
klass->srcpad_portnums[srccount++] = i;
|
klass->srcpad_portnums[srccount++] = i;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (LADSPA_IS_PORT_CONTROL(desc->PortDescriptors[i]) &&
|
if (LADSPA_IS_PORT_CONTROL(desc->PortDescriptors[i]) &&
|
||||||
LADSPA_IS_PORT_INPUT(desc->PortDescriptors[i])){
|
LADSPA_IS_PORT_INPUT(desc->PortDescriptors[i])){
|
||||||
GST_DEBUG (0, "control port %d", i);
|
GST_DEBUG ("control port %d", i);
|
||||||
klass->control_portnums[controlcount++] = i;
|
klass->control_portnums[controlcount++] = i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -324,7 +324,7 @@ gst_ladspa_class_init (GstLADSPAClass *klass)
|
||||||
|
|
||||||
klass->control_info[i].param_name = argname;
|
klass->control_info[i].param_name = argname;
|
||||||
|
|
||||||
GST_DEBUG (0, "adding arg %s from %s",argname, klass->control_info[i].name);
|
GST_DEBUG ("adding arg %s from %s",argname, klass->control_info[i].name);
|
||||||
|
|
||||||
if (argtype==G_TYPE_BOOLEAN){
|
if (argtype==G_TYPE_BOOLEAN){
|
||||||
paramspec = g_param_spec_boolean(argname,argname,argname, FALSE, argperms);
|
paramspec = g_param_spec_boolean(argname,argname,argname, FALSE, argperms);
|
||||||
|
@ -443,7 +443,7 @@ gst_ladspa_init (GstLADSPA *ladspa)
|
||||||
|
|
||||||
if (sinkcount==0 && srccount == 1) {
|
if (sinkcount==0 && srccount == 1) {
|
||||||
/* get mode (no sink pads) */
|
/* get mode (no sink pads) */
|
||||||
GST_DEBUG (0, "mono get mode with 1 src pad");
|
GST_DEBUG ("mono get mode with 1 src pad");
|
||||||
|
|
||||||
ladspa->newcaps = TRUE;
|
ladspa->newcaps = TRUE;
|
||||||
|
|
||||||
|
@ -451,14 +451,14 @@ gst_ladspa_init (GstLADSPA *ladspa)
|
||||||
gst_pad_set_get_function (ladspa->srcpads[0], gst_ladspa_get);
|
gst_pad_set_get_function (ladspa->srcpads[0], gst_ladspa_get);
|
||||||
} else if (sinkcount==1){
|
} else if (sinkcount==1){
|
||||||
/* with one sink we can use the chain function */
|
/* with one sink we can use the chain function */
|
||||||
GST_DEBUG (0, "chain mode");
|
GST_DEBUG ("chain mode");
|
||||||
|
|
||||||
gst_pad_set_link_function (ladspa->sinkpads[0], gst_ladspa_connect);
|
gst_pad_set_link_function (ladspa->sinkpads[0], gst_ladspa_connect);
|
||||||
gst_pad_set_chain_function (ladspa->sinkpads[0], gst_ladspa_chain);
|
gst_pad_set_chain_function (ladspa->sinkpads[0], gst_ladspa_chain);
|
||||||
gst_pad_set_bufferpool_function (ladspa->sinkpads[0], gst_ladspa_get_bufferpool);
|
gst_pad_set_bufferpool_function (ladspa->sinkpads[0], gst_ladspa_get_bufferpool);
|
||||||
} else if (sinkcount > 1){
|
} else if (sinkcount > 1){
|
||||||
/* more than one sink pad needs loop mode */
|
/* more than one sink pad needs loop mode */
|
||||||
GST_DEBUG (0, "loop mode with %d sink pads and %d src pads", sinkcount, srccount);
|
GST_DEBUG ("loop mode with %d sink pads and %d src pads", sinkcount, srccount);
|
||||||
|
|
||||||
for (i=0;i<sinkcount;i++) {
|
for (i=0;i<sinkcount;i++) {
|
||||||
gst_pad_set_link_function (ladspa->sinkpads[i], gst_ladspa_connect);
|
gst_pad_set_link_function (ladspa->sinkpads[i], gst_ladspa_connect);
|
||||||
|
@ -469,7 +469,7 @@ gst_ladspa_init (GstLADSPA *ladspa)
|
||||||
else if (sinkcount==0 && srccount == 0){
|
else if (sinkcount==0 && srccount == 0){
|
||||||
/* for some reason these plugins exist - we'll just ignore them */
|
/* for some reason these plugins exist - we'll just ignore them */
|
||||||
} else {
|
} else {
|
||||||
GST_DEBUG (0, "%d sink pads, %d src pads not yet supported", sinkcount, srccount);
|
GST_DEBUG ("%d sink pads, %d src pads not yet supported", sinkcount, srccount);
|
||||||
}
|
}
|
||||||
|
|
||||||
gst_ladspa_instantiate (ladspa);
|
gst_ladspa_instantiate (ladspa);
|
||||||
|
@ -539,7 +539,7 @@ gst_ladspa_connect_get (GstPad *pad, GstCaps *caps)
|
||||||
static void
|
static void
|
||||||
gst_ladspa_force_src_caps(GstLADSPA *ladspa, GstPad *pad)
|
gst_ladspa_force_src_caps(GstLADSPA *ladspa, GstPad *pad)
|
||||||
{
|
{
|
||||||
GST_DEBUG (0, "forcing caps with rate %d", ladspa->samplerate);
|
GST_DEBUG ("forcing caps with rate %d", ladspa->samplerate);
|
||||||
gst_pad_try_set_caps (pad, gst_caps_new (
|
gst_pad_try_set_caps (pad, gst_caps_new (
|
||||||
"ladspa_src_caps",
|
"ladspa_src_caps",
|
||||||
"audio/raw",
|
"audio/raw",
|
||||||
|
@ -605,7 +605,7 @@ gst_ladspa_set_property (GObject *object, guint prop_id, const GValue *value, GP
|
||||||
ladspa->controls[cid] = val;
|
ladspa->controls[cid] = val;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (0, "set arg %s to %f", control_info->name, ladspa->controls[cid]);
|
GST_DEBUG ("set arg %s to %f", control_info->name, ladspa->controls[cid]);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -633,7 +633,7 @@ gst_ladspa_get_property (GObject *object, guint prop_id, GValue *value, GParamSp
|
||||||
control_info = &(oclass->control_info[cid]);
|
control_info = &(oclass->control_info[cid]);
|
||||||
if (control_info->name == NULL) return;
|
if (control_info->name == NULL) return;
|
||||||
|
|
||||||
GST_DEBUG (0, "got arg %s as %f", control_info->name, ladspa->controls[cid]);
|
GST_DEBUG ("got arg %s as %f", control_info->name, ladspa->controls[cid]);
|
||||||
|
|
||||||
/* now see what type it is */
|
/* now see what type it is */
|
||||||
if (control_info->toggled) {
|
if (control_info->toggled) {
|
||||||
|
@ -666,7 +666,7 @@ gst_ladspa_instantiate (GstLADSPA *ladspa)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* instantiate the plugin */
|
/* instantiate the plugin */
|
||||||
GST_DEBUG (0, "instantiating the plugin");
|
GST_DEBUG ("instantiating the plugin");
|
||||||
|
|
||||||
ladspa->handle = desc->instantiate(desc,ladspa->samplerate);
|
ladspa->handle = desc->instantiate(desc,ladspa->samplerate);
|
||||||
g_return_val_if_fail (ladspa->handle != NULL, FALSE);
|
g_return_val_if_fail (ladspa->handle != NULL, FALSE);
|
||||||
|
@ -674,7 +674,7 @@ gst_ladspa_instantiate (GstLADSPA *ladspa)
|
||||||
/* walk through the ports and add all the arguments */
|
/* walk through the ports and add all the arguments */
|
||||||
for (i=0;i<oclass->numcontrols;i++) {
|
for (i=0;i<oclass->numcontrols;i++) {
|
||||||
/* connect the argument to the plugin */
|
/* connect the argument to the plugin */
|
||||||
GST_DEBUG (0, "added control port %d", oclass->control_portnums[i]);
|
GST_DEBUG ("added control port %d", oclass->control_portnums[i]);
|
||||||
desc->connect_port(ladspa->handle,
|
desc->connect_port(ladspa->handle,
|
||||||
oclass->control_portnums[i],
|
oclass->control_portnums[i],
|
||||||
&(ladspa->controls[i]));
|
&(ladspa->controls[i]));
|
||||||
|
@ -694,7 +694,7 @@ gst_ladspa_change_state (GstElement *element)
|
||||||
GstLADSPA *ladspa = (GstLADSPA*)element;
|
GstLADSPA *ladspa = (GstLADSPA*)element;
|
||||||
desc = ladspa->descriptor;
|
desc = ladspa->descriptor;
|
||||||
|
|
||||||
GST_DEBUG (0, "changing state");
|
GST_DEBUG ("changing state");
|
||||||
switch (GST_STATE_TRANSITION (element)) {
|
switch (GST_STATE_TRANSITION (element)) {
|
||||||
case GST_STATE_NULL_TO_READY:
|
case GST_STATE_NULL_TO_READY:
|
||||||
gst_ladspa_activate(ladspa);
|
gst_ladspa_activate(ladspa);
|
||||||
|
@ -722,7 +722,7 @@ gst_ladspa_activate(GstLADSPA *ladspa)
|
||||||
gst_ladspa_deactivate(ladspa);
|
gst_ladspa_deactivate(ladspa);
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (0, "activating");
|
GST_DEBUG ("activating");
|
||||||
|
|
||||||
/* activate the plugin (function might be null) */
|
/* activate the plugin (function might be null) */
|
||||||
if (desc->activate != NULL) {
|
if (desc->activate != NULL) {
|
||||||
|
@ -738,7 +738,7 @@ gst_ladspa_deactivate(GstLADSPA *ladspa)
|
||||||
LADSPA_Descriptor *desc;
|
LADSPA_Descriptor *desc;
|
||||||
desc = ladspa->descriptor;
|
desc = ladspa->descriptor;
|
||||||
|
|
||||||
GST_DEBUG (0, "deactivating");
|
GST_DEBUG ("deactivating");
|
||||||
|
|
||||||
/* deactivate the plugin (function might be null) */
|
/* deactivate the plugin (function might be null) */
|
||||||
if (ladspa->activated && (desc->deactivate != NULL)) {
|
if (ladspa->activated && (desc->deactivate != NULL)) {
|
||||||
|
@ -776,11 +776,11 @@ gst_ladspa_loop(GstElement *element)
|
||||||
|
|
||||||
/* find a bufferpool */
|
/* find a bufferpool */
|
||||||
if (numsrcpads > 0 && (bufpool = gst_pad_get_bufferpool (ladspa->srcpads[0]))) {
|
if (numsrcpads > 0 && (bufpool = gst_pad_get_bufferpool (ladspa->srcpads[0]))) {
|
||||||
GST_DEBUG (0, "Got bufferpool from first source pad");
|
GST_DEBUG ("Got bufferpool from first source pad");
|
||||||
} else {
|
} else {
|
||||||
bufferbytesize = sizeof (LADSPA_Data) * ladspa->buffersize;
|
bufferbytesize = sizeof (LADSPA_Data) * ladspa->buffersize;
|
||||||
bufpool = gst_buffer_pool_get_default (bufferbytesize, ladspa->numbuffers);
|
bufpool = gst_buffer_pool_get_default (bufferbytesize, ladspa->numbuffers);
|
||||||
GST_DEBUG (0, "Created default bufferpool, %d x %d bytes", ladspa->numbuffers, bufferbytesize);
|
GST_DEBUG ("Created default bufferpool, %d x %d bytes", ladspa->numbuffers, bufferbytesize);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* get the bytestreams for each pad */
|
/* get the bytestreams for each pad */
|
||||||
|
@ -803,7 +803,7 @@ gst_ladspa_loop(GstElement *element)
|
||||||
num_empty_pads = 0;
|
num_empty_pads = 0;
|
||||||
/* first get all the necessary data from the input ports */
|
/* first get all the necessary data from the input ports */
|
||||||
for (i=0 ; i<numsinkpads ; i++){
|
for (i=0 ; i<numsinkpads ; i++){
|
||||||
GST_DEBUG (0, "pulling %u bytes through channel %d's bytestream", bufferbytesize, i);
|
GST_DEBUG ("pulling %u bytes through channel %d's bytestream", bufferbytesize, i);
|
||||||
got_bytes = gst_bytestream_read (bytestreams[i], buffers_in + i, bufferbytesize);
|
got_bytes = gst_bytestream_read (bytestreams[i], buffers_in + i, bufferbytesize);
|
||||||
|
|
||||||
if (got_bytes != bufferbytesize) {
|
if (got_bytes != bufferbytesize) {
|
||||||
|
@ -814,7 +814,7 @@ gst_ladspa_loop(GstElement *element)
|
||||||
/* if we get an EOS event from one of our sink pads, we assume that
|
/* if we get an EOS event from one of our sink pads, we assume that
|
||||||
pad's finished handling data. delete the bytestream, free up the
|
pad's finished handling data. delete the bytestream, free up the
|
||||||
pad, and free up the memory associated with the input channel. */
|
pad, and free up the memory associated with the input channel. */
|
||||||
GST_DEBUG (0, "got an EOS event on sinkpad %d", i);
|
GST_DEBUG ("got an EOS event on sinkpad %d", i);
|
||||||
}
|
}
|
||||||
/* CHECKME should maybe check for other events and try to pull more data here */
|
/* CHECKME should maybe check for other events and try to pull more data here */
|
||||||
num_empty_pads++;
|
num_empty_pads++;
|
||||||
|
@ -845,7 +845,7 @@ gst_ladspa_loop(GstElement *element)
|
||||||
else {
|
else {
|
||||||
/* all pads have EOS, time to quit */
|
/* all pads have EOS, time to quit */
|
||||||
/* CHECKME do I have to push EOS events here? */
|
/* CHECKME do I have to push EOS events here? */
|
||||||
GST_DEBUG (0, "All sink pads have EOS, finishing.");
|
GST_DEBUG ("All sink pads have EOS, finishing.");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -878,7 +878,7 @@ gst_ladspa_loop(GstElement *element)
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i=0 ; i<numsrcpads ; i++) {
|
for (i=0 ; i<numsrcpads ; i++) {
|
||||||
GST_DEBUG (0, "pushing buffer (%p) on src pad %d", buffers_out[i], i);
|
GST_DEBUG ("pushing buffer (%p) on src pad %d", buffers_out[i], i);
|
||||||
gst_pad_push (ladspa->srcpads[i], buffers_out[i]);
|
gst_pad_push (ladspa->srcpads[i], buffers_out[i]);
|
||||||
|
|
||||||
data_out[i] = NULL;
|
data_out[i] = NULL;
|
||||||
|
|
|
@ -16,6 +16,9 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
#include "gstpngenc.h"
|
#include "gstpngenc.h"
|
||||||
|
@ -198,7 +201,7 @@ gst_pngenc_chain (GstPad *pad, GstBuffer *buf)
|
||||||
/* non-0 return is from a longjmp inside of libpng */
|
/* non-0 return is from a longjmp inside of libpng */
|
||||||
if (setjmp (pngenc->png_struct_ptr->jmpbuf) != 0)
|
if (setjmp (pngenc->png_struct_ptr->jmpbuf) != 0)
|
||||||
{
|
{
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO, "returning from longjmp");
|
GST_DEBUG ("returning from longjmp");
|
||||||
png_destroy_write_struct (&pngenc->png_struct_ptr, &pngenc->png_info_ptr);
|
png_destroy_write_struct (&pngenc->png_struct_ptr, &pngenc->png_info_ptr);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,6 +17,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include "gstmikmod.h"
|
#include "gstmikmod.h"
|
||||||
|
|
||||||
#include <gst/audio/audio.h>
|
#include <gst/audio/audio.h>
|
||||||
|
@ -406,7 +409,7 @@ GstMikMod *mikmod;
|
||||||
|
|
||||||
mikmod = GST_MIKMOD (element);
|
mikmod = GST_MIKMOD (element);
|
||||||
|
|
||||||
GST_DEBUG (0,"state pending %d", GST_STATE_PENDING (element));
|
GST_DEBUG ("state pending %d", GST_STATE_PENDING (element));
|
||||||
|
|
||||||
if (GST_STATE_PENDING (element) == GST_STATE_READY)
|
if (GST_STATE_PENDING (element) == GST_STATE_READY)
|
||||||
{
|
{
|
||||||
|
|
|
@ -18,6 +18,9 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -226,32 +226,32 @@ int gst_dv1394src_iso_receive(raw1394handle_t handle,int channel,size_t len,quad
|
||||||
if( p[3] & 0x80 ) {
|
if( p[3] & 0x80 ) {
|
||||||
// PAL
|
// PAL
|
||||||
dv1394src->frameSize = PAL_FRAMESIZE;
|
dv1394src->frameSize = PAL_FRAMESIZE;
|
||||||
GST_DEBUG(0,"PAL data");
|
GST_DEBUG ("PAL data");
|
||||||
if (gst_pad_try_set_caps (dv1394src->srcpad,
|
if (gst_pad_try_set_caps (dv1394src->srcpad,
|
||||||
GST_CAPS_NEW ( "dv1394src", "video/dv",
|
GST_CAPS_NEW ( "dv1394src", "video/dv",
|
||||||
"format", GST_PROPS_STRING("PAL"),
|
"format", GST_PROPS_STRING("PAL"),
|
||||||
NULL)
|
NULL)
|
||||||
) <= 0) {
|
) <= 0) {
|
||||||
GST_ERROR(GST_ELEMENT(dv1394src), "Could not set source caps for PAL");
|
gst_element_error (GST_ELEMENT(dv1394src), "Could not set source caps for PAL");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// NTSC (untested)
|
// NTSC (untested)
|
||||||
dv1394src->frameSize = NTSC_FRAMESIZE;
|
dv1394src->frameSize = NTSC_FRAMESIZE;
|
||||||
GST_DEBUG(0,"NTSC data [untested] - please report success/failure to <dan@f3c.com>");
|
GST_DEBUG ("NTSC data [untested] - please report success/failure to <dan@f3c.com>");
|
||||||
if (gst_pad_try_set_caps (dv1394src->srcpad,
|
if (gst_pad_try_set_caps (dv1394src->srcpad,
|
||||||
GST_CAPS_NEW ( "dv1394src", "video/dv",
|
GST_CAPS_NEW ( "dv1394src", "video/dv",
|
||||||
"format", GST_PROPS_STRING ("NTSC"),
|
"format", GST_PROPS_STRING ("NTSC"),
|
||||||
NULL)
|
NULL)
|
||||||
) <= 0) {
|
) <= 0) {
|
||||||
GST_ERROR(GST_ELEMENT(dv1394src), "Could not set source caps for NTSC");
|
gst_element_error (GST_ELEMENT(dv1394src), "Could not set source caps for NTSC");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
dv1394src->pool = gst_buffer_pool_get_default( dv1394src->frameSize, N_BUFFERS_IN_POOL );
|
dv1394src->pool = gst_buffer_pool_get_default( dv1394src->frameSize, N_BUFFERS_IN_POOL );
|
||||||
if (dv1394src->pool == NULL) {
|
if (dv1394src->pool == NULL) {
|
||||||
GST_ERROR(GST_ELEMENT(dv1394src), "gst_buffer_pool_get_default returned NULL");
|
gst_element_error (GST_ELEMENT(dv1394src), "gst_buffer_pool_get_default returned NULL");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -259,7 +259,7 @@ int gst_dv1394src_iso_receive(raw1394handle_t handle,int channel,size_t len,quad
|
||||||
if( !dv1394src->drop_incomplete || dv1394src->bytesInFrame == dv1394src->frameSize ) {
|
if( !dv1394src->drop_incomplete || dv1394src->bytesInFrame == dv1394src->frameSize ) {
|
||||||
dv1394src->buf = dv1394src->frame;
|
dv1394src->buf = dv1394src->frame;
|
||||||
} else {
|
} else {
|
||||||
GST_INFO_ELEMENT(GST_CAT_PLUGIN_INFO, GST_ELEMENT(dv1394src), "incomplete frame dropped");
|
GST_INFO_OBJECT (GST_ELEMENT(dv1394src), "incomplete frame dropped");
|
||||||
}
|
}
|
||||||
dv1394src->frame = NULL;
|
dv1394src->frame = NULL;
|
||||||
|
|
||||||
|
@ -310,7 +310,7 @@ int gst_dv1394src_iso_receive(raw1394handle_t handle,int channel,size_t len,quad
|
||||||
static
|
static
|
||||||
int gst_dv1394src_bus_reset(raw1394handle_t handle,
|
int gst_dv1394src_bus_reset(raw1394handle_t handle,
|
||||||
unsigned int generation) {
|
unsigned int generation) {
|
||||||
GST_INFO_ELEMENT(0,GST_DV1394SRC(raw1394_get_userdata(handle)),"have bus reset");
|
GST_INFO_OBJECT (GST_DV1394SRC(raw1394_get_userdata(handle)),"have bus reset");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -337,31 +337,31 @@ gst_dv1394src_change_state (GstElement *element)
|
||||||
switch (GST_STATE_TRANSITION (element)) {
|
switch (GST_STATE_TRANSITION (element)) {
|
||||||
case GST_STATE_NULL_TO_READY:
|
case GST_STATE_NULL_TO_READY:
|
||||||
if ((dv1394src->handle = raw1394_new_handle()) == NULL) {
|
if ((dv1394src->handle = raw1394_new_handle()) == NULL) {
|
||||||
GST_INFO_ELEMENT(0,dv1394src,"can't get raw1394 handle");
|
GST_INFO_OBJECT (dv1394src,"can't get raw1394 handle");
|
||||||
return GST_STATE_FAILURE;
|
return GST_STATE_FAILURE;
|
||||||
}
|
}
|
||||||
raw1394_set_userdata(dv1394src->handle,dv1394src);
|
raw1394_set_userdata(dv1394src->handle,dv1394src);
|
||||||
dv1394src->numcards = raw1394_get_port_info(dv1394src->handle,dv1394src->pinfo,16);
|
dv1394src->numcards = raw1394_get_port_info(dv1394src->handle,dv1394src->pinfo,16);
|
||||||
if (dv1394src->numcards == 0) {
|
if (dv1394src->numcards == 0) {
|
||||||
GST_INFO_ELEMENT(0,dv1394src,"no cards available for raw1394");
|
GST_INFO_OBJECT (dv1394src,"no cards available for raw1394");
|
||||||
return GST_STATE_FAILURE;
|
return GST_STATE_FAILURE;
|
||||||
}
|
}
|
||||||
if (dv1394src->pinfo[dv1394src->card].nodes <= 1) {
|
if (dv1394src->pinfo[dv1394src->card].nodes <= 1) {
|
||||||
GST_INFO_ELEMENT(0,dv1394src,"there are no nodes on the 1394 bus");
|
GST_INFO_OBJECT (dv1394src,"there are no nodes on the 1394 bus");
|
||||||
return GST_STATE_FAILURE;
|
return GST_STATE_FAILURE;
|
||||||
}
|
}
|
||||||
if (raw1394_set_port(dv1394src->handle,dv1394src->port) < 0) {
|
if (raw1394_set_port(dv1394src->handle,dv1394src->port) < 0) {
|
||||||
GST_INFO_ELEMENT(0,dv1394src,"can't set 1394 port %d",dv1394src->port);
|
GST_INFO_OBJECT (dv1394src,"can't set 1394 port %d",dv1394src->port);
|
||||||
return GST_STATE_FAILURE;
|
return GST_STATE_FAILURE;
|
||||||
}
|
}
|
||||||
raw1394_set_iso_handler(dv1394src->handle,dv1394src->channel,gst_dv1394src_iso_receive);
|
raw1394_set_iso_handler(dv1394src->handle,dv1394src->channel,gst_dv1394src_iso_receive);
|
||||||
raw1394_set_bus_reset_handler(dv1394src->handle,gst_dv1394src_bus_reset);
|
raw1394_set_bus_reset_handler(dv1394src->handle,gst_dv1394src_bus_reset);
|
||||||
dv1394src->started = FALSE;
|
dv1394src->started = FALSE;
|
||||||
GST_DEBUG(0,"successfully opened up 1394 connection");
|
GST_DEBUG ("successfully opened up 1394 connection");
|
||||||
break;
|
break;
|
||||||
case GST_STATE_PAUSED_TO_PLAYING:
|
case GST_STATE_PAUSED_TO_PLAYING:
|
||||||
if (raw1394_start_iso_rcv(dv1394src->handle,dv1394src->channel) < 0) {
|
if (raw1394_start_iso_rcv(dv1394src->handle,dv1394src->channel) < 0) {
|
||||||
GST_INFO_ELEMENT(0,dv1394src,"can't start 1394 iso receive");
|
GST_INFO_OBJECT (dv1394src,"can't start 1394 iso receive");
|
||||||
return GST_STATE_FAILURE;
|
return GST_STATE_FAILURE;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -17,6 +17,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include "gstshout2.h"
|
#include "gstshout2.h"
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
@ -390,7 +393,7 @@ gst_shout2send_change_state (GstElement *element)
|
||||||
|
|
||||||
shout2send = GST_SHOUT2SEND(element);
|
shout2send = GST_SHOUT2SEND(element);
|
||||||
|
|
||||||
GST_DEBUG (0,"state pending %d", GST_STATE_PENDING (element));
|
GST_DEBUG ("state pending %d", GST_STATE_PENDING (element));
|
||||||
|
|
||||||
/* if going down into NULL state, close the file if it's open */
|
/* if going down into NULL state, close the file if it's open */
|
||||||
switch (GST_STATE_TRANSITION (element)) {
|
switch (GST_STATE_TRANSITION (element)) {
|
||||||
|
|
|
@ -18,6 +18,9 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include "gstspeexdec.h"
|
#include "gstspeexdec.h"
|
||||||
|
@ -87,7 +90,7 @@ gst_speexdec_class_init (GstSpeexDec *klass)
|
||||||
static void
|
static void
|
||||||
gst_speexdec_init (GstSpeexDec *speexdec)
|
gst_speexdec_init (GstSpeexDec *speexdec)
|
||||||
{
|
{
|
||||||
GST_DEBUG (0,"gst_speexdec_init: initializing");
|
GST_DEBUG ("gst_speexdec_init: initializing");
|
||||||
|
|
||||||
/* create the sink and src pads */
|
/* create the sink and src pads */
|
||||||
speexdec->sinkpad = gst_pad_new_from_template (speexdec_sink_template, "sink");
|
speexdec->sinkpad = gst_pad_new_from_template (speexdec_sink_template, "sink");
|
||||||
|
|
|
@ -18,6 +18,9 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include "gstspeexenc.h"
|
#include "gstspeexenc.h"
|
||||||
|
|
|
@ -30,6 +30,9 @@
|
||||||
* - this might be improved upon with bytestream
|
* - this might be improved upon with bytestream
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
#include "gstfilter.h"
|
#include "gstfilter.h"
|
||||||
#include <math.h> /* M_PI */
|
#include <math.h> /* M_PI */
|
||||||
|
@ -197,7 +200,7 @@ gst_bpwsinc_sink_connect (GstPad * pad, GstCaps * caps)
|
||||||
{
|
{
|
||||||
len = filter->wing_size;
|
len = filter->wing_size;
|
||||||
/* fill the lp kernel */
|
/* fill the lp kernel */
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO,
|
GST_DEBUG (
|
||||||
"bpwsinc: initializing LP kernel of length %d with cut-off %f",
|
"bpwsinc: initializing LP kernel of length %d with cut-off %f",
|
||||||
len * 2 + 1, filter->lower_frequency);
|
len * 2 + 1, filter->lower_frequency);
|
||||||
kernel_lp = (double *) g_malloc (sizeof (double) * (2 * len + 1));
|
kernel_lp = (double *) g_malloc (sizeof (double) * (2 * len + 1));
|
||||||
|
@ -220,7 +223,7 @@ gst_bpwsinc_sink_connect (GstPad * pad, GstCaps * caps)
|
||||||
for (i = 0; i <= len * 2; ++i) kernel_lp[i] /= sum;
|
for (i = 0; i <= len * 2; ++i) kernel_lp[i] /= sum;
|
||||||
|
|
||||||
/* fill the hp kernel */
|
/* fill the hp kernel */
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO,
|
GST_DEBUG (
|
||||||
"bpwsinc: initializing HP kernel of length %d with cut-off %f",
|
"bpwsinc: initializing HP kernel of length %d with cut-off %f",
|
||||||
len * 2 + 1, filter->upper_frequency);
|
len * 2 + 1, filter->upper_frequency);
|
||||||
kernel_hp = (double *) g_malloc (sizeof (double) * (2 * len + 1));
|
kernel_hp = (double *) g_malloc (sizeof (double) * (2 * len + 1));
|
||||||
|
|
|
@ -30,6 +30,9 @@
|
||||||
* - this might be improved upon with bytestream
|
* - this might be improved upon with bytestream
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
#include "gstfilter.h"
|
#include "gstfilter.h"
|
||||||
#include <math.h> /* M_PI */
|
#include <math.h> /* M_PI */
|
||||||
|
@ -189,7 +192,7 @@ gst_lpwsinc_sink_connect (GstPad * pad, GstCaps * caps)
|
||||||
/* fill the kernel */
|
/* fill the kernel */
|
||||||
g_print ("DEBUG: initing filter kernel\n");
|
g_print ("DEBUG: initing filter kernel\n");
|
||||||
len = filter->wing_size;
|
len = filter->wing_size;
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO,
|
GST_DEBUG (
|
||||||
"lpwsinc: initializing filter kernel of length %d", len * 2 + 1);
|
"lpwsinc: initializing filter kernel of length %d", len * 2 + 1);
|
||||||
filter->kernel = (double *) g_malloc (sizeof (double) * (2 * len + 1));
|
filter->kernel = (double *) g_malloc (sizeof (double) * (2 * len + 1));
|
||||||
|
|
||||||
|
|
|
@ -21,6 +21,9 @@
|
||||||
* Zaheer Merali <zaheer@grid9.net
|
* Zaheer Merali <zaheer@grid9.net
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
@ -182,7 +185,7 @@ gst_auparse_chain (GstPad *pad, GstBuffer *buf)
|
||||||
|
|
||||||
auparse = GST_AUPARSE (gst_pad_get_parent (pad));
|
auparse = GST_AUPARSE (gst_pad_get_parent (pad));
|
||||||
|
|
||||||
GST_DEBUG (0, "gst_auparse_chain: got buffer in '%s'",
|
GST_DEBUG ("gst_auparse_chain: got buffer in '%s'",
|
||||||
gst_element_get_name (GST_ELEMENT (auparse)));
|
gst_element_get_name (GST_ELEMENT (auparse)));
|
||||||
|
|
||||||
data = GST_BUFFER_DATA (buf);
|
data = GST_BUFFER_DATA (buf);
|
||||||
|
@ -234,7 +237,7 @@ gst_auparse_chain (GstPad *pad, GstBuffer *buf)
|
||||||
g_print ("offset %ld, size %ld, encoding %ld, frequency %ld, channels %ld\n",
|
g_print ("offset %ld, size %ld, encoding %ld, frequency %ld, channels %ld\n",
|
||||||
auparse->offset,auparse->size,auparse->encoding,
|
auparse->offset,auparse->size,auparse->encoding,
|
||||||
auparse->frequency,auparse->channels);
|
auparse->frequency,auparse->channels);
|
||||||
GST_DEBUG (0, "offset %ld, size %ld, encoding %ld, frequency %ld, channels %ld",
|
GST_DEBUG ("offset %ld, size %ld, encoding %ld, frequency %ld, channels %ld",
|
||||||
auparse->offset,auparse->size,auparse->encoding,
|
auparse->offset,auparse->size,auparse->encoding,
|
||||||
auparse->frequency,auparse->channels);
|
auparse->frequency,auparse->channels);
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,9 @@
|
||||||
|
|
||||||
|
|
||||||
/* #define GST_DEBUG_ENABLED */
|
/* #define GST_DEBUG_ENABLED */
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include "gstavidemux.h"
|
#include "gstavidemux.h"
|
||||||
|
@ -268,7 +271,7 @@ avi_type_find (GstBuffer *buf,
|
||||||
gchar *data = GST_BUFFER_DATA (buf);
|
gchar *data = GST_BUFFER_DATA (buf);
|
||||||
GstCaps *new;
|
GstCaps *new;
|
||||||
|
|
||||||
GST_DEBUG (0,"avi_demux: typefind");
|
GST_DEBUG ("avi_demux: typefind");
|
||||||
|
|
||||||
if (GUINT32_FROM_LE (((guint32 *)data)[0]) != GST_RIFF_TAG_RIFF)
|
if (GUINT32_FROM_LE (((guint32 *)data)[0]) != GST_RIFF_TAG_RIFF)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -308,21 +311,21 @@ gst_avi_demux_avih (GstAviDemux *avi_demux)
|
||||||
avi_demux->avih.start = GUINT32_FROM_LE (avih->start);
|
avi_demux->avih.start = GUINT32_FROM_LE (avih->start);
|
||||||
avi_demux->avih.length = GUINT32_FROM_LE (avih->length);
|
avi_demux->avih.length = GUINT32_FROM_LE (avih->length);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: avih tag found");
|
GST_INFO ( "gst_avi_demux: avih tag found");
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: us_frame %d", avi_demux->avih.us_frame);
|
GST_INFO ( "gst_avi_demux: us_frame %d", avi_demux->avih.us_frame);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: max_bps %d", avi_demux->avih.max_bps);
|
GST_INFO ( "gst_avi_demux: max_bps %d", avi_demux->avih.max_bps);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: pad_gran %d", avi_demux->avih.pad_gran);
|
GST_INFO ( "gst_avi_demux: pad_gran %d", avi_demux->avih.pad_gran);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: flags 0x%08x", avi_demux->avih.flags);
|
GST_INFO ( "gst_avi_demux: flags 0x%08x", avi_demux->avih.flags);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: tot_frames %d", avi_demux->avih.tot_frames);
|
GST_INFO ( "gst_avi_demux: tot_frames %d", avi_demux->avih.tot_frames);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: init_frames %d", avi_demux->avih.init_frames);
|
GST_INFO ( "gst_avi_demux: init_frames %d", avi_demux->avih.init_frames);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: streams %d", avi_demux->avih.streams);
|
GST_INFO ( "gst_avi_demux: streams %d", avi_demux->avih.streams);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: bufsize %d", avi_demux->avih.bufsize);
|
GST_INFO ( "gst_avi_demux: bufsize %d", avi_demux->avih.bufsize);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: width %d", avi_demux->avih.width);
|
GST_INFO ( "gst_avi_demux: width %d", avi_demux->avih.width);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: height %d", avi_demux->avih.height);
|
GST_INFO ( "gst_avi_demux: height %d", avi_demux->avih.height);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: scale %d", avi_demux->avih.scale);
|
GST_INFO ( "gst_avi_demux: scale %d", avi_demux->avih.scale);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: rate %d", avi_demux->avih.rate);
|
GST_INFO ( "gst_avi_demux: rate %d", avi_demux->avih.rate);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: start %d", avi_demux->avih.start);
|
GST_INFO ( "gst_avi_demux: start %d", avi_demux->avih.start);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: length %d", avi_demux->avih.length);
|
GST_INFO ( "gst_avi_demux: length %d", avi_demux->avih.length);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
@ -367,21 +370,21 @@ gst_avi_demux_strh (GstAviDemux *avi_demux)
|
||||||
if (!target->strh.rate)
|
if (!target->strh.rate)
|
||||||
target->strh.rate = 1; /* avoid division by zero */
|
target->strh.rate = 1; /* avoid division by zero */
|
||||||
|
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: strh tag found");
|
GST_INFO ( "gst_avi_demux: strh tag found");
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: type 0x%08x (%s)",
|
GST_INFO ( "gst_avi_demux: type 0x%08x (%s)",
|
||||||
target->strh.type, gst_riff_id_to_fourcc (strh->type));
|
target->strh.type, gst_riff_id_to_fourcc (strh->type));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: fcc_handler 0x%08x (%s)",
|
GST_INFO ( "gst_avi_demux: fcc_handler 0x%08x (%s)",
|
||||||
target->strh.fcc_handler, gst_riff_id_to_fourcc (strh->fcc_handler));
|
target->strh.fcc_handler, gst_riff_id_to_fourcc (strh->fcc_handler));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: flags 0x%08x", strh->flags);
|
GST_INFO ( "gst_avi_demux: flags 0x%08x", strh->flags);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: priority %d", target->strh.priority);
|
GST_INFO ( "gst_avi_demux: priority %d", target->strh.priority);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: init_frames %d", target->strh.init_frames);
|
GST_INFO ( "gst_avi_demux: init_frames %d", target->strh.init_frames);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: scale %d", target->strh.scale);
|
GST_INFO ( "gst_avi_demux: scale %d", target->strh.scale);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: rate %d", target->strh.rate);
|
GST_INFO ( "gst_avi_demux: rate %d", target->strh.rate);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: start %d", target->strh.start);
|
GST_INFO ( "gst_avi_demux: start %d", target->strh.start);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: length %d", target->strh.length);
|
GST_INFO ( "gst_avi_demux: length %d", target->strh.length);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: bufsize %d", target->strh.bufsize);
|
GST_INFO ( "gst_avi_demux: bufsize %d", target->strh.bufsize);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: quality %d", target->strh.quality);
|
GST_INFO ( "gst_avi_demux: quality %d", target->strh.quality);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: samplesize %d", target->strh.samplesize);
|
GST_INFO ( "gst_avi_demux: samplesize %d", target->strh.samplesize);
|
||||||
|
|
||||||
target->delay = 0LL;
|
target->delay = 0LL;
|
||||||
target->total_bytes = 0LL;
|
target->total_bytes = 0LL;
|
||||||
|
@ -424,7 +427,7 @@ gst_avi_demux_strn (GstAviDemux *avi_demux, gint len)
|
||||||
if (got_bytes != len)
|
if (got_bytes != len)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
GST_DEBUG (0, "Stream name: \"%s\"", name);
|
GST_DEBUG ("Stream name: \"%s\"", name);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -592,19 +595,19 @@ gst_avi_demux_strf_vids (GstAviDemux *avi_demux)
|
||||||
if (got_bytes != sizeof (gst_riff_strf_vids))
|
if (got_bytes != sizeof (gst_riff_strf_vids))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: strf tag found in context vids");
|
GST_INFO ( "gst_avi_demux: strf tag found in context vids");
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: size %d", GUINT32_FROM_LE (strf->size));
|
GST_INFO ( "gst_avi_demux: size %d", GUINT32_FROM_LE (strf->size));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: width %d", GUINT32_FROM_LE (strf->width));
|
GST_INFO ( "gst_avi_demux: width %d", GUINT32_FROM_LE (strf->width));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: height %d", GUINT32_FROM_LE (strf->height));
|
GST_INFO ( "gst_avi_demux: height %d", GUINT32_FROM_LE (strf->height));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: planes %d", GUINT16_FROM_LE (strf->planes));
|
GST_INFO ( "gst_avi_demux: planes %d", GUINT16_FROM_LE (strf->planes));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: bit_cnt %d", GUINT16_FROM_LE (strf->bit_cnt));
|
GST_INFO ( "gst_avi_demux: bit_cnt %d", GUINT16_FROM_LE (strf->bit_cnt));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: compression 0x%08x (%s)",
|
GST_INFO ( "gst_avi_demux: compression 0x%08x (%s)",
|
||||||
GUINT32_FROM_LE (strf->compression), gst_riff_id_to_fourcc (strf->compression));
|
GUINT32_FROM_LE (strf->compression), gst_riff_id_to_fourcc (strf->compression));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: image_size %d", GUINT32_FROM_LE (strf->image_size));
|
GST_INFO ( "gst_avi_demux: image_size %d", GUINT32_FROM_LE (strf->image_size));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: xpels_meter %d", GUINT32_FROM_LE (strf->xpels_meter));
|
GST_INFO ( "gst_avi_demux: xpels_meter %d", GUINT32_FROM_LE (strf->xpels_meter));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: ypels_meter %d", GUINT32_FROM_LE (strf->ypels_meter));
|
GST_INFO ( "gst_avi_demux: ypels_meter %d", GUINT32_FROM_LE (strf->ypels_meter));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: num_colors %d", GUINT32_FROM_LE (strf->num_colors));
|
GST_INFO ( "gst_avi_demux: num_colors %d", GUINT32_FROM_LE (strf->num_colors));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: imp_colors %d", GUINT32_FROM_LE (strf->imp_colors));
|
GST_INFO ( "gst_avi_demux: imp_colors %d", GUINT32_FROM_LE (strf->imp_colors));
|
||||||
|
|
||||||
srcpad = gst_pad_new_from_template (
|
srcpad = gst_pad_new_from_template (
|
||||||
GST_PAD_TEMPLATE_GET (src_video_templ), g_strdup_printf ("video_%02d",
|
GST_PAD_TEMPLATE_GET (src_video_templ), g_strdup_printf ("video_%02d",
|
||||||
|
@ -772,13 +775,13 @@ gst_avi_demux_strf_auds (GstAviDemux *avi_demux)
|
||||||
if (got_bytes != sizeof (gst_riff_strf_auds))
|
if (got_bytes != sizeof (gst_riff_strf_auds))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: strf tag found in context auds");
|
GST_INFO ( "gst_avi_demux: strf tag found in context auds");
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: format %d", GUINT16_FROM_LE (strf->format));
|
GST_INFO ( "gst_avi_demux: format %d", GUINT16_FROM_LE (strf->format));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: channels %d", GUINT16_FROM_LE (strf->channels));
|
GST_INFO ( "gst_avi_demux: channels %d", GUINT16_FROM_LE (strf->channels));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: rate %d", GUINT32_FROM_LE (strf->rate));
|
GST_INFO ( "gst_avi_demux: rate %d", GUINT32_FROM_LE (strf->rate));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: av_bps %d", GUINT32_FROM_LE (strf->av_bps));
|
GST_INFO ( "gst_avi_demux: av_bps %d", GUINT32_FROM_LE (strf->av_bps));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: blockalign %d", GUINT16_FROM_LE (strf->blockalign));
|
GST_INFO ( "gst_avi_demux: blockalign %d", GUINT16_FROM_LE (strf->blockalign));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: size %d", GUINT16_FROM_LE (strf->size));
|
GST_INFO ( "gst_avi_demux: size %d", GUINT16_FROM_LE (strf->size));
|
||||||
|
|
||||||
srcpad = gst_pad_new_from_template (
|
srcpad = gst_pad_new_from_template (
|
||||||
GST_PAD_TEMPLATE_GET (src_audio_templ), g_strdup_printf ("audio_%02d",
|
GST_PAD_TEMPLATE_GET (src_audio_templ), g_strdup_printf ("audio_%02d",
|
||||||
|
@ -910,15 +913,15 @@ gst_avi_demux_strf_iavs (GstAviDemux *avi_demux)
|
||||||
if (got_bytes != sizeof (gst_riff_strf_iavs))
|
if (got_bytes != sizeof (gst_riff_strf_iavs))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: strf tag found in context iavs");
|
GST_INFO ( "gst_avi_demux: strf tag found in context iavs");
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: DVAAuxSrc %08x", GUINT32_FROM_LE (strf->DVAAuxSrc));
|
GST_INFO ( "gst_avi_demux: DVAAuxSrc %08x", GUINT32_FROM_LE (strf->DVAAuxSrc));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: DVAAuxCtl %08x", GUINT32_FROM_LE (strf->DVAAuxCtl));
|
GST_INFO ( "gst_avi_demux: DVAAuxCtl %08x", GUINT32_FROM_LE (strf->DVAAuxCtl));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: DVAAuxSrc1 %08x", GUINT32_FROM_LE (strf->DVAAuxSrc1));
|
GST_INFO ( "gst_avi_demux: DVAAuxSrc1 %08x", GUINT32_FROM_LE (strf->DVAAuxSrc1));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: DVAAuxCtl1 %08x", GUINT32_FROM_LE (strf->DVAAuxCtl1));
|
GST_INFO ( "gst_avi_demux: DVAAuxCtl1 %08x", GUINT32_FROM_LE (strf->DVAAuxCtl1));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: DVVAuxSrc %08x", GUINT32_FROM_LE (strf->DVVAuxSrc));
|
GST_INFO ( "gst_avi_demux: DVVAuxSrc %08x", GUINT32_FROM_LE (strf->DVVAuxSrc));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: DVVAuxCtl %08x", GUINT32_FROM_LE (strf->DVVAuxCtl));
|
GST_INFO ( "gst_avi_demux: DVVAuxCtl %08x", GUINT32_FROM_LE (strf->DVVAuxCtl));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: DVReserved1 %08x", GUINT32_FROM_LE (strf->DVReserved1));
|
GST_INFO ( "gst_avi_demux: DVReserved1 %08x", GUINT32_FROM_LE (strf->DVReserved1));
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux: DVReserved2 %08x", GUINT32_FROM_LE (strf->DVReserved2));
|
GST_INFO ( "gst_avi_demux: DVReserved2 %08x", GUINT32_FROM_LE (strf->DVReserved2));
|
||||||
|
|
||||||
srcpad = gst_pad_new_from_template (
|
srcpad = gst_pad_new_from_template (
|
||||||
GST_PAD_TEMPLATE_GET (src_video_templ), g_strdup_printf ("video_%02d",
|
GST_PAD_TEMPLATE_GET (src_video_templ), g_strdup_printf ("video_%02d",
|
||||||
|
@ -966,7 +969,7 @@ gst_avi_demux_strf_iavs (GstAviDemux *avi_demux)
|
||||||
static void
|
static void
|
||||||
gst_avi_debug_entry (const gchar *prefix, gst_avi_index_entry *entry)
|
gst_avi_debug_entry (const gchar *prefix, gst_avi_index_entry *entry)
|
||||||
{
|
{
|
||||||
GST_DEBUG (0, "%s: %05d %d %08llx %05d %14" G_GINT64_FORMAT " %08x %08x (%d) %08x",
|
GST_DEBUG ("%s: %05d %d %08llx %05d %14" G_GINT64_FORMAT " %08x %08x (%d) %08x",
|
||||||
prefix, entry->index_nr, entry->stream_nr,
|
prefix, entry->index_nr, entry->stream_nr,
|
||||||
(unsigned long long)entry->bytes_before,
|
(unsigned long long)entry->bytes_before,
|
||||||
entry->frames_before, entry->ts, entry->flags, entry->offset,
|
entry->frames_before, entry->ts, entry->flags, entry->offset,
|
||||||
|
@ -985,7 +988,7 @@ gst_avi_demux_parse_index (GstAviDemux *avi_demux,
|
||||||
guint32 id;
|
guint32 id;
|
||||||
|
|
||||||
if (!gst_bytestream_seek (avi_demux->bs, filepos + offset, GST_SEEK_METHOD_SET)) {
|
if (!gst_bytestream_seek (avi_demux->bs, filepos + offset, GST_SEEK_METHOD_SET)) {
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "avidemux: could not seek to index");
|
GST_INFO ( "avidemux: could not seek to index");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
do {
|
do {
|
||||||
|
@ -1001,7 +1004,7 @@ gst_avi_demux_parse_index (GstAviDemux *avi_demux,
|
||||||
} while (TRUE);
|
} while (TRUE);
|
||||||
|
|
||||||
if (GST_BUFFER_OFFSET (buf) != filepos + offset || GST_BUFFER_SIZE (buf) != 8) {
|
if (GST_BUFFER_OFFSET (buf) != filepos + offset || GST_BUFFER_SIZE (buf) != 8) {
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "avidemux: could not get index, got %" G_GINT64_FORMAT " %d, expected %ld",
|
GST_INFO ( "avidemux: could not get index, got %" G_GINT64_FORMAT " %d, expected %ld",
|
||||||
GST_BUFFER_OFFSET (buf), GST_BUFFER_SIZE (buf), filepos + offset);
|
GST_BUFFER_OFFSET (buf), GST_BUFFER_SIZE (buf), filepos + offset);
|
||||||
goto end;
|
goto end;
|
||||||
}
|
}
|
||||||
|
@ -1009,7 +1012,7 @@ gst_avi_demux_parse_index (GstAviDemux *avi_demux,
|
||||||
id = GUINT32_FROM_LE (*(guint32 *)GST_BUFFER_DATA (buf));
|
id = GUINT32_FROM_LE (*(guint32 *)GST_BUFFER_DATA (buf));
|
||||||
|
|
||||||
if (id != GST_RIFF_TAG_idx1) {
|
if (id != GST_RIFF_TAG_idx1) {
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "avidemux: no index found");
|
GST_INFO ( "avidemux: no index found");
|
||||||
goto end;
|
goto end;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1020,12 +1023,12 @@ gst_avi_demux_parse_index (GstAviDemux *avi_demux,
|
||||||
|
|
||||||
got_bytes = gst_bytestream_read (avi_demux->bs, &buf, index_size);
|
got_bytes = gst_bytestream_read (avi_demux->bs, &buf, index_size);
|
||||||
if (got_bytes < index_size) {
|
if (got_bytes < index_size) {
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "avidemux: error reading index");
|
GST_INFO ( "avidemux: error reading index");
|
||||||
goto end;
|
goto end;
|
||||||
}
|
}
|
||||||
|
|
||||||
avi_demux->index_size = index_size/sizeof(gst_riff_index_entry);
|
avi_demux->index_size = index_size/sizeof(gst_riff_index_entry);
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "avidemux: index size %lu", avi_demux->index_size);
|
GST_INFO ( "avidemux: index size %lu", avi_demux->index_size);
|
||||||
|
|
||||||
avi_demux->index_entries = g_malloc (avi_demux->index_size * sizeof (gst_avi_index_entry));
|
avi_demux->index_entries = g_malloc (avi_demux->index_size * sizeof (gst_avi_index_entry));
|
||||||
|
|
||||||
|
@ -1089,16 +1092,16 @@ gst_avi_demux_parse_index (GstAviDemux *avi_demux,
|
||||||
avi_stream_context *stream;
|
avi_stream_context *stream;
|
||||||
|
|
||||||
stream = &avi_demux->stream[i];
|
stream = &avi_demux->stream[i];
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO, "stream %i: %d frames, %" G_GINT64_FORMAT " bytes",
|
GST_DEBUG ("stream %i: %d frames, %" G_GINT64_FORMAT " bytes",
|
||||||
i, stream->total_frames, stream->total_bytes);
|
i, stream->total_frames, stream->total_bytes);
|
||||||
}
|
}
|
||||||
gst_buffer_unref (buf);
|
gst_buffer_unref (buf);
|
||||||
|
|
||||||
end:
|
end:
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO, "index offset at %08lx", filepos);
|
GST_DEBUG ("index offset at %08lx", filepos);
|
||||||
|
|
||||||
if (!gst_bytestream_seek (avi_demux->bs, filepos, GST_SEEK_METHOD_SET)) {
|
if (!gst_bytestream_seek (avi_demux->bs, filepos, GST_SEEK_METHOD_SET)) {
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "avidemux: could not seek back to movi");
|
GST_INFO ( "avidemux: could not seek back to movi");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1305,7 +1308,7 @@ gst_avi_demux_sync_streams (GstAviDemux *avi_demux, guint64 time)
|
||||||
for (i = 0; i < avi_demux->num_streams; i++) {
|
for (i = 0; i < avi_demux->num_streams; i++) {
|
||||||
stream = &avi_demux->stream[i];
|
stream = &avi_demux->stream[i];
|
||||||
|
|
||||||
GST_DEBUG (0, "finding %d for time %" G_GINT64_FORMAT, i, time);
|
GST_DEBUG ("finding %d for time %" G_GINT64_FORMAT, i, time);
|
||||||
|
|
||||||
entry = gst_avi_demux_index_entry_for_time (avi_demux, stream->num, time, GST_RIFF_IF_KEYFRAME);
|
entry = gst_avi_demux_index_entry_for_time (avi_demux, stream->num, time, GST_RIFF_IF_KEYFRAME);
|
||||||
if (entry) {
|
if (entry) {
|
||||||
|
@ -1314,7 +1317,7 @@ gst_avi_demux_sync_streams (GstAviDemux *avi_demux, guint64 time)
|
||||||
min_index = MIN (entry->index_nr, min_index);
|
min_index = MIN (entry->index_nr, min_index);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
GST_DEBUG (0, "first index at %d", min_index);
|
GST_DEBUG ("first index at %d", min_index);
|
||||||
|
|
||||||
/* now we know the entry we need to sync on. calculate number of frames to
|
/* now we know the entry we need to sync on. calculate number of frames to
|
||||||
* skip fro there on and the stream stats */
|
* skip fro there on and the stream stats */
|
||||||
|
@ -1332,9 +1335,9 @@ gst_avi_demux_sync_streams (GstAviDemux *avi_demux, guint64 time)
|
||||||
stream->current_frame = next_entry->frames_before;
|
stream->current_frame = next_entry->frames_before;
|
||||||
stream->skip = entry->frames_before - next_entry->frames_before;
|
stream->skip = entry->frames_before - next_entry->frames_before;
|
||||||
|
|
||||||
GST_DEBUG (0, "%d skip %d", stream->num, stream->skip);
|
GST_DEBUG ("%d skip %d", stream->num, stream->skip);
|
||||||
}
|
}
|
||||||
GST_DEBUG (0, "final index at %d", min_index);
|
GST_DEBUG ("final index at %d", min_index);
|
||||||
|
|
||||||
return min_index;
|
return min_index;
|
||||||
}
|
}
|
||||||
|
@ -1391,7 +1394,7 @@ gst_avi_demux_handle_src_event (GstPad *pad, GstEvent *event)
|
||||||
case GST_EVENT_SEEK_SEGMENT:
|
case GST_EVENT_SEEK_SEGMENT:
|
||||||
stream->end_pos = GST_EVENT_SEEK_ENDOFFSET (event);
|
stream->end_pos = GST_EVENT_SEEK_ENDOFFSET (event);
|
||||||
case GST_EVENT_SEEK:
|
case GST_EVENT_SEEK:
|
||||||
GST_DEBUG (0, "seek format %d, %08x", GST_EVENT_SEEK_FORMAT (event), stream->strh.type);
|
GST_DEBUG ("seek format %d, %08x", GST_EVENT_SEEK_FORMAT (event), stream->strh.type);
|
||||||
switch (GST_EVENT_SEEK_FORMAT (event)) {
|
switch (GST_EVENT_SEEK_FORMAT (event)) {
|
||||||
case GST_FORMAT_BYTES:
|
case GST_FORMAT_BYTES:
|
||||||
case GST_FORMAT_DEFAULT:
|
case GST_FORMAT_DEFAULT:
|
||||||
|
@ -1409,7 +1412,7 @@ gst_avi_demux_handle_src_event (GstPad *pad, GstEvent *event)
|
||||||
res = FALSE;
|
res = FALSE;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
GST_DEBUG (0, "seeking to %" G_GINT64_FORMAT, desired_offset);
|
GST_DEBUG ("seeking to %" G_GINT64_FORMAT, desired_offset);
|
||||||
|
|
||||||
flags = GST_RIFF_IF_KEYFRAME;
|
flags = GST_RIFF_IF_KEYFRAME;
|
||||||
|
|
||||||
|
@ -1426,7 +1429,7 @@ gst_avi_demux_handle_src_event (GstPad *pad, GstEvent *event)
|
||||||
avi_demux->last_seek = seek_entry->ts;
|
avi_demux->last_seek = seek_entry->ts;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
GST_DEBUG (0, "no index entry found for time %" G_GINT64_FORMAT, desired_offset);
|
GST_DEBUG ("no index entry found for time %" G_GINT64_FORMAT, desired_offset);
|
||||||
res = FALSE;
|
res = FALSE;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -1458,7 +1461,7 @@ gst_avi_demux_handle_sink_event (GstAviDemux *avi_demux)
|
||||||
gst_bytestream_get_status (avi_demux->bs, &remaining, &event);
|
gst_bytestream_get_status (avi_demux->bs, &remaining, &event);
|
||||||
|
|
||||||
type = event? GST_EVENT_TYPE (event) : GST_EVENT_UNKNOWN;
|
type = event? GST_EVENT_TYPE (event) : GST_EVENT_UNKNOWN;
|
||||||
GST_DEBUG (0, "avidemux: event %p %d", event, type);
|
GST_DEBUG ("avidemux: event %p %d", event, type);
|
||||||
|
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case GST_EVENT_EOS:
|
case GST_EVENT_EOS:
|
||||||
|
@ -1478,7 +1481,7 @@ gst_avi_demux_handle_sink_event (GstAviDemux *avi_demux)
|
||||||
avi_stream_context *stream = &avi_demux->stream[i];
|
avi_stream_context *stream = &avi_demux->stream[i];
|
||||||
|
|
||||||
if (GST_PAD_IS_USABLE (stream->pad)) {
|
if (GST_PAD_IS_USABLE (stream->pad)) {
|
||||||
GST_DEBUG (GST_CAT_EVENT, "sending discont on %d %" G_GINT64_FORMAT " + %" G_GINT64_FORMAT " = %" G_GINT64_FORMAT,
|
GST_DEBUG ("sending discont on %d %" G_GINT64_FORMAT " + %" G_GINT64_FORMAT " = %" G_GINT64_FORMAT,
|
||||||
i, avi_demux->last_seek, stream->delay, avi_demux->last_seek + stream->delay);
|
i, avi_demux->last_seek, stream->delay, avi_demux->last_seek + stream->delay);
|
||||||
|
|
||||||
discont = gst_event_new_discontinuous (FALSE, GST_FORMAT_TIME,
|
discont = gst_event_new_discontinuous (FALSE, GST_FORMAT_TIME,
|
||||||
|
@ -1517,14 +1520,14 @@ gst_avi_demux_loop (GstElement *element)
|
||||||
bs = avi_demux->bs;
|
bs = avi_demux->bs;
|
||||||
|
|
||||||
if (avi_demux->seek_pending) {
|
if (avi_demux->seek_pending) {
|
||||||
GST_DEBUG (0, "avidemux: seek pending to %" G_GINT64_FORMAT " %08llx",
|
GST_DEBUG ("avidemux: seek pending to %" G_GINT64_FORMAT " %08llx",
|
||||||
avi_demux->seek_offset, (unsigned long long)avi_demux->seek_offset);
|
avi_demux->seek_offset, (unsigned long long)avi_demux->seek_offset);
|
||||||
|
|
||||||
if (!gst_bytestream_seek (avi_demux->bs,
|
if (!gst_bytestream_seek (avi_demux->bs,
|
||||||
avi_demux->seek_offset,
|
avi_demux->seek_offset,
|
||||||
GST_SEEK_METHOD_SET))
|
GST_SEEK_METHOD_SET))
|
||||||
{
|
{
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "avidemux: could not seek");
|
GST_INFO ( "avidemux: could not seek");
|
||||||
}
|
}
|
||||||
avi_demux->seek_pending = FALSE;
|
avi_demux->seek_pending = FALSE;
|
||||||
}
|
}
|
||||||
|
@ -1588,10 +1591,10 @@ gst_avi_demux_loop (GstElement *element)
|
||||||
flush = 0;
|
flush = 0;
|
||||||
break;
|
break;
|
||||||
case GST_AVI_DEMUX_HEADER:
|
case GST_AVI_DEMUX_HEADER:
|
||||||
GST_DEBUG (0, "riff tag: %4.4s %08x", (gchar *)&chunk.id, chunk.size);
|
GST_DEBUG ("riff tag: %4.4s %08x", (gchar *)&chunk.id, chunk.size);
|
||||||
switch (chunk.id) {
|
switch (chunk.id) {
|
||||||
case GST_RIFF_TAG_LIST:
|
case GST_RIFF_TAG_LIST:
|
||||||
GST_DEBUG (0, "list type: %4.4s", (gchar *)&chunk.type);
|
GST_DEBUG ("list type: %4.4s", (gchar *)&chunk.type);
|
||||||
switch (chunk.type) {
|
switch (chunk.type) {
|
||||||
case GST_RIFF_LIST_movi:
|
case GST_RIFF_LIST_movi:
|
||||||
{
|
{
|
||||||
|
@ -1639,7 +1642,7 @@ gst_avi_demux_loop (GstElement *element)
|
||||||
case GST_RIFF_FCC_pads:
|
case GST_RIFF_FCC_pads:
|
||||||
case GST_RIFF_FCC_txts:
|
case GST_RIFF_FCC_txts:
|
||||||
default:
|
default:
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "gst_avi_demux_chain: strh type %s not supported",
|
GST_INFO ( "gst_avi_demux_chain: strh type %s not supported",
|
||||||
gst_riff_id_to_fourcc (avi_demux->fcc_type));
|
gst_riff_id_to_fourcc (avi_demux->fcc_type));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -1654,7 +1657,7 @@ gst_avi_demux_loop (GstElement *element)
|
||||||
case GST_RIFF_ISFT:
|
case GST_RIFF_ISFT:
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
GST_DEBUG (0, " ***** unknown chunkid %08x", chunk.id);
|
GST_DEBUG (" ***** unknown chunkid %08x", chunk.id);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -1674,7 +1677,7 @@ gst_avi_demux_loop (GstElement *element)
|
||||||
|
|
||||||
stream = &avi_demux->stream[stream_id];
|
stream = &avi_demux->stream[stream_id];
|
||||||
|
|
||||||
GST_DEBUG (0,"gst_avi_demux_chain: tag found %08x size %08x stream_id %d",
|
GST_DEBUG ("gst_avi_demux_chain: tag found %08x size %08x stream_id %d",
|
||||||
chunk.id, chunk.size, stream_id);
|
chunk.id, chunk.size, stream_id);
|
||||||
|
|
||||||
format = GST_FORMAT_TIME;
|
format = GST_FORMAT_TIME;
|
||||||
|
@ -1693,7 +1696,7 @@ gst_avi_demux_loop (GstElement *element)
|
||||||
if (GST_PAD_IS_USABLE (stream->pad)) {
|
if (GST_PAD_IS_USABLE (stream->pad)) {
|
||||||
if (next_ts >= stream->end_pos) {
|
if (next_ts >= stream->end_pos) {
|
||||||
gst_pad_push (stream->pad, GST_BUFFER (gst_event_new (GST_EVENT_EOS)));
|
gst_pad_push (stream->pad, GST_BUFFER (gst_event_new (GST_EVENT_EOS)));
|
||||||
GST_DEBUG (0, "end stream %d: %" G_GINT64_FORMAT " %d %" G_GINT64_FORMAT,
|
GST_DEBUG ("end stream %d: %" G_GINT64_FORMAT " %d %" G_GINT64_FORMAT,
|
||||||
stream_id, next_ts, stream->current_frame - 1,
|
stream_id, next_ts, stream->current_frame - 1,
|
||||||
stream->end_pos);
|
stream->end_pos);
|
||||||
}
|
}
|
||||||
|
@ -1714,7 +1717,7 @@ gst_avi_demux_loop (GstElement *element)
|
||||||
/* FIXME, do some flush event here */
|
/* FIXME, do some flush event here */
|
||||||
stream->need_flush = FALSE;
|
stream->need_flush = FALSE;
|
||||||
}
|
}
|
||||||
GST_DEBUG (0, "send stream %d: %" G_GINT64_FORMAT " %d %" G_GINT64_FORMAT " %08x",
|
GST_DEBUG ("send stream %d: %" G_GINT64_FORMAT " %d %" G_GINT64_FORMAT " %08x",
|
||||||
stream_id, next_ts, stream->current_frame - 1,
|
stream_id, next_ts, stream->current_frame - 1,
|
||||||
stream->delay, chunk.size);
|
stream->delay, chunk.size);
|
||||||
|
|
||||||
|
@ -1726,7 +1729,7 @@ gst_avi_demux_loop (GstElement *element)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
GST_DEBUG (0, " ***** unknown chunkid %08x", chunk.id);
|
GST_DEBUG (" ***** unknown chunkid %08x", chunk.id);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -25,6 +25,9 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <config.h>
|
#include <config.h>
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
@ -308,7 +311,7 @@ gst_avimux_sinkconnect (GstPad *pad, GstCaps *vscaps)
|
||||||
if (!GST_CAPS_IS_FIXED (vscaps))
|
if (!GST_CAPS_IS_FIXED (vscaps))
|
||||||
return GST_PAD_LINK_DELAYED;
|
return GST_PAD_LINK_DELAYED;
|
||||||
|
|
||||||
GST_DEBUG (0, "avimux: sinkconnect triggered on %s", gst_pad_get_name (pad));
|
GST_DEBUG ("avimux: sinkconnect triggered on %s", gst_pad_get_name (pad));
|
||||||
|
|
||||||
for (caps = vscaps; caps != NULL; caps = vscaps = vscaps->next)
|
for (caps = vscaps; caps != NULL; caps = vscaps = vscaps->next)
|
||||||
{
|
{
|
||||||
|
@ -438,7 +441,7 @@ gst_avimux_sinkconnect (GstPad *pad, GstCaps *vscaps)
|
||||||
gst_caps_has_property(caps, "layer"))
|
gst_caps_has_property(caps, "layer"))
|
||||||
gst_caps_get_int(caps, "layer", &layer);
|
gst_caps_get_int(caps, "layer", &layer);
|
||||||
else
|
else
|
||||||
GST_DEBUG(GST_CAT_PLUGIN_INFO,
|
GST_DEBUG (
|
||||||
"No layer specified, assuming layer 3");
|
"No layer specified, assuming layer 3");
|
||||||
|
|
||||||
/* we don't need to do anything here, compressed mp3 contains it all */
|
/* we don't need to do anything here, compressed mp3 contains it all */
|
||||||
|
@ -497,7 +500,7 @@ gst_avimux_pad_link (GstPad *pad,
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG(GST_CAT_PLUGIN_INFO, "pad '%s' connected", padname);
|
GST_DEBUG ("pad '%s' connected", padname);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -524,7 +527,7 @@ gst_avimux_pad_unlink (GstPad *pad,
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG(GST_CAT_PLUGIN_INFO, "pad '%s' unlinked", padname);
|
GST_DEBUG ("pad '%s' unlinked", padname);
|
||||||
}
|
}
|
||||||
|
|
||||||
static GstPad*
|
static GstPad*
|
||||||
|
|
|
@ -17,6 +17,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
#include <gst/audio/audio.h>
|
#include <gst/audio/audio.h>
|
||||||
#include "gstcutter.h"
|
#include "gstcutter.h"
|
||||||
|
@ -222,7 +225,7 @@ gst_cutter_chain (GstPad *pad, GstBuffer *buf)
|
||||||
if (!filter->have_caps) gst_cutter_get_caps (pad, filter);
|
if (!filter->have_caps) gst_cutter_get_caps (pad, filter);
|
||||||
|
|
||||||
in_data = (gint16 *) GST_BUFFER_DATA (buf);
|
in_data = (gint16 *) GST_BUFFER_DATA (buf);
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO,
|
GST_DEBUG (
|
||||||
"length of prerec buffer: %.3f sec",
|
"length of prerec buffer: %.3f sec",
|
||||||
filter->pre_run_length);
|
filter->pre_run_length);
|
||||||
|
|
||||||
|
@ -248,7 +251,7 @@ gst_cutter_chain (GstPad *pad, GstBuffer *buf)
|
||||||
/* if RMS below threshold, add buffer length to silent run length count
|
/* if RMS below threshold, add buffer length to silent run length count
|
||||||
* if not, reset
|
* if not, reset
|
||||||
*/
|
*/
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO,
|
GST_DEBUG (
|
||||||
"buffer stats: ms %f, RMS %f, audio length %f",
|
"buffer stats: ms %f, RMS %f, audio length %f",
|
||||||
ms, RMS, gst_audio_length (filter->srcpad, buf));
|
ms, RMS, gst_audio_length (filter->srcpad, buf));
|
||||||
if (RMS < filter->threshold_level)
|
if (RMS < filter->threshold_level)
|
||||||
|
@ -279,7 +282,7 @@ gst_cutter_chain (GstPad *pad, GstBuffer *buf)
|
||||||
/* g_print ("DEBUG: cutter: start from here, turning on out\n"); */
|
/* g_print ("DEBUG: cutter: start from here, turning on out\n"); */
|
||||||
/* first of all, flush current buffer */
|
/* first of all, flush current buffer */
|
||||||
g_signal_emit (G_OBJECT (filter), gst_cutter_signals[CUT_START], 0);
|
g_signal_emit (G_OBJECT (filter), gst_cutter_signals[CUT_START], 0);
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO,
|
GST_DEBUG (
|
||||||
"flushing buffer of length %.3f",
|
"flushing buffer of length %.3f",
|
||||||
filter->pre_run_length);
|
filter->pre_run_length);
|
||||||
while (filter->pre_buffer)
|
while (filter->pre_buffer)
|
||||||
|
@ -289,7 +292,7 @@ gst_cutter_chain (GstPad *pad, GstBuffer *buf)
|
||||||
gst_pad_push (filter->srcpad, prebuf);
|
gst_pad_push (filter->srcpad, prebuf);
|
||||||
++count;
|
++count;
|
||||||
}
|
}
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO, "flushed %d buffers", count);
|
GST_DEBUG ("flushed %d buffers", count);
|
||||||
filter->pre_run_length = 0.0;
|
filter->pre_run_length = 0.0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -345,7 +348,7 @@ gst_cutter_set_property (GObject *object, guint prop_id,
|
||||||
case ARG_THRESHOLD:
|
case ARG_THRESHOLD:
|
||||||
/* set the level */
|
/* set the level */
|
||||||
filter->threshold_level = g_value_get_double (value);
|
filter->threshold_level = g_value_get_double (value);
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO,
|
GST_DEBUG (
|
||||||
"DEBUG: set threshold level to %f",
|
"DEBUG: set threshold level to %f",
|
||||||
filter->threshold_level);
|
filter->threshold_level);
|
||||||
break;
|
break;
|
||||||
|
@ -355,7 +358,7 @@ gst_cutter_set_property (GObject *object, guint prop_id,
|
||||||
* values in dB < 0 result in values between 0 and 1
|
* values in dB < 0 result in values between 0 and 1
|
||||||
*/
|
*/
|
||||||
filter->threshold_level = pow (10, g_value_get_double (value) / 20);
|
filter->threshold_level = pow (10, g_value_get_double (value) / 20);
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO,
|
GST_DEBUG (
|
||||||
"DEBUG: set threshold level to %f",
|
"DEBUG: set threshold level to %f",
|
||||||
filter->threshold_level);
|
filter->threshold_level);
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -19,6 +19,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
@ -200,7 +203,7 @@ gst_efence_chain (GstPad *pad, GstBuffer *buffer)
|
||||||
GstBuffer *copy;
|
GstBuffer *copy;
|
||||||
void *ptr;
|
void *ptr;
|
||||||
|
|
||||||
GST_DEBUG(0, "gst_efence_chain");
|
GST_DEBUG ("gst_efence_chain");
|
||||||
|
|
||||||
g_return_if_fail (GST_IS_PAD (pad));
|
g_return_if_fail (GST_IS_PAD (pad));
|
||||||
g_return_if_fail (buffer != NULL);
|
g_return_if_fail (buffer != NULL);
|
||||||
|
@ -322,7 +325,7 @@ GstBuffer *gst_fenced_buffer_new(void)
|
||||||
GST_BUFFER_BUFFERPOOL (newbuf) = NULL;
|
GST_BUFFER_BUFFERPOOL (newbuf) = NULL;
|
||||||
GST_BUFFER_POOL_PRIVATE (newbuf) = NULL;
|
GST_BUFFER_POOL_PRIVATE (newbuf) = NULL;
|
||||||
|
|
||||||
GST_DEBUG(0, "new buffer=%p", newbuf);
|
GST_DEBUG ("new buffer=%p", newbuf);
|
||||||
|
|
||||||
return newbuf;
|
return newbuf;
|
||||||
}
|
}
|
||||||
|
@ -331,7 +334,7 @@ void gst_fenced_buffer_default_free (GstBuffer *buffer)
|
||||||
{
|
{
|
||||||
GstFencedBuffer *fenced_buffer;
|
GstFencedBuffer *fenced_buffer;
|
||||||
|
|
||||||
GST_DEBUG(0, "free buffer=%p", buffer);
|
GST_DEBUG ("free buffer=%p", buffer);
|
||||||
|
|
||||||
g_return_if_fail (buffer != NULL);
|
g_return_if_fail (buffer != NULL);
|
||||||
|
|
||||||
|
@ -340,11 +343,11 @@ void gst_fenced_buffer_default_free (GstBuffer *buffer)
|
||||||
/* free our data */
|
/* free our data */
|
||||||
if (!GST_BUFFER_FLAG_IS_SET (buffer, GST_BUFFER_DONTFREE) &&
|
if (!GST_BUFFER_FLAG_IS_SET (buffer, GST_BUFFER_DONTFREE) &&
|
||||||
GST_BUFFER_DATA (buffer)) {
|
GST_BUFFER_DATA (buffer)) {
|
||||||
GST_DEBUG(0, "free region %p %d", fenced_buffer->region,
|
GST_DEBUG ("free region %p %d", fenced_buffer->region,
|
||||||
fenced_buffer->length);
|
fenced_buffer->length);
|
||||||
munmap(fenced_buffer->region, fenced_buffer->length);
|
munmap(fenced_buffer->region, fenced_buffer->length);
|
||||||
}else{
|
}else{
|
||||||
GST_DEBUG(0, "not freeing region %p %d %p", fenced_buffer->region,
|
GST_DEBUG ("not freeing region %p %d %p", fenced_buffer->region,
|
||||||
GST_BUFFER_FLAGS(buffer), GST_BUFFER_DATA(buffer));
|
GST_BUFFER_FLAGS(buffer), GST_BUFFER_DATA(buffer));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -392,7 +395,7 @@ void *gst_fenced_buffer_alloc(GstBuffer *buffer, unsigned int length,
|
||||||
GstFencedBuffer *fenced_buffer = (GstFencedBuffer *) buffer;
|
GstFencedBuffer *fenced_buffer = (GstFencedBuffer *) buffer;
|
||||||
int page_size;
|
int page_size;
|
||||||
|
|
||||||
GST_DEBUG(0, "buffer=%p length=%d fence_top=%d", buffer, length, fence_top);
|
GST_DEBUG ("buffer=%p length=%d fence_top=%d", buffer, length, fence_top);
|
||||||
|
|
||||||
if(length==0)return NULL;
|
if(length==0)return NULL;
|
||||||
|
|
||||||
|
@ -418,7 +421,7 @@ void *gst_fenced_buffer_alloc(GstBuffer *buffer, unsigned int length,
|
||||||
fenced_buffer->region = region;
|
fenced_buffer->region = region;
|
||||||
fenced_buffer->length = alloc_size;
|
fenced_buffer->length = alloc_size;
|
||||||
|
|
||||||
GST_DEBUG(0, "new region %p %d", fenced_buffer->region,
|
GST_DEBUG ("new region %p %d", fenced_buffer->region,
|
||||||
fenced_buffer->length);
|
fenced_buffer->length);
|
||||||
|
|
||||||
if(fence_top){
|
if(fence_top){
|
||||||
|
|
|
@ -21,6 +21,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "gsteffectv.h"
|
#include "gsteffectv.h"
|
||||||
|
|
||||||
|
|
|
@ -10,6 +10,9 @@
|
||||||
* 270 degrees. The amount of rotation for each square is chosen at random.
|
* 270 degrees. The amount of rotation for each square is chosen at random.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
#include "gsteffectv.h"
|
#include "gsteffectv.h"
|
||||||
|
|
|
@ -21,6 +21,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
#include "gsteffectv.h"
|
#include "gsteffectv.h"
|
||||||
|
|
|
@ -21,6 +21,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
|
@ -40,6 +40,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
|
@ -22,6 +22,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
|
@ -22,6 +22,9 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
|
@ -27,6 +27,9 @@
|
||||||
* by sam lantinga slouken@devolution.com
|
* by sam lantinga slouken@devolution.com
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
|
@ -17,6 +17,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include "flx_fmt.h"
|
#include "flx_fmt.h"
|
||||||
|
@ -471,7 +474,7 @@ gst_flxdec_loop (GstElement *element)
|
||||||
g_return_if_fail (element != NULL);
|
g_return_if_fail (element != NULL);
|
||||||
g_return_if_fail (GST_IS_FLXDEC(element));
|
g_return_if_fail (GST_IS_FLXDEC(element));
|
||||||
|
|
||||||
GST_DEBUG (0, "entering loop function");
|
GST_DEBUG ("entering loop function");
|
||||||
|
|
||||||
flxdec = GST_FLXDEC(element);
|
flxdec = GST_FLXDEC(element);
|
||||||
|
|
||||||
|
|
|
@ -17,6 +17,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <config.h>
|
#include <config.h>
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
||||||
|
@ -297,7 +300,7 @@ gst_goom_chain (GstPad *pad, GstBuffer *bufin)
|
||||||
|
|
||||||
goom = GST_GOOM (gst_pad_get_parent (pad));
|
goom = GST_GOOM (gst_pad_get_parent (pad));
|
||||||
|
|
||||||
GST_DEBUG (0, "GOOM: chainfunc called");
|
GST_DEBUG ("GOOM: chainfunc called");
|
||||||
|
|
||||||
if (GST_IS_EVENT (bufin)) {
|
if (GST_IS_EVENT (bufin)) {
|
||||||
GstEvent *event = GST_EVENT (bufin);
|
GstEvent *event = GST_EVENT (bufin);
|
||||||
|
@ -335,7 +338,7 @@ gst_goom_chain (GstPad *pad, GstBuffer *bufin)
|
||||||
|
|
||||||
samples_in = GST_BUFFER_SIZE (bufin) / (sizeof (gint16) * goom->channels);
|
samples_in = GST_BUFFER_SIZE (bufin) / (sizeof (gint16) * goom->channels);
|
||||||
|
|
||||||
GST_DEBUG (0, "input buffer has %d samples", samples_in);
|
GST_DEBUG ("input buffer has %d samples", samples_in);
|
||||||
|
|
||||||
if (GST_BUFFER_TIMESTAMP (bufin) < goom->next_time || samples_in < 512) {
|
if (GST_BUFFER_TIMESTAMP (bufin) < goom->next_time || samples_in < 512) {
|
||||||
goto done;
|
goto done;
|
||||||
|
@ -368,7 +371,7 @@ gst_goom_chain (GstPad *pad, GstBuffer *bufin)
|
||||||
done:
|
done:
|
||||||
gst_buffer_unref (bufin);
|
gst_buffer_unref (bufin);
|
||||||
|
|
||||||
GST_DEBUG (0, "GOOM: exiting chainfunc");
|
GST_DEBUG ("GOOM: exiting chainfunc");
|
||||||
}
|
}
|
||||||
|
|
||||||
static GstElementStateReturn
|
static GstElementStateReturn
|
||||||
|
|
|
@ -1,3 +1,6 @@
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include "alaw-encode.h"
|
#include "alaw-encode.h"
|
||||||
#include "alaw-decode.h"
|
#include "alaw-decode.h"
|
||||||
|
|
||||||
|
|
|
@ -1,3 +1,6 @@
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include "mulaw-encode.h"
|
#include "mulaw-encode.h"
|
||||||
#include "mulaw-decode.h"
|
#include "mulaw-decode.h"
|
||||||
|
|
||||||
|
|
|
@ -17,6 +17,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
#include "gstlevel.h"
|
#include "gstlevel.h"
|
||||||
#include "math.h"
|
#include "math.h"
|
||||||
|
|
|
@ -17,6 +17,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <gstmedian.h>
|
#include <gstmedian.h>
|
||||||
|
|
||||||
|
@ -282,7 +285,7 @@ gst_median_chain (GstPad *pad, GstBuffer *buf)
|
||||||
data = GST_BUFFER_DATA(buf);
|
data = GST_BUFFER_DATA(buf);
|
||||||
size = GST_BUFFER_SIZE(buf);
|
size = GST_BUFFER_SIZE(buf);
|
||||||
|
|
||||||
GST_DEBUG (0,"median: have buffer of %d", GST_BUFFER_SIZE(buf));
|
GST_DEBUG ("median: have buffer of %d", GST_BUFFER_SIZE(buf));
|
||||||
|
|
||||||
outbuf = gst_buffer_new();
|
outbuf = gst_buffer_new();
|
||||||
GST_BUFFER_DATA(outbuf) = g_malloc(GST_BUFFER_SIZE(buf));
|
GST_BUFFER_DATA(outbuf) = g_malloc(GST_BUFFER_SIZE(buf));
|
||||||
|
|
|
@ -17,6 +17,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <config.h>
|
#include <config.h>
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
||||||
|
@ -234,15 +237,15 @@ gst_monoscope_chain (GstPad *pad, GstBuffer *bufin)
|
||||||
|
|
||||||
monoscope = GST_MONOSCOPE (gst_pad_get_parent (pad));
|
monoscope = GST_MONOSCOPE (gst_pad_get_parent (pad));
|
||||||
|
|
||||||
GST_DEBUG (0, "Monoscope: chainfunc called");
|
GST_DEBUG ("Monoscope: chainfunc called");
|
||||||
|
|
||||||
samples_in = GST_BUFFER_SIZE (bufin) / sizeof (gint16);
|
samples_in = GST_BUFFER_SIZE (bufin) / sizeof (gint16);
|
||||||
|
|
||||||
GST_DEBUG (0, "input buffer has %d samples", samples_in);
|
GST_DEBUG ("input buffer has %d samples", samples_in);
|
||||||
|
|
||||||
/* FIXME: should really select the first 1024 samples after the timestamp. */
|
/* FIXME: should really select the first 1024 samples after the timestamp. */
|
||||||
if (GST_BUFFER_TIMESTAMP (bufin) < monoscope->next_time || samples_in < 1024) {
|
if (GST_BUFFER_TIMESTAMP (bufin) < monoscope->next_time || samples_in < 1024) {
|
||||||
GST_DEBUG (0, "timestamp is %" G_GUINT64_FORMAT ": want >= %" G_GUINT64_FORMAT, GST_BUFFER_TIMESTAMP (bufin), monoscope->next_time);
|
GST_DEBUG ("timestamp is %" G_GUINT64_FORMAT ": want >= %" G_GUINT64_FORMAT, GST_BUFFER_TIMESTAMP (bufin), monoscope->next_time);
|
||||||
gst_buffer_unref (bufin);
|
gst_buffer_unref (bufin);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -258,7 +261,7 @@ gst_monoscope_chain (GstPad *pad, GstBuffer *bufin)
|
||||||
|
|
||||||
monoscope->visstate = monoscope_init (monoscope->width, monoscope->height);
|
monoscope->visstate = monoscope_init (monoscope->width, monoscope->height);
|
||||||
g_assert(monoscope->visstate != 0);
|
g_assert(monoscope->visstate != 0);
|
||||||
GST_DEBUG (0, "making new pad");
|
GST_DEBUG ("making new pad");
|
||||||
|
|
||||||
caps = GST_CAPS_NEW (
|
caps = GST_CAPS_NEW (
|
||||||
"monoscopesrc",
|
"monoscopesrc",
|
||||||
|
@ -293,7 +296,7 @@ gst_monoscope_chain (GstPad *pad, GstBuffer *bufin)
|
||||||
|
|
||||||
gst_buffer_unref (bufin);
|
gst_buffer_unref (bufin);
|
||||||
|
|
||||||
GST_DEBUG (0, "Monoscope: exiting chainfunc");
|
GST_DEBUG ("Monoscope: exiting chainfunc");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -18,6 +18,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include "qtdemux.h"
|
#include "qtdemux.h"
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
@ -257,7 +260,7 @@ static gboolean gst_qtdemux_handle_sink_event (GstQTDemux *qtdemux)
|
||||||
gst_bytestream_get_status(qtdemux->bs, &remaining, &event);
|
gst_bytestream_get_status(qtdemux->bs, &remaining, &event);
|
||||||
|
|
||||||
type = event ? GST_EVENT_TYPE(event) : GST_EVENT_UNKNOWN;
|
type = event ? GST_EVENT_TYPE(event) : GST_EVENT_UNKNOWN;
|
||||||
GST_DEBUG(0,"qtdemux: event %p %d", event, type);
|
GST_DEBUG ("qtdemux: event %p %d", event, type);
|
||||||
|
|
||||||
switch(type){
|
switch(type){
|
||||||
case GST_EVENT_EOS:
|
case GST_EVENT_EOS:
|
||||||
|
@ -268,7 +271,7 @@ static gboolean gst_qtdemux_handle_sink_event (GstQTDemux *qtdemux)
|
||||||
g_warning("flush event");
|
g_warning("flush event");
|
||||||
break;
|
break;
|
||||||
case GST_EVENT_DISCONTINUOUS:
|
case GST_EVENT_DISCONTINUOUS:
|
||||||
GST_DEBUG(0,"discontinuous event\n");
|
GST_DEBUG ("discontinuous event\n");
|
||||||
//gst_bytestream_flush_fast(qtdemux->bs, remaining);
|
//gst_bytestream_flush_fast(qtdemux->bs, remaining);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -324,7 +327,7 @@ static void gst_qtdemux_loop_header (GstElement *element)
|
||||||
//cur_offset = gst_bytestream_tell(qtdemux->bs);
|
//cur_offset = gst_bytestream_tell(qtdemux->bs);
|
||||||
|
|
||||||
cur_offset = qtdemux->offset;
|
cur_offset = qtdemux->offset;
|
||||||
GST_DEBUG(0,"loop at position %d",cur_offset);
|
GST_DEBUG ("loop at position %d",cur_offset);
|
||||||
|
|
||||||
switch(qtdemux->state){
|
switch(qtdemux->state){
|
||||||
case QTDEMUX_STATE_HEADER:
|
case QTDEMUX_STATE_HEADER:
|
||||||
|
@ -341,9 +344,9 @@ static void gst_qtdemux_loop_header (GstElement *element)
|
||||||
}while(1);
|
}while(1);
|
||||||
|
|
||||||
length = GUINT32_FROM_BE(*(guint32 *)data);
|
length = GUINT32_FROM_BE(*(guint32 *)data);
|
||||||
GST_DEBUG(0,"length %08x",length);
|
GST_DEBUG ("length %08x",length);
|
||||||
fourcc = GUINT32_FROM_LE(*(guint32 *)(data+4));
|
fourcc = GUINT32_FROM_LE(*(guint32 *)(data+4));
|
||||||
GST_DEBUG(0,"fourcc " GST_FOURCC_FORMAT, GST_FOURCC_ARGS(fourcc));
|
GST_DEBUG ("fourcc " GST_FOURCC_FORMAT, GST_FOURCC_ARGS(fourcc));
|
||||||
if(length==0){
|
if(length==0){
|
||||||
length = gst_bytestream_length(qtdemux->bs) - cur_offset;
|
length = gst_bytestream_length(qtdemux->bs) - cur_offset;
|
||||||
}
|
}
|
||||||
|
@ -351,9 +354,9 @@ static void gst_qtdemux_loop_header (GstElement *element)
|
||||||
guint32 length1, length2;
|
guint32 length1, length2;
|
||||||
|
|
||||||
length1 = GUINT32_FROM_BE(*(guint32 *)(data+8));
|
length1 = GUINT32_FROM_BE(*(guint32 *)(data+8));
|
||||||
GST_DEBUG(0,"length1 %08x",length1);
|
GST_DEBUG ("length1 %08x",length1);
|
||||||
length2 = GUINT32_FROM_BE(*(guint32 *)(data+12));
|
length2 = GUINT32_FROM_BE(*(guint32 *)(data+12));
|
||||||
GST_DEBUG(0,"length2 %08x",length2);
|
GST_DEBUG ("length2 %08x",length2);
|
||||||
|
|
||||||
length=length2;
|
length=length2;
|
||||||
}
|
}
|
||||||
|
@ -370,7 +373,7 @@ static void gst_qtdemux_loop_header (GstElement *element)
|
||||||
do{
|
do{
|
||||||
ret = gst_bytestream_read(qtdemux->bs, &moov, length);
|
ret = gst_bytestream_read(qtdemux->bs, &moov, length);
|
||||||
if(ret < length){
|
if(ret < length){
|
||||||
GST_DEBUG(0,"read failed (%d < %d)",ret,length);
|
GST_DEBUG ("read failed (%d < %d)",ret,length);
|
||||||
if(!gst_qtdemux_handle_sink_event(qtdemux)){
|
if(!gst_qtdemux_handle_sink_event(qtdemux)){
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -395,7 +398,7 @@ static void gst_qtdemux_loop_header (GstElement *element)
|
||||||
ret = gst_bytestream_seek(qtdemux->bs, cur_offset + length,
|
ret = gst_bytestream_seek(qtdemux->bs, cur_offset + length,
|
||||||
GST_SEEK_METHOD_SET);
|
GST_SEEK_METHOD_SET);
|
||||||
qtdemux->offset = cur_offset + length;
|
qtdemux->offset = cur_offset + length;
|
||||||
GST_DEBUG(0,"seek returned %d\n",ret);
|
GST_DEBUG ("seek returned %d\n",ret);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case QTDEMUX_STATE_SEEKING_EOS:
|
case QTDEMUX_STATE_SEEKING_EOS:
|
||||||
|
@ -444,7 +447,7 @@ static void gst_qtdemux_loop_header (GstElement *element)
|
||||||
GST_BUFFER(gst_event_new (GST_EVENT_EOS)));
|
GST_BUFFER(gst_event_new (GST_EVENT_EOS)));
|
||||||
}
|
}
|
||||||
ret = gst_bytestream_seek(qtdemux->bs, 0, GST_SEEK_METHOD_END);
|
ret = gst_bytestream_seek(qtdemux->bs, 0, GST_SEEK_METHOD_END);
|
||||||
GST_DEBUG(0,"seek returned %d",ret);
|
GST_DEBUG ("seek returned %d",ret);
|
||||||
|
|
||||||
qtdemux->state = QTDEMUX_STATE_SEEKING_EOS;
|
qtdemux->state = QTDEMUX_STATE_SEEKING_EOS;
|
||||||
return;
|
return;
|
||||||
|
@ -455,23 +458,23 @@ static void gst_qtdemux_loop_header (GstElement *element)
|
||||||
offset = stream->samples[stream->sample_index].offset;
|
offset = stream->samples[stream->sample_index].offset;
|
||||||
size = stream->samples[stream->sample_index].size;
|
size = stream->samples[stream->sample_index].size;
|
||||||
|
|
||||||
GST_DEBUG(0,"pushing from stream %d, sample_index=%d offset=%d size=%d",
|
GST_DEBUG ("pushing from stream %d, sample_index=%d offset=%d size=%d",
|
||||||
index, stream->sample_index, offset, size);
|
index, stream->sample_index, offset, size);
|
||||||
|
|
||||||
cur_offset = gst_bytestream_tell(qtdemux->bs);
|
cur_offset = gst_bytestream_tell(qtdemux->bs);
|
||||||
if(offset != cur_offset){
|
if(offset != cur_offset){
|
||||||
GST_DEBUG(0,"seeking to offset %d",offset);
|
GST_DEBUG ("seeking to offset %d",offset);
|
||||||
ret = gst_bytestream_seek(qtdemux->bs, offset, GST_SEEK_METHOD_SET);
|
ret = gst_bytestream_seek(qtdemux->bs, offset, GST_SEEK_METHOD_SET);
|
||||||
GST_DEBUG(0,"seek returned %d",ret);
|
GST_DEBUG ("seek returned %d",ret);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG(0,"reading %d bytes\n",size);
|
GST_DEBUG ("reading %d bytes\n",size);
|
||||||
buf = NULL;
|
buf = NULL;
|
||||||
do{
|
do{
|
||||||
ret = gst_bytestream_read(qtdemux->bs, &buf, size);
|
ret = gst_bytestream_read(qtdemux->bs, &buf, size);
|
||||||
if(ret < size){
|
if(ret < size){
|
||||||
GST_DEBUG(0,"read failed (%d < %d)",ret,size);
|
GST_DEBUG ("read failed (%d < %d)",ret,size);
|
||||||
if(!gst_qtdemux_handle_sink_event(qtdemux)){
|
if(!gst_qtdemux_handle_sink_event(qtdemux)){
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -500,14 +503,14 @@ static GstCaps *gst_qtdemux_src_getcaps(GstPad *pad, GstCaps *caps)
|
||||||
QtDemuxStream *stream;
|
QtDemuxStream *stream;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
GST_DEBUG(0,"gst_qtdemux_src_getcaps");
|
GST_DEBUG ("gst_qtdemux_src_getcaps");
|
||||||
|
|
||||||
qtdemux = GST_QTDEMUX(gst_pad_get_parent(pad));
|
qtdemux = GST_QTDEMUX(gst_pad_get_parent(pad));
|
||||||
|
|
||||||
g_return_val_if_fail(GST_IS_QTDEMUX(qtdemux), NULL);
|
g_return_val_if_fail(GST_IS_QTDEMUX(qtdemux), NULL);
|
||||||
|
|
||||||
GST_DEBUG(0, "looking for pad %p in qtdemux %p", pad, qtdemux);
|
GST_DEBUG ("looking for pad %p in qtdemux %p", pad, qtdemux);
|
||||||
GST_DEBUG(0, "n_streams is %d", qtdemux->n_streams);
|
GST_DEBUG ("n_streams is %d", qtdemux->n_streams);
|
||||||
for(i=0;i<qtdemux->n_streams;i++){
|
for(i=0;i<qtdemux->n_streams;i++){
|
||||||
stream = qtdemux->streams[i];
|
stream = qtdemux->streams[i];
|
||||||
if(stream->pad == pad){
|
if(stream->pad == pad){
|
||||||
|
@ -515,7 +518,7 @@ static GstCaps *gst_qtdemux_src_getcaps(GstPad *pad, GstCaps *caps)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG(0,"Couldn't find stream cooresponding to pad\n");
|
GST_DEBUG ("Couldn't find stream cooresponding to pad\n");
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -527,23 +530,23 @@ gst_qtdemux_src_link(GstPad *pad, GstCaps *caps)
|
||||||
QtDemuxStream *stream;
|
QtDemuxStream *stream;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
GST_DEBUG(0,"gst_qtdemux_src_link");
|
GST_DEBUG ("gst_qtdemux_src_link");
|
||||||
|
|
||||||
qtdemux = GST_QTDEMUX(gst_pad_get_parent(pad));
|
qtdemux = GST_QTDEMUX(gst_pad_get_parent(pad));
|
||||||
|
|
||||||
GST_DEBUG(0, "looking for pad %p in qtdemux %p", pad, qtdemux);
|
GST_DEBUG ("looking for pad %p in qtdemux %p", pad, qtdemux);
|
||||||
g_return_val_if_fail(GST_IS_QTDEMUX(qtdemux), GST_PAD_LINK_REFUSED);
|
g_return_val_if_fail(GST_IS_QTDEMUX(qtdemux), GST_PAD_LINK_REFUSED);
|
||||||
|
|
||||||
GST_DEBUG(0, "n_streams is %d", qtdemux->n_streams);
|
GST_DEBUG ("n_streams is %d", qtdemux->n_streams);
|
||||||
for(i=0;i<qtdemux->n_streams;i++){
|
for(i=0;i<qtdemux->n_streams;i++){
|
||||||
stream = qtdemux->streams[i];
|
stream = qtdemux->streams[i];
|
||||||
GST_DEBUG(0, "pad[%d] is %p", i, stream->pad);
|
GST_DEBUG ("pad[%d] is %p", i, stream->pad);
|
||||||
if(stream->pad == pad){
|
if(stream->pad == pad){
|
||||||
return GST_PAD_LINK_OK;
|
return GST_PAD_LINK_OK;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG(0,"Couldn't find stream cooresponding to pad\n");
|
GST_DEBUG ("Couldn't find stream cooresponding to pad\n");
|
||||||
|
|
||||||
return GST_PAD_LINK_REFUSED;
|
return GST_PAD_LINK_REFUSED;
|
||||||
}
|
}
|
||||||
|
@ -581,9 +584,9 @@ void gst_qtdemux_add_stream(GstQTDemux *qtdemux, QtDemuxStream *stream)
|
||||||
|
|
||||||
qtdemux->streams[qtdemux->n_streams] = stream;
|
qtdemux->streams[qtdemux->n_streams] = stream;
|
||||||
qtdemux->n_streams++;
|
qtdemux->n_streams++;
|
||||||
GST_DEBUG(0, "n_streams is now %d", qtdemux->n_streams);
|
GST_DEBUG ("n_streams is now %d", qtdemux->n_streams);
|
||||||
|
|
||||||
GST_DEBUG(0, "adding pad %p to qtdemux %p", stream->pad, qtdemux);
|
GST_DEBUG ("adding pad %p to qtdemux %p", stream->pad, qtdemux);
|
||||||
gst_element_add_pad(GST_ELEMENT (qtdemux), stream->pad);
|
gst_element_add_pad(GST_ELEMENT (qtdemux), stream->pad);
|
||||||
|
|
||||||
/* Note: we need to have everything set up before calling try_set_caps */
|
/* Note: we need to have everything set up before calling try_set_caps */
|
||||||
|
|
|
@ -12,6 +12,9 @@
|
||||||
* Library General Public License for more
|
* Library General Public License for more
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "gstrtpL16parse.h"
|
#include "gstrtpL16parse.h"
|
||||||
#include "gstrtp-common.h"
|
#include "gstrtp-common.h"
|
||||||
|
@ -238,7 +241,7 @@ gst_rtpL16parse_chain (GstPad * pad, GstBuffer * buf)
|
||||||
|
|
||||||
memcpy (GST_BUFFER_DATA (outbuf), rtp_packet_get_payload (packet), GST_BUFFER_SIZE (outbuf));
|
memcpy (GST_BUFFER_DATA (outbuf), rtp_packet_get_payload (packet), GST_BUFFER_SIZE (outbuf));
|
||||||
|
|
||||||
GST_DEBUG (0,"gst_rtpL16parse_chain: pushing buffer of size %d", GST_BUFFER_SIZE(outbuf));
|
GST_DEBUG ("gst_rtpL16parse_chain: pushing buffer of size %d", GST_BUFFER_SIZE(outbuf));
|
||||||
|
|
||||||
/* FIXME: According to RFC 1890, this is required, right? */
|
/* FIXME: According to RFC 1890, this is required, right? */
|
||||||
#if G_BYTE_ORDER == G_LITTLE_ENDIAN
|
#if G_BYTE_ORDER == G_LITTLE_ENDIAN
|
||||||
|
@ -303,7 +306,7 @@ gst_rtpL16parse_change_state (GstElement * element)
|
||||||
|
|
||||||
rtpL16parse = GST_RTP_L16_PARSE (element);
|
rtpL16parse = GST_RTP_L16_PARSE (element);
|
||||||
|
|
||||||
GST_DEBUG (0, "state pending %d\n", GST_STATE_PENDING (element));
|
GST_DEBUG ("state pending %d\n", GST_STATE_PENDING (element));
|
||||||
|
|
||||||
switch (GST_STATE_TRANSITION (element)) {
|
switch (GST_STATE_TRANSITION (element)) {
|
||||||
case GST_STATE_NULL_TO_READY:
|
case GST_STATE_NULL_TO_READY:
|
||||||
|
|
|
@ -17,6 +17,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "gstrtpL16enc.h"
|
#include "gstrtpL16enc.h"
|
||||||
|
|
||||||
|
@ -195,7 +198,7 @@ gst_rtpL16enc_chain (GstPad * pad, GstBuffer * buf)
|
||||||
|
|
||||||
switch (GST_EVENT_TYPE (event)) {
|
switch (GST_EVENT_TYPE (event)) {
|
||||||
case GST_EVENT_DISCONTINUOUS:
|
case GST_EVENT_DISCONTINUOUS:
|
||||||
GST_DEBUG (GST_CAT_EVENT, "discont");
|
GST_DEBUG ("discont");
|
||||||
rtpL16enc->next_time = 0;
|
rtpL16enc->next_time = 0;
|
||||||
gst_pad_event_default (pad, event);
|
gst_pad_event_default (pad, event);
|
||||||
return;
|
return;
|
||||||
|
@ -238,7 +241,7 @@ gst_rtpL16enc_chain (GstPad * pad, GstBuffer * buf)
|
||||||
memcpy (GST_BUFFER_DATA (outbuf), packet->data, rtp_packet_get_packet_len (packet));
|
memcpy (GST_BUFFER_DATA (outbuf), packet->data, rtp_packet_get_packet_len (packet));
|
||||||
memcpy (GST_BUFFER_DATA (outbuf) + rtp_packet_get_packet_len(packet), GST_BUFFER_DATA (buf), GST_BUFFER_SIZE (buf));
|
memcpy (GST_BUFFER_DATA (outbuf) + rtp_packet_get_packet_len(packet), GST_BUFFER_DATA (buf), GST_BUFFER_SIZE (buf));
|
||||||
|
|
||||||
GST_DEBUG (0,"gst_rtpL16enc_chain: pushing buffer of size %d", GST_BUFFER_SIZE(outbuf));
|
GST_DEBUG ("gst_rtpL16enc_chain: pushing buffer of size %d", GST_BUFFER_SIZE(outbuf));
|
||||||
gst_pad_push (rtpL16enc->srcpad, outbuf);
|
gst_pad_push (rtpL16enc->srcpad, outbuf);
|
||||||
|
|
||||||
++rtpL16enc->seq;
|
++rtpL16enc->seq;
|
||||||
|
@ -288,7 +291,7 @@ gst_rtpL16enc_change_state (GstElement * element)
|
||||||
|
|
||||||
rtpL16enc = GST_RTP_L16_ENC (element);
|
rtpL16enc = GST_RTP_L16_ENC (element);
|
||||||
|
|
||||||
GST_DEBUG (0, "state pending %d\n", GST_STATE_PENDING (element));
|
GST_DEBUG ("state pending %d\n", GST_STATE_PENDING (element));
|
||||||
|
|
||||||
/* if going down into NULL state, close the file if it's open */
|
/* if going down into NULL state, close the file if it's open */
|
||||||
switch (GST_STATE_TRANSITION (element)) {
|
switch (GST_STATE_TRANSITION (element)) {
|
||||||
|
|
|
@ -12,6 +12,9 @@
|
||||||
* Library General Public License for more
|
* Library General Public License for more
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "gstrtpL16parse.h"
|
#include "gstrtpL16parse.h"
|
||||||
#include "gstrtp-common.h"
|
#include "gstrtp-common.h"
|
||||||
|
@ -238,7 +241,7 @@ gst_rtpL16parse_chain (GstPad * pad, GstBuffer * buf)
|
||||||
|
|
||||||
memcpy (GST_BUFFER_DATA (outbuf), rtp_packet_get_payload (packet), GST_BUFFER_SIZE (outbuf));
|
memcpy (GST_BUFFER_DATA (outbuf), rtp_packet_get_payload (packet), GST_BUFFER_SIZE (outbuf));
|
||||||
|
|
||||||
GST_DEBUG (0,"gst_rtpL16parse_chain: pushing buffer of size %d", GST_BUFFER_SIZE(outbuf));
|
GST_DEBUG ("gst_rtpL16parse_chain: pushing buffer of size %d", GST_BUFFER_SIZE(outbuf));
|
||||||
|
|
||||||
/* FIXME: According to RFC 1890, this is required, right? */
|
/* FIXME: According to RFC 1890, this is required, right? */
|
||||||
#if G_BYTE_ORDER == G_LITTLE_ENDIAN
|
#if G_BYTE_ORDER == G_LITTLE_ENDIAN
|
||||||
|
@ -303,7 +306,7 @@ gst_rtpL16parse_change_state (GstElement * element)
|
||||||
|
|
||||||
rtpL16parse = GST_RTP_L16_PARSE (element);
|
rtpL16parse = GST_RTP_L16_PARSE (element);
|
||||||
|
|
||||||
GST_DEBUG (0, "state pending %d\n", GST_STATE_PENDING (element));
|
GST_DEBUG ("state pending %d\n", GST_STATE_PENDING (element));
|
||||||
|
|
||||||
switch (GST_STATE_TRANSITION (element)) {
|
switch (GST_STATE_TRANSITION (element)) {
|
||||||
case GST_STATE_NULL_TO_READY:
|
case GST_STATE_NULL_TO_READY:
|
||||||
|
|
|
@ -17,6 +17,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "gstrtpL16enc.h"
|
#include "gstrtpL16enc.h"
|
||||||
|
|
||||||
|
@ -195,7 +198,7 @@ gst_rtpL16enc_chain (GstPad * pad, GstBuffer * buf)
|
||||||
|
|
||||||
switch (GST_EVENT_TYPE (event)) {
|
switch (GST_EVENT_TYPE (event)) {
|
||||||
case GST_EVENT_DISCONTINUOUS:
|
case GST_EVENT_DISCONTINUOUS:
|
||||||
GST_DEBUG (GST_CAT_EVENT, "discont");
|
GST_DEBUG ("discont");
|
||||||
rtpL16enc->next_time = 0;
|
rtpL16enc->next_time = 0;
|
||||||
gst_pad_event_default (pad, event);
|
gst_pad_event_default (pad, event);
|
||||||
return;
|
return;
|
||||||
|
@ -238,7 +241,7 @@ gst_rtpL16enc_chain (GstPad * pad, GstBuffer * buf)
|
||||||
memcpy (GST_BUFFER_DATA (outbuf), packet->data, rtp_packet_get_packet_len (packet));
|
memcpy (GST_BUFFER_DATA (outbuf), packet->data, rtp_packet_get_packet_len (packet));
|
||||||
memcpy (GST_BUFFER_DATA (outbuf) + rtp_packet_get_packet_len(packet), GST_BUFFER_DATA (buf), GST_BUFFER_SIZE (buf));
|
memcpy (GST_BUFFER_DATA (outbuf) + rtp_packet_get_packet_len(packet), GST_BUFFER_DATA (buf), GST_BUFFER_SIZE (buf));
|
||||||
|
|
||||||
GST_DEBUG (0,"gst_rtpL16enc_chain: pushing buffer of size %d", GST_BUFFER_SIZE(outbuf));
|
GST_DEBUG ("gst_rtpL16enc_chain: pushing buffer of size %d", GST_BUFFER_SIZE(outbuf));
|
||||||
gst_pad_push (rtpL16enc->srcpad, outbuf);
|
gst_pad_push (rtpL16enc->srcpad, outbuf);
|
||||||
|
|
||||||
++rtpL16enc->seq;
|
++rtpL16enc->seq;
|
||||||
|
@ -288,7 +291,7 @@ gst_rtpL16enc_change_state (GstElement * element)
|
||||||
|
|
||||||
rtpL16enc = GST_RTP_L16_ENC (element);
|
rtpL16enc = GST_RTP_L16_ENC (element);
|
||||||
|
|
||||||
GST_DEBUG (0, "state pending %d\n", GST_STATE_PENDING (element));
|
GST_DEBUG ("state pending %d\n", GST_STATE_PENDING (element));
|
||||||
|
|
||||||
/* if going down into NULL state, close the file if it's open */
|
/* if going down into NULL state, close the file if it's open */
|
||||||
switch (GST_STATE_TRANSITION (element)) {
|
switch (GST_STATE_TRANSITION (element)) {
|
||||||
|
|
|
@ -18,6 +18,9 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include "gstsmoothwave.h"
|
#include "gstsmoothwave.h"
|
||||||
|
@ -125,12 +128,12 @@ gst_smoothwave_init (GstSmoothWave *smoothwave)
|
||||||
/* gtk_widget_set_default_colormap (gdk_rgb_get_cmap()); */
|
/* gtk_widget_set_default_colormap (gdk_rgb_get_cmap()); */
|
||||||
/* gtk_widget_set_default_visual (gdk_rgb_get_visual()); */
|
/* gtk_widget_set_default_visual (gdk_rgb_get_visual()); */
|
||||||
|
|
||||||
/* GST_DEBUG (0,"creating palette"); */
|
/* GST_DEBUG ("creating palette"); */
|
||||||
for (i=0;i<256;i++)
|
for (i=0;i<256;i++)
|
||||||
palette[i] = (i << 16) || (i << 8);
|
palette[i] = (i << 16) || (i << 8);
|
||||||
/* GST_DEBUG (0,"creating cmap"); */
|
/* GST_DEBUG ("creating cmap"); */
|
||||||
smoothwave->cmap = gdk_rgb_cmap_new(palette,256);
|
smoothwave->cmap = gdk_rgb_cmap_new(palette,256);
|
||||||
/* GST_DEBUG (0,"created cmap"); */
|
/* GST_DEBUG ("created cmap"); */
|
||||||
/* gtk_widget_set_default_colormap (smoothwave->cmap); */
|
/* gtk_widget_set_default_colormap (smoothwave->cmap); */
|
||||||
|
|
||||||
smoothwave->image = gtk_drawing_area_new();
|
smoothwave->image = gtk_drawing_area_new();
|
||||||
|
@ -176,7 +179,7 @@ gst_smoothwave_chain (GstPad *pad, GstBuffer *buf)
|
||||||
|
|
||||||
qheight = smoothwave->height/4;
|
qheight = smoothwave->height/4;
|
||||||
|
|
||||||
/* GST_DEBUG (0,"traversing %d",smoothwave->width); */
|
/* GST_DEBUG ("traversing %d",smoothwave->width); */
|
||||||
for (i=0;i<MAX(smoothwave->width,samplecount);i++) {
|
for (i=0;i<MAX(smoothwave->width,samplecount);i++) {
|
||||||
gint16 y1 = (gint32)(samples[i*2] * qheight) / 32768 +
|
gint16 y1 = (gint32)(samples[i*2] * qheight) / 32768 +
|
||||||
qheight;
|
qheight;
|
||||||
|
@ -195,8 +198,8 @@ gst_smoothwave_chain (GstPad *pad, GstBuffer *buf)
|
||||||
ptr++;
|
ptr++;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* GST_DEBUG (0,"drawing"); */
|
/* GST_DEBUG ("drawing"); */
|
||||||
/* GST_DEBUG (0,"gdk_draw_indexed_image(%p,%p,%d,%d,%d,%d,%s,%p,%d,%p);",
|
/* GST_DEBUG ("gdk_draw_indexed_image(%p,%p,%d,%d,%d,%d,%s,%p,%d,%p);",
|
||||||
smoothwave->image->window,
|
smoothwave->image->window,
|
||||||
smoothwave->image->style->fg_gc[GTK_STATE_NORMAL],
|
smoothwave->image->style->fg_gc[GTK_STATE_NORMAL],
|
||||||
0,0,smoothwave->width,smoothwave->height,
|
0,0,smoothwave->width,smoothwave->height,
|
||||||
|
|
|
@ -17,6 +17,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <gstsmpte.h>
|
#include <gstsmpte.h>
|
||||||
#include "paint.h"
|
#include "paint.h"
|
||||||
|
|
|
@ -17,6 +17,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include "gstspectrum.h"
|
#include "gstspectrum.h"
|
||||||
|
|
|
@ -18,6 +18,9 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include "gstudpsink.h"
|
#include "gstudpsink.h"
|
||||||
|
|
||||||
#define UDP_DEFAULT_HOST "localhost"
|
#define UDP_DEFAULT_HOST "localhost"
|
||||||
|
@ -271,7 +274,7 @@ gst_udpsink_chain (GstPad *pad, GstBuffer *buf)
|
||||||
if (udpsink->clock) {
|
if (udpsink->clock) {
|
||||||
GstClockID id = gst_clock_new_single_shot_id (udpsink->clock, GST_BUFFER_TIMESTAMP (buf));
|
GstClockID id = gst_clock_new_single_shot_id (udpsink->clock, GST_BUFFER_TIMESTAMP (buf));
|
||||||
|
|
||||||
GST_DEBUG (0, "udpsink: clock wait: %" G_GUINT64_FORMAT "\n", GST_BUFFER_TIMESTAMP (buf));
|
GST_DEBUG ("udpsink: clock wait: %" G_GUINT64_FORMAT "\n", GST_BUFFER_TIMESTAMP (buf));
|
||||||
gst_element_clock_wait (GST_ELEMENT (udpsink), id, NULL);
|
gst_element_clock_wait (GST_ELEMENT (udpsink), id, NULL);
|
||||||
gst_clock_id_free (id);
|
gst_clock_id_free (id);
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,7 +18,12 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "gstudpsrc.h"
|
#include "gstudpsrc.h"
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
#define UDP_DEFAULT_PORT 4951
|
#define UDP_DEFAULT_PORT 4951
|
||||||
#define UDP_DEFAULT_MULTICAST_GROUP "0.0.0.0"
|
#define UDP_DEFAULT_MULTICAST_GROUP "0.0.0.0"
|
||||||
|
|
|
@ -17,6 +17,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
|
@ -19,6 +19,9 @@
|
||||||
|
|
||||||
|
|
||||||
/*#define DEBUG_ENABLED */
|
/*#define DEBUG_ENABLED */
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <gstvideoflip.h>
|
#include <gstvideoflip.h>
|
||||||
#include <videoflip.h>
|
#include <videoflip.h>
|
||||||
|
|
||||||
|
@ -188,7 +191,7 @@ gst_videoflip_sink_getcaps (GstPad *pad, GstCaps *caps)
|
||||||
GstCaps *sizecaps;
|
GstCaps *sizecaps;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
GST_DEBUG(0,"gst_videoflip_src_link");
|
GST_DEBUG ("gst_videoflip_src_link");
|
||||||
videoflip = GST_VIDEOFLIP (gst_pad_get_parent (pad));
|
videoflip = GST_VIDEOFLIP (gst_pad_get_parent (pad));
|
||||||
|
|
||||||
/* get list of peer's caps */
|
/* get list of peer's caps */
|
||||||
|
@ -229,7 +232,7 @@ gst_videoflip_src_link (GstPad *pad, GstCaps *caps)
|
||||||
GstPadLinkReturn ret;
|
GstPadLinkReturn ret;
|
||||||
GstCaps *peercaps;
|
GstCaps *peercaps;
|
||||||
|
|
||||||
GST_DEBUG(0,"gst_videoflip_src_link");
|
GST_DEBUG ("gst_videoflip_src_link");
|
||||||
videoflip = GST_VIDEOFLIP (gst_pad_get_parent (pad));
|
videoflip = GST_VIDEOFLIP (gst_pad_get_parent (pad));
|
||||||
|
|
||||||
if (!GST_CAPS_IS_FIXED (caps)) {
|
if (!GST_CAPS_IS_FIXED (caps)) {
|
||||||
|
@ -244,7 +247,7 @@ gst_videoflip_src_link (GstPad *pad, GstCaps *caps)
|
||||||
gst_caps_get_int (caps, "width", &videoflip->to_width);
|
gst_caps_get_int (caps, "width", &videoflip->to_width);
|
||||||
gst_caps_get_int (caps, "height", &videoflip->to_height);
|
gst_caps_get_int (caps, "height", &videoflip->to_height);
|
||||||
|
|
||||||
GST_DEBUG(0,"width %d height %d",videoflip->to_width,videoflip->to_height);
|
GST_DEBUG ("width %d height %d",videoflip->to_width,videoflip->to_height);
|
||||||
|
|
||||||
peercaps = gst_caps_copy(caps);
|
peercaps = gst_caps_copy(caps);
|
||||||
|
|
||||||
|
@ -273,7 +276,7 @@ gst_videoflip_sink_link (GstPad *pad, GstCaps *caps)
|
||||||
GstPadLinkReturn ret;
|
GstPadLinkReturn ret;
|
||||||
GstCaps *peercaps;
|
GstCaps *peercaps;
|
||||||
|
|
||||||
GST_DEBUG(0,"gst_videoflip_src_link");
|
GST_DEBUG ("gst_videoflip_src_link");
|
||||||
videoflip = GST_VIDEOFLIP (gst_pad_get_parent (pad));
|
videoflip = GST_VIDEOFLIP (gst_pad_get_parent (pad));
|
||||||
|
|
||||||
if (!GST_CAPS_IS_FIXED (caps)) {
|
if (!GST_CAPS_IS_FIXED (caps)) {
|
||||||
|
@ -312,7 +315,7 @@ gst_videoflip_sink_link (GstPad *pad, GstCaps *caps)
|
||||||
static void
|
static void
|
||||||
gst_videoflip_init (GstVideoflip *videoflip)
|
gst_videoflip_init (GstVideoflip *videoflip)
|
||||||
{
|
{
|
||||||
GST_DEBUG(0,"gst_videoflip_init");
|
GST_DEBUG ("gst_videoflip_init");
|
||||||
videoflip->sinkpad = gst_pad_new_from_template (
|
videoflip->sinkpad = gst_pad_new_from_template (
|
||||||
GST_PAD_TEMPLATE_GET (gst_videoflip_sink_template_factory),
|
GST_PAD_TEMPLATE_GET (gst_videoflip_sink_template_factory),
|
||||||
"sink");
|
"sink");
|
||||||
|
@ -341,7 +344,7 @@ gst_videoflip_chain (GstPad *pad, GstBuffer *buf)
|
||||||
gulong size;
|
gulong size;
|
||||||
GstBuffer *outbuf;
|
GstBuffer *outbuf;
|
||||||
|
|
||||||
GST_DEBUG (0,"gst_videoflip_chain");
|
GST_DEBUG ("gst_videoflip_chain");
|
||||||
|
|
||||||
g_return_if_fail (pad != NULL);
|
g_return_if_fail (pad != NULL);
|
||||||
g_return_if_fail (GST_IS_PAD (pad));
|
g_return_if_fail (GST_IS_PAD (pad));
|
||||||
|
@ -358,10 +361,10 @@ gst_videoflip_chain (GstPad *pad, GstBuffer *buf)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (0,"gst_videoflip_chain: got buffer of %ld bytes in '%s'",size,
|
GST_DEBUG ("gst_videoflip_chain: got buffer of %ld bytes in '%s'",size,
|
||||||
GST_OBJECT_NAME (videoflip));
|
GST_OBJECT_NAME (videoflip));
|
||||||
|
|
||||||
GST_DEBUG(0,"size=%ld from=%dx%d to=%dx%d fromsize=%ld (should be %d) tosize=%d",
|
GST_DEBUG ("size=%ld from=%dx%d to=%dx%d fromsize=%ld (should be %d) tosize=%d",
|
||||||
size,
|
size,
|
||||||
videoflip->from_width, videoflip->from_height,
|
videoflip->from_width, videoflip->from_height,
|
||||||
videoflip->to_width, videoflip->to_height,
|
videoflip->to_width, videoflip->to_height,
|
||||||
|
@ -377,12 +380,12 @@ gst_videoflip_chain (GstPad *pad, GstBuffer *buf)
|
||||||
GST_BUFFER_TIMESTAMP(outbuf) = GST_BUFFER_TIMESTAMP(buf);
|
GST_BUFFER_TIMESTAMP(outbuf) = GST_BUFFER_TIMESTAMP(buf);
|
||||||
|
|
||||||
g_return_if_fail(videoflip->format);
|
g_return_if_fail(videoflip->format);
|
||||||
GST_DEBUG (0,"format %s",videoflip->format->fourcc);
|
GST_DEBUG ("format %s",videoflip->format->fourcc);
|
||||||
g_return_if_fail(videoflip->format->scale);
|
g_return_if_fail(videoflip->format->scale);
|
||||||
|
|
||||||
videoflip->format->scale(videoflip, GST_BUFFER_DATA(outbuf), data);
|
videoflip->format->scale(videoflip, GST_BUFFER_DATA(outbuf), data);
|
||||||
|
|
||||||
GST_DEBUG (0,"gst_videoflip_chain: pushing buffer of %d bytes in '%s'",GST_BUFFER_SIZE(outbuf),
|
GST_DEBUG ("gst_videoflip_chain: pushing buffer of %d bytes in '%s'",GST_BUFFER_SIZE(outbuf),
|
||||||
GST_OBJECT_NAME (videoflip));
|
GST_OBJECT_NAME (videoflip));
|
||||||
|
|
||||||
gst_pad_push(videoflip->srcpad, outbuf);
|
gst_pad_push(videoflip->srcpad, outbuf);
|
||||||
|
@ -399,7 +402,7 @@ gst_videoflip_set_property (GObject *object, guint prop_id, const GValue *value,
|
||||||
g_return_if_fail(GST_IS_VIDEOFLIP(object));
|
g_return_if_fail(GST_IS_VIDEOFLIP(object));
|
||||||
src = GST_VIDEOFLIP(object);
|
src = GST_VIDEOFLIP(object);
|
||||||
|
|
||||||
GST_DEBUG(0,"gst_videoflip_set_property");
|
GST_DEBUG ("gst_videoflip_set_property");
|
||||||
switch (prop_id) {
|
switch (prop_id) {
|
||||||
case ARG_METHOD:
|
case ARG_METHOD:
|
||||||
src->method = g_value_get_enum (value);
|
src->method = g_value_get_enum (value);
|
||||||
|
|
|
@ -74,7 +74,7 @@ videoflip_find_by_caps(GstCaps *caps)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
GST_DEBUG (0,"finding %p",caps);
|
GST_DEBUG ("finding %p",caps);
|
||||||
|
|
||||||
g_return_val_if_fail(caps != NULL, NULL);
|
g_return_val_if_fail(caps != NULL, NULL);
|
||||||
|
|
||||||
|
@ -121,13 +121,13 @@ gst_videoflip_setup (GstVideoflip *videoflip)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (0,"format=%p \"%s\" from %dx%d to %dx%d",
|
GST_DEBUG ("format=%p \"%s\" from %dx%d to %dx%d",
|
||||||
videoflip->format, videoflip->format->fourcc,
|
videoflip->format, videoflip->format->fourcc,
|
||||||
videoflip->from_width, videoflip->from_height,
|
videoflip->from_width, videoflip->from_height,
|
||||||
videoflip->to_width, videoflip->to_height);
|
videoflip->to_width, videoflip->to_height);
|
||||||
|
|
||||||
if(videoflip->method == GST_VIDEOFLIP_METHOD_IDENTITY){
|
if(videoflip->method == GST_VIDEOFLIP_METHOD_IDENTITY){
|
||||||
GST_DEBUG (0,"videoflip: using passthru");
|
GST_DEBUG ("videoflip: using passthru");
|
||||||
videoflip->passthru = TRUE;
|
videoflip->passthru = TRUE;
|
||||||
videoflip->inited = TRUE;
|
videoflip->inited = TRUE;
|
||||||
return;
|
return;
|
||||||
|
@ -149,7 +149,7 @@ gst_videoflip_planar411 (GstVideoflip *scale, unsigned char *dest, unsigned char
|
||||||
int dw = scale->to_width;
|
int dw = scale->to_width;
|
||||||
int dh = scale->to_height;
|
int dh = scale->to_height;
|
||||||
|
|
||||||
GST_DEBUG (0,"videoflip: scaling planar 4:1:1 %dx%d to %dx%d", sw, sh, dw, dh);
|
GST_DEBUG ("videoflip: scaling planar 4:1:1 %dx%d to %dx%d", sw, sh, dw, dh);
|
||||||
|
|
||||||
gst_videoflip_flip(scale, dest, src, sw, sh, dw, dh);
|
gst_videoflip_flip(scale, dest, src, sw, sh, dw, dh);
|
||||||
|
|
||||||
|
|
|
@ -18,6 +18,9 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <gstwavenc.h>
|
#include <gstwavenc.h>
|
||||||
|
|
||||||
|
|
|
@ -18,6 +18,9 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include <gstwavparse.h>
|
#include <gstwavparse.h>
|
||||||
|
@ -233,7 +236,7 @@ gst_wavparse_chain (GstPad *pad, GstBuffer *buf)
|
||||||
g_return_if_fail (GST_BUFFER_DATA (buf) != NULL);
|
g_return_if_fail (GST_BUFFER_DATA (buf) != NULL);
|
||||||
|
|
||||||
wavparse = GST_WAVPARSE (gst_pad_get_parent (pad));
|
wavparse = GST_WAVPARSE (gst_pad_get_parent (pad));
|
||||||
GST_DEBUG (0, "gst_wavparse_chain: got buffer in '%s'",
|
GST_DEBUG ("gst_wavparse_chain: got buffer in '%s'",
|
||||||
gst_object_get_name (GST_OBJECT (wavparse)));
|
gst_object_get_name (GST_OBJECT (wavparse)));
|
||||||
|
|
||||||
size = GST_BUFFER_SIZE (buf);
|
size = GST_BUFFER_SIZE (buf);
|
||||||
|
@ -298,7 +301,7 @@ gst_wavparse_chain (GstPad *pad, GstBuffer *buf)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (wavparse->state == GST_WAVPARSE_OTHER) {
|
if (wavparse->state == GST_WAVPARSE_OTHER) {
|
||||||
GST_DEBUG (0, "we're in unknown territory here, not passing on");
|
GST_DEBUG ("we're in unknown territory here, not passing on");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -311,7 +314,7 @@ gst_wavparse_chain (GstPad *pad, GstBuffer *buf)
|
||||||
if (wavparse->state == GST_WAVPARSE_UNKNOWN) {
|
if (wavparse->state == GST_WAVPARSE_UNKNOWN) {
|
||||||
gint retval;
|
gint retval;
|
||||||
|
|
||||||
GST_DEBUG (0, "GstWavParse: checking for RIFF format");
|
GST_DEBUG ("GstWavParse: checking for RIFF format");
|
||||||
|
|
||||||
/* create a new RIFF parser */
|
/* create a new RIFF parser */
|
||||||
wavparse->riff = gst_riff_new ();
|
wavparse->riff = gst_riff_new ();
|
||||||
|
@ -320,13 +323,13 @@ gst_wavparse_chain (GstPad *pad, GstBuffer *buf)
|
||||||
retval = gst_riff_next_buffer (wavparse->riff, buf, 0);
|
retval = gst_riff_next_buffer (wavparse->riff, buf, 0);
|
||||||
buffer_riffed = TRUE;
|
buffer_riffed = TRUE;
|
||||||
if (retval < 0) {
|
if (retval < 0) {
|
||||||
GST_DEBUG (0, "sorry, isn't RIFF");
|
GST_DEBUG ("sorry, isn't RIFF");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* this has to be a file of form WAVE for us to deal with it */
|
/* this has to be a file of form WAVE for us to deal with it */
|
||||||
if (wavparse->riff->form != gst_riff_fourcc_to_id ("WAVE")) {
|
if (wavparse->riff->form != gst_riff_fourcc_to_id ("WAVE")) {
|
||||||
GST_DEBUG (0, "sorry, isn't WAVE");
|
GST_DEBUG ("sorry, isn't WAVE");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -339,7 +342,7 @@ gst_wavparse_chain (GstPad *pad, GstBuffer *buf)
|
||||||
GstRiffChunk *fmt;
|
GstRiffChunk *fmt;
|
||||||
GstWavParseFormat *format;
|
GstWavParseFormat *format;
|
||||||
|
|
||||||
GST_DEBUG (0, "GstWavParse: looking for fmt chunk");
|
GST_DEBUG ("GstWavParse: looking for fmt chunk");
|
||||||
|
|
||||||
/* there's a good possibility we may not have parsed this buffer */
|
/* there's a good possibility we may not have parsed this buffer */
|
||||||
if (buffer_riffed == FALSE) {
|
if (buffer_riffed == FALSE) {
|
||||||
|
@ -417,7 +420,7 @@ gst_wavparse_chain (GstPad *pad, GstBuffer *buf)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (0, "frequency %d, channels %d",
|
GST_DEBUG ("frequency %d, channels %d",
|
||||||
wavparse->rate, wavparse->channels);
|
wavparse->rate, wavparse->channels);
|
||||||
|
|
||||||
/* we're now looking for the data chunk */
|
/* we're now looking for the data chunk */
|
||||||
|
@ -434,7 +437,7 @@ gst_wavparse_chain (GstPad *pad, GstBuffer *buf)
|
||||||
GstBuffer *newbuf;
|
GstBuffer *newbuf;
|
||||||
GstRiffChunk *datachunk;
|
GstRiffChunk *datachunk;
|
||||||
|
|
||||||
GST_DEBUG (0, "GstWavParse: looking for data chunk");
|
GST_DEBUG ("GstWavParse: looking for data chunk");
|
||||||
|
|
||||||
/* again, we might need to parse the buffer */
|
/* again, we might need to parse the buffer */
|
||||||
if (buffer_riffed == FALSE) {
|
if (buffer_riffed == FALSE) {
|
||||||
|
@ -447,7 +450,7 @@ gst_wavparse_chain (GstPad *pad, GstBuffer *buf)
|
||||||
if (datachunk != NULL) {
|
if (datachunk != NULL) {
|
||||||
gulong subsize;
|
gulong subsize;
|
||||||
|
|
||||||
GST_DEBUG (0, "data begins at %ld", datachunk->offset);
|
GST_DEBUG ("data begins at %ld", datachunk->offset);
|
||||||
|
|
||||||
wavparse->datastart = datachunk->offset;
|
wavparse->datastart = datachunk->offset;
|
||||||
|
|
||||||
|
@ -456,7 +459,7 @@ gst_wavparse_chain (GstPad *pad, GstBuffer *buf)
|
||||||
|
|
||||||
/* now we construct a new buffer for the remainder */
|
/* now we construct a new buffer for the remainder */
|
||||||
subsize = size - datachunk->offset;
|
subsize = size - datachunk->offset;
|
||||||
GST_DEBUG (0, "sending last %ld bytes along as audio", subsize);
|
GST_DEBUG ("sending last %ld bytes along as audio", subsize);
|
||||||
|
|
||||||
newbuf = gst_buffer_create_sub (buf, datachunk->offset, subsize);
|
newbuf = gst_buffer_create_sub (buf, datachunk->offset, subsize);
|
||||||
gst_buffer_unref (buf);
|
gst_buffer_unref (buf);
|
||||||
|
@ -510,7 +513,7 @@ gst_wavparse_pad_convert (GstPad *pad,
|
||||||
|
|
||||||
bytes_per_sample = wavparse->channels * wavparse->width / 8;
|
bytes_per_sample = wavparse->channels * wavparse->width / 8;
|
||||||
if (bytes_per_sample == 0) {
|
if (bytes_per_sample == 0) {
|
||||||
GST_DEBUG (0, "bytes_per_sample is 0, probably an mp3 - channels %d, width %d\n",
|
GST_DEBUG ("bytes_per_sample is 0, probably an mp3 - channels %d, width %d\n",
|
||||||
wavparse->channels, wavparse->width);
|
wavparse->channels, wavparse->width);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
@ -519,7 +522,7 @@ gst_wavparse_pad_convert (GstPad *pad,
|
||||||
g_warning ("byterate is 0, internal error\n");
|
g_warning ("byterate is 0, internal error\n");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
GST_DEBUG (0, "bytes per sample: %d\n", bytes_per_sample);
|
GST_DEBUG ("bytes per sample: %d\n", bytes_per_sample);
|
||||||
|
|
||||||
switch (src_format) {
|
switch (src_format) {
|
||||||
case GST_FORMAT_BYTES:
|
case GST_FORMAT_BYTES:
|
||||||
|
@ -589,7 +592,7 @@ gst_wavparse_pad_query (GstPad *pad, GstQueryType type,
|
||||||
g_warning ("Could not query sink pad's peer\n");
|
g_warning ("Could not query sink pad's peer\n");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
GST_DEBUG (0, "pad_query done, value %" G_GINT64_FORMAT "\n", *value);
|
GST_DEBUG ("pad_query done, value %" G_GINT64_FORMAT "\n", *value);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -610,7 +613,7 @@ gst_wavparse_srcpad_event (GstPad *pad, GstEvent *event)
|
||||||
GstWavParse *wavparse = GST_WAVPARSE (GST_PAD_PARENT (pad));
|
GstWavParse *wavparse = GST_WAVPARSE (GST_PAD_PARENT (pad));
|
||||||
gboolean res = FALSE;
|
gboolean res = FALSE;
|
||||||
|
|
||||||
GST_DEBUG(0, "event %d", GST_EVENT_TYPE (event));
|
GST_DEBUG ("event %d", GST_EVENT_TYPE (event));
|
||||||
|
|
||||||
switch (GST_EVENT_TYPE (event)) {
|
switch (GST_EVENT_TYPE (event)) {
|
||||||
case GST_EVENT_SEEK:
|
case GST_EVENT_SEEK:
|
||||||
|
|
|
@ -18,6 +18,7 @@ dnl a date spec)
|
||||||
AC_DEFUN(AS_SLURP_FFMPEG,
|
AC_DEFUN(AS_SLURP_FFMPEG,
|
||||||
[
|
[
|
||||||
# save original dir
|
# save original dir
|
||||||
|
FAILED=""
|
||||||
DIRECTORY=`pwd`
|
DIRECTORY=`pwd`
|
||||||
# get/update cvs
|
# get/update cvs
|
||||||
if test ! -d $1; then mkdir -p $1; fi
|
if test ! -d $1; then mkdir -p $1; fi
|
||||||
|
@ -27,18 +28,17 @@ AC_DEFUN(AS_SLURP_FFMPEG,
|
||||||
# check out cvs code
|
# check out cvs code
|
||||||
AC_MSG_NOTICE(checking out ffmpeg cvs code from $2 into $1)
|
AC_MSG_NOTICE(checking out ffmpeg cvs code from $2 into $1)
|
||||||
cvs -Q -d:pserver:anonymous@cvs.ffmpeg.sourceforge.net:/cvsroot/ffmpeg co -D '$2' ffmpeg || FAILED=yes
|
cvs -Q -d:pserver:anonymous@cvs.ffmpeg.sourceforge.net:/cvsroot/ffmpeg co -D '$2' ffmpeg || FAILED=yes
|
||||||
cd ffmpeg
|
echo "$2" > Tag
|
||||||
else
|
else
|
||||||
# compare against Tag file and see if it needs updating
|
# compare against Tag file and see if it needs updating
|
||||||
if diff -q Tag ffmpeg/CVS/Tag > /dev/null 2> /dev/null
|
if test "`cat Tag`" == "$2"; then
|
||||||
then
|
|
||||||
# diff returned no problem
|
|
||||||
AC_MSG_NOTICE(ffmpeg cvs code in sync)
|
AC_MSG_NOTICE(ffmpeg cvs code in sync)
|
||||||
else
|
else
|
||||||
# diff says they differ
|
|
||||||
cd ffmpeg
|
cd ffmpeg
|
||||||
AC_MSG_NOTICE(updating ffmpeg cvs code)
|
AC_MSG_NOTICE(updating ffmpeg cvs code to $2)
|
||||||
cvs -Q update -dP -D '$2' || FAILED=yes
|
cvs -Q update -dP -D '$2' || FAILED=yes
|
||||||
|
cd ..
|
||||||
|
echo "$2" > Tag
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
|
@ -47,24 +47,24 @@ gst_ossformat_get (gint law, gint endianness, gboolean sign, gint width, gint de
|
||||||
if (sign == TRUE) {
|
if (sign == TRUE) {
|
||||||
if (endianness == G_LITTLE_ENDIAN) {
|
if (endianness == G_LITTLE_ENDIAN) {
|
||||||
*format = AFMT_S16_LE;
|
*format = AFMT_S16_LE;
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO,
|
GST_DEBUG (
|
||||||
"16 bit signed LE, no law (%d)", *format);
|
"16 bit signed LE, no law (%d)", *format);
|
||||||
}
|
}
|
||||||
else if (endianness == G_BIG_ENDIAN) {
|
else if (endianness == G_BIG_ENDIAN) {
|
||||||
*format = AFMT_S16_BE;
|
*format = AFMT_S16_BE;
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO,
|
GST_DEBUG (
|
||||||
"16 bit signed BE, no law (%d)", *format);
|
"16 bit signed BE, no law (%d)", *format);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if (endianness == G_LITTLE_ENDIAN) {
|
if (endianness == G_LITTLE_ENDIAN) {
|
||||||
*format = AFMT_U16_LE;
|
*format = AFMT_U16_LE;
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO,
|
GST_DEBUG (
|
||||||
"16 bit unsigned LE, no law (%d)", *format);
|
"16 bit unsigned LE, no law (%d)", *format);
|
||||||
}
|
}
|
||||||
else if (endianness == G_BIG_ENDIAN) {
|
else if (endianness == G_BIG_ENDIAN) {
|
||||||
*format = AFMT_U16_BE;
|
*format = AFMT_U16_BE;
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO,
|
GST_DEBUG (
|
||||||
"16 bit unsigned BE, no law (%d)", *format);
|
"16 bit unsigned BE, no law (%d)", *format);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -73,23 +73,23 @@ gst_ossformat_get (gint law, gint endianness, gboolean sign, gint width, gint de
|
||||||
else if (width == 8) {
|
else if (width == 8) {
|
||||||
if (sign == TRUE) {
|
if (sign == TRUE) {
|
||||||
*format = AFMT_S8;
|
*format = AFMT_S8;
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO,
|
GST_DEBUG (
|
||||||
"8 bit signed, no law (%d)", *format);
|
"8 bit signed, no law (%d)", *format);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
*format = AFMT_U8;
|
*format = AFMT_U8;
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO,
|
GST_DEBUG (
|
||||||
"8 bit unsigned, no law (%d)", *format);
|
"8 bit unsigned, no law (%d)", *format);
|
||||||
}
|
}
|
||||||
*bps = 1;
|
*bps = 1;
|
||||||
}
|
}
|
||||||
} else if (law == 1) {
|
} else if (law == 1) {
|
||||||
*format = AFMT_MU_LAW;
|
*format = AFMT_MU_LAW;
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO,
|
GST_DEBUG (
|
||||||
"mu law (%d)", *format);
|
"mu law (%d)", *format);
|
||||||
} else if (law == 2) {
|
} else if (law == 2) {
|
||||||
*format = AFMT_A_LAW;
|
*format = AFMT_A_LAW;
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO,
|
GST_DEBUG (
|
||||||
"a law (%d)", *format);
|
"a law (%d)", *format);
|
||||||
} else {
|
} else {
|
||||||
g_critical ("unknown law");
|
g_critical ("unknown law");
|
||||||
|
@ -147,7 +147,7 @@ gst_osscommon_parse_caps (GstOssCommon *common, GstCaps *caps)
|
||||||
if (!gst_ossformat_get (common->law, common->endianness, common->sign,
|
if (!gst_ossformat_get (common->law, common->endianness, common->sign,
|
||||||
common->width, common->depth, &format, &bps))
|
common->width, common->depth, &format, &bps))
|
||||||
{
|
{
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO, "could not get format");
|
GST_DEBUG ("could not get format");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -216,7 +216,7 @@ gst_osscommon_sync_parms (GstOssCommon *common)
|
||||||
else
|
else
|
||||||
frag = 0x7FFF0000 | common->fragment;
|
frag = 0x7FFF0000 | common->fragment;
|
||||||
|
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO,
|
GST_INFO (
|
||||||
"common: setting sound card to %dHz %d format %s (%08x fragment)",
|
"common: setting sound card to %dHz %d format %s (%08x fragment)",
|
||||||
common->rate, common->format,
|
common->rate, common->format,
|
||||||
(common->channels == 2) ? "stereo" : "mono", frag);
|
(common->channels == 2) ? "stereo" : "mono", frag);
|
||||||
|
@ -250,7 +250,7 @@ gst_osscommon_sync_parms (GstOssCommon *common)
|
||||||
}
|
}
|
||||||
common->fragment = space.fragstotal << 16 | frag_ln;
|
common->fragment = space.fragstotal << 16 | frag_ln;
|
||||||
|
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO,
|
GST_INFO (
|
||||||
"common: set sound card to %dHz, %d format, %s "
|
"common: set sound card to %dHz, %d format, %s "
|
||||||
"(%d bytes buffer, %08x fragment)",
|
"(%d bytes buffer, %08x fragment)",
|
||||||
common->rate, common->format,
|
common->rate, common->format,
|
||||||
|
@ -258,7 +258,7 @@ gst_osscommon_sync_parms (GstOssCommon *common)
|
||||||
space.bytes, common->fragment);
|
space.bytes, common->fragment);
|
||||||
|
|
||||||
common->fragment_time = (GST_SECOND * common->fragment_size) / common->bps;
|
common->fragment_time = (GST_SECOND * common->fragment_size) / common->bps;
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "fragment time %u %" G_GUINT64_FORMAT "\n",
|
GST_INFO ( "fragment time %u %" G_GUINT64_FORMAT "\n",
|
||||||
common->bps, common->fragment_time);
|
common->bps, common->fragment_time);
|
||||||
|
|
||||||
if (target_format != common->format ||
|
if (target_format != common->format ||
|
||||||
|
@ -278,7 +278,7 @@ gst_osscommon_open_audio (GstOssCommon *common, GstOssOpenMode mode, gchar **err
|
||||||
gint caps;
|
gint caps;
|
||||||
g_return_val_if_fail (common->fd == -1, FALSE);
|
g_return_val_if_fail (common->fd == -1, FALSE);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "common: attempting to open sound device");
|
GST_INFO ( "common: attempting to open sound device");
|
||||||
|
|
||||||
/* first try to open the sound card */
|
/* first try to open the sound card */
|
||||||
if (mode == GST_OSSCOMMON_WRITE) {
|
if (mode == GST_OSSCOMMON_WRITE) {
|
||||||
|
@ -336,41 +336,41 @@ gst_osscommon_open_audio (GstOssCommon *common, GstOssOpenMode mode, gchar **err
|
||||||
/* set card state */
|
/* set card state */
|
||||||
ioctl (common->fd, SNDCTL_DSP_GETCAPS, &caps);
|
ioctl (common->fd, SNDCTL_DSP_GETCAPS, &caps);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "osscommon: Capabilities %08x", caps);
|
GST_INFO ( "osscommon: Capabilities %08x", caps);
|
||||||
|
|
||||||
if (caps & DSP_CAP_DUPLEX) GST_INFO (GST_CAT_PLUGIN_INFO, "osscommon: Full duplex");
|
if (caps & DSP_CAP_DUPLEX) GST_INFO ( "osscommon: Full duplex");
|
||||||
if (caps & DSP_CAP_REALTIME) GST_INFO (GST_CAT_PLUGIN_INFO, "osscommon: Realtime");
|
if (caps & DSP_CAP_REALTIME) GST_INFO ( "osscommon: Realtime");
|
||||||
if (caps & DSP_CAP_BATCH) GST_INFO (GST_CAT_PLUGIN_INFO, "osscommon: Batch");
|
if (caps & DSP_CAP_BATCH) GST_INFO ( "osscommon: Batch");
|
||||||
if (caps & DSP_CAP_COPROC) GST_INFO (GST_CAT_PLUGIN_INFO, "osscommon: Has coprocessor");
|
if (caps & DSP_CAP_COPROC) GST_INFO ( "osscommon: Has coprocessor");
|
||||||
if (caps & DSP_CAP_TRIGGER) GST_INFO (GST_CAT_PLUGIN_INFO, "osscommon: Trigger");
|
if (caps & DSP_CAP_TRIGGER) GST_INFO ( "osscommon: Trigger");
|
||||||
if (caps & DSP_CAP_MMAP) GST_INFO (GST_CAT_PLUGIN_INFO, "osscommon: Direct access");
|
if (caps & DSP_CAP_MMAP) GST_INFO ( "osscommon: Direct access");
|
||||||
|
|
||||||
#ifdef DSP_CAP_MULTI
|
#ifdef DSP_CAP_MULTI
|
||||||
if (caps & DSP_CAP_MULTI) GST_INFO (GST_CAT_PLUGIN_INFO, "osscommon: Multiple open");
|
if (caps & DSP_CAP_MULTI) GST_INFO ( "osscommon: Multiple open");
|
||||||
#endif /* DSP_CAP_MULTI */
|
#endif /* DSP_CAP_MULTI */
|
||||||
|
|
||||||
#ifdef DSP_CAP_BIND
|
#ifdef DSP_CAP_BIND
|
||||||
if (caps & DSP_CAP_BIND) GST_INFO (GST_CAT_PLUGIN_INFO, "osscommon: Channel binding");
|
if (caps & DSP_CAP_BIND) GST_INFO ( "osscommon: Channel binding");
|
||||||
#endif /* DSP_CAP_BIND */
|
#endif /* DSP_CAP_BIND */
|
||||||
|
|
||||||
ioctl(common->fd, SNDCTL_DSP_GETFMTS, &caps);
|
ioctl(common->fd, SNDCTL_DSP_GETFMTS, &caps);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "osscommon: Formats %08x", caps);
|
GST_INFO ( "osscommon: Formats %08x", caps);
|
||||||
if (caps & AFMT_MU_LAW) GST_INFO (GST_CAT_PLUGIN_INFO, "osscommon: MU_LAW");
|
if (caps & AFMT_MU_LAW) GST_INFO ( "osscommon: MU_LAW");
|
||||||
if (caps & AFMT_A_LAW) GST_INFO (GST_CAT_PLUGIN_INFO, "osscommon: A_LAW");
|
if (caps & AFMT_A_LAW) GST_INFO ( "osscommon: A_LAW");
|
||||||
if (caps & AFMT_IMA_ADPCM) GST_INFO (GST_CAT_PLUGIN_INFO, "osscommon: IMA_ADPCM");
|
if (caps & AFMT_IMA_ADPCM) GST_INFO ( "osscommon: IMA_ADPCM");
|
||||||
if (caps & AFMT_U8) GST_INFO (GST_CAT_PLUGIN_INFO, "osscommon: U8");
|
if (caps & AFMT_U8) GST_INFO ( "osscommon: U8");
|
||||||
if (caps & AFMT_S16_LE) GST_INFO (GST_CAT_PLUGIN_INFO, "osscommon: S16_LE");
|
if (caps & AFMT_S16_LE) GST_INFO ( "osscommon: S16_LE");
|
||||||
if (caps & AFMT_S16_BE) GST_INFO (GST_CAT_PLUGIN_INFO, "osscommon: S16_BE");
|
if (caps & AFMT_S16_BE) GST_INFO ( "osscommon: S16_BE");
|
||||||
if (caps & AFMT_S8) GST_INFO (GST_CAT_PLUGIN_INFO, "osscommon: S8");
|
if (caps & AFMT_S8) GST_INFO ( "osscommon: S8");
|
||||||
if (caps & AFMT_U16_LE) GST_INFO (GST_CAT_PLUGIN_INFO, "osscommon: U16_LE");
|
if (caps & AFMT_U16_LE) GST_INFO ( "osscommon: U16_LE");
|
||||||
if (caps & AFMT_U16_BE) GST_INFO (GST_CAT_PLUGIN_INFO, "osscommon: U16_BE");
|
if (caps & AFMT_U16_BE) GST_INFO ( "osscommon: U16_BE");
|
||||||
if (caps & AFMT_MPEG) GST_INFO (GST_CAT_PLUGIN_INFO, "osscommon: MPEG");
|
if (caps & AFMT_MPEG) GST_INFO ( "osscommon: MPEG");
|
||||||
#ifdef AFMT_AC3
|
#ifdef AFMT_AC3
|
||||||
if (caps & AFMT_AC3) GST_INFO (GST_CAT_PLUGIN_INFO, "osscommon: AC3");
|
if (caps & AFMT_AC3) GST_INFO ( "osscommon: AC3");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO,
|
GST_INFO (
|
||||||
"osscommon: opened audio (%s) with fd=%d", common->device, common->fd);
|
"osscommon: opened audio (%s) with fd=%d", common->device, common->fd);
|
||||||
|
|
||||||
common->caps = caps;
|
common->caps = caps;
|
||||||
|
|
|
@ -21,6 +21,9 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <sys/ioctl.h>
|
#include <sys/ioctl.h>
|
||||||
|
@ -173,7 +176,7 @@ gst_ossgst_format_to_caps (gint format, gint stereo, gint rate)
|
||||||
gint width = 16;
|
gint width = 16;
|
||||||
gboolean supported = TRUE;
|
gboolean supported = TRUE;
|
||||||
|
|
||||||
GST_DEBUG (0, "have format 0x%08x %d %d", format, stereo, rate);
|
GST_DEBUG ("have format 0x%08x %d %d", format, stereo, rate);
|
||||||
|
|
||||||
switch (format) {
|
switch (format) {
|
||||||
case AFMT_MU_LAW:
|
case AFMT_MU_LAW:
|
||||||
|
@ -342,7 +345,7 @@ gst_ossgst_spawn_process (GstOssGst *ossgst)
|
||||||
pipe(ossgst->fdin);
|
pipe(ossgst->fdin);
|
||||||
pipe(ossgst->fdout);
|
pipe(ossgst->fdout);
|
||||||
|
|
||||||
GST_DEBUG (0, "about to fork");
|
GST_DEBUG ("about to fork");
|
||||||
|
|
||||||
if((ossgst->childpid = fork()) == -1)
|
if((ossgst->childpid = fork()) == -1)
|
||||||
{
|
{
|
||||||
|
@ -350,13 +353,13 @@ gst_ossgst_spawn_process (GstOssGst *ossgst)
|
||||||
gst_element_error(GST_ELEMENT(ossgst),"forking");
|
gst_element_error(GST_ELEMENT(ossgst),"forking");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
GST_DEBUG (0,"forked %d", ossgst->childpid);
|
GST_DEBUG ("forked %d", ossgst->childpid);
|
||||||
|
|
||||||
if(ossgst->childpid == 0)
|
if(ossgst->childpid == 0)
|
||||||
{
|
{
|
||||||
gchar **args;
|
gchar **args;
|
||||||
|
|
||||||
GST_DEBUG (0, "fork command %d", ossgst->childpid);
|
GST_DEBUG ("fork command %d", ossgst->childpid);
|
||||||
|
|
||||||
ld_preload = getenv ("LD_PRELOAD");
|
ld_preload = getenv ("LD_PRELOAD");
|
||||||
|
|
||||||
|
|
|
@ -20,11 +20,15 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <sys/ioctl.h>
|
#include <sys/ioctl.h>
|
||||||
#include <sys/soundcard.h>
|
#include <sys/soundcard.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
#include <gstosssink.h>
|
#include "gstosssink.h"
|
||||||
|
|
||||||
/* elementfactory information */
|
/* elementfactory information */
|
||||||
static GstElementDetails gst_osssink_details = {
|
static GstElementDetails gst_osssink_details = {
|
||||||
|
@ -634,7 +638,7 @@ gst_osssink_change_state (GstElement *element)
|
||||||
gst_osscommon_close_audio (&osssink->common);
|
gst_osscommon_close_audio (&osssink->common);
|
||||||
GST_FLAG_UNSET (osssink, GST_OSSSINK_OPEN);
|
GST_FLAG_UNSET (osssink, GST_OSSSINK_OPEN);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_PLUGIN_INFO, "osssink: closed sound device");
|
GST_INFO ( "osssink: closed sound device");
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,6 +20,9 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
|
@ -322,7 +325,7 @@ gst_osssrc_get (GstPad *pad)
|
||||||
|
|
||||||
src = GST_OSSSRC(gst_pad_get_parent (pad));
|
src = GST_OSSSRC(gst_pad_get_parent (pad));
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO, "attempting to read something from the soundcard");
|
GST_DEBUG ("attempting to read something from the soundcard");
|
||||||
|
|
||||||
if (src->need_eos) {
|
if (src->need_eos) {
|
||||||
src->need_eos = FALSE;
|
src->need_eos = FALSE;
|
||||||
|
@ -368,7 +371,7 @@ gst_osssrc_get (GstPad *pad)
|
||||||
|
|
||||||
src->curoffset += readbytes;
|
src->curoffset += readbytes;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO, "pushed buffer from soundcard of %ld bytes, timestamp %" G_GINT64_FORMAT,
|
GST_DEBUG ("pushed buffer from soundcard of %ld bytes, timestamp %" G_GINT64_FORMAT,
|
||||||
readbytes, GST_BUFFER_TIMESTAMP (buf));
|
readbytes, GST_BUFFER_TIMESTAMP (buf));
|
||||||
|
|
||||||
return buf;
|
return buf;
|
||||||
|
@ -426,7 +429,7 @@ gst_osssrc_change_state (GstElement *element)
|
||||||
{
|
{
|
||||||
GstOssSrc *osssrc = GST_OSSSRC (element);
|
GstOssSrc *osssrc = GST_OSSSRC (element);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_INFO, "osssrc: state change");
|
GST_DEBUG ("osssrc: state change");
|
||||||
|
|
||||||
switch (GST_STATE_TRANSITION (element)) {
|
switch (GST_STATE_TRANSITION (element)) {
|
||||||
case GST_STATE_NULL_TO_READY:
|
case GST_STATE_NULL_TO_READY:
|
||||||
|
|
|
@ -430,7 +430,7 @@ gst_v4l2src_v4l2fourcc_to_caps (guint32 fourcc,
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
GST_DEBUG(GST_CAT_PLUGIN_INFO,
|
GST_DEBUG (
|
||||||
"Unknown fourcc 0x%08x " GST_FOURCC_FORMAT ", trying default",
|
"Unknown fourcc 0x%08x " GST_FOURCC_FORMAT ", trying default",
|
||||||
fourcc, GST_FOURCC_ARGS(fourcc));
|
fourcc, GST_FOURCC_ARGS(fourcc));
|
||||||
|
|
||||||
|
|
|
@ -31,7 +31,7 @@
|
||||||
#include "v4l2_calls.h"
|
#include "v4l2_calls.h"
|
||||||
|
|
||||||
#define DEBUG(format, args...) \
|
#define DEBUG(format, args...) \
|
||||||
GST_DEBUG_ELEMENT(GST_CAT_PLUGIN_INFO, \
|
GST_DEBUG_OBJECT (\
|
||||||
GST_ELEMENT(v4l2element), \
|
GST_ELEMENT(v4l2element), \
|
||||||
"V4L2-overlay: " format, ##args)
|
"V4L2-overlay: " format, ##args)
|
||||||
|
|
||||||
|
|
|
@ -31,7 +31,7 @@
|
||||||
#include "v4l2_calls.h"
|
#include "v4l2_calls.h"
|
||||||
|
|
||||||
#define DEBUG(format, args...) \
|
#define DEBUG(format, args...) \
|
||||||
GST_DEBUG_ELEMENT(GST_CAT_PLUGIN_INFO, \
|
GST_DEBUG_OBJECT (\
|
||||||
GST_ELEMENT(v4l2element), \
|
GST_ELEMENT(v4l2element), \
|
||||||
"V4L2: " format, ##args)
|
"V4L2: " format, ##args)
|
||||||
|
|
||||||
|
|
|
@ -29,7 +29,7 @@
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
|
|
||||||
#define DEBUG(format, args...) \
|
#define DEBUG(format, args...) \
|
||||||
GST_DEBUG_ELEMENT(GST_CAT_PLUGIN_INFO, \
|
GST_DEBUG_OBJECT (\
|
||||||
GST_ELEMENT(v4l2src), \
|
GST_ELEMENT(v4l2src), \
|
||||||
"V4L2SRC: " format, ##args)
|
"V4L2SRC: " format, ##args)
|
||||||
|
|
||||||
|
@ -400,7 +400,7 @@ gst_v4l2src_grab_frame (GstV4l2Src *v4l2src,
|
||||||
while (v4l2src->frame_queue_state[v4l2src->queue_frame] !=
|
while (v4l2src->frame_queue_state[v4l2src->queue_frame] !=
|
||||||
QUEUE_STATE_READY_FOR_QUEUE &&
|
QUEUE_STATE_READY_FOR_QUEUE &&
|
||||||
!v4l2src->quit) {
|
!v4l2src->quit) {
|
||||||
GST_DEBUG(GST_CAT_PLUGIN_INFO,
|
GST_DEBUG (
|
||||||
"Waiting for frames to become available (%d < %d)",
|
"Waiting for frames to become available (%d < %d)",
|
||||||
v4l2src->num_queued, MIN_BUFFERS_QUEUED);
|
v4l2src->num_queued, MIN_BUFFERS_QUEUED);
|
||||||
g_cond_wait(v4l2src->cond_queue_state,
|
g_cond_wait(v4l2src->cond_queue_state,
|
||||||
|
|
Loading…
Reference in a new issue