mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-11-23 10:11:08 +00:00
actually recurse into sndfile if we are able big ladspa cleanups, mainly to comply with the buffer-frames caps proper...
Original commit message from CVS: * actually recurse into sndfile if we are able * big ladspa cleanups, mainly to comply with the buffer-frames caps property, but also general cleanups - the samplerate prop is gone, if you want to set it explicitly (as in for get-based plugins) you need to use a filtered connection, just like with buffer-frames * big float2int and int2float changes for buffer-frames compatibility - I think it's quite a bit simpler * make the ossclock general, add it to gstaudio, and use it in sndfile as well i need to update mimetypes, but that's coming soon. there are some other plugins that don't support buffer-frames, i guess i need to get around to fixing them as well.
This commit is contained in:
parent
4418ea9659
commit
6f06c87c12
10 changed files with 355 additions and 803 deletions
|
@ -273,7 +273,7 @@ SUBDIRS=$(A52DEC_DIR) $(AALIB_DIR) $(ALSA_DIR) \
|
|||
$(MAD_DIR) $(MATROSKA_DIR) $(MIKMOD_DIR) \
|
||||
$(MPEG2DEC_DIR) $(PANGO_DIR) $(RAW1394_DIR) \
|
||||
$(SDL_DIR) $(SHOUT_DIR) $(SIDPLAY_DIR) \
|
||||
$(SMOOTHWAVE_DIR) $(SWFDEC_DIR) $(TARKIN_DIR) \
|
||||
$(SMOOTHWAVE_DIR) $(SNDFILE_DIR) $(SWFDEC_DIR) $(TARKIN_DIR) \
|
||||
$(VORBIS_DIR) $(XVID_DIR) $(SNAPSHOT_DIR)
|
||||
|
||||
DIST_SUBDIRS=\
|
||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -60,12 +60,11 @@ struct _GstLADSPA {
|
|||
GstPad **sinkpads,
|
||||
**srcpads;
|
||||
|
||||
|
||||
GstBufferPool *bufpool;
|
||||
|
||||
gboolean newcaps, activated;
|
||||
gboolean activated;
|
||||
|
||||
gint samplerate, buffersize, numbuffers;
|
||||
gint samplerate, buffer_frames;
|
||||
gint64 timestamp;
|
||||
gboolean inplace_broken;
|
||||
};
|
||||
|
|
|
@ -8,7 +8,6 @@ libgstossaudio_la_SOURCES = gstosssink.c \
|
|||
gstosssrc.c \
|
||||
gstossaudio.c \
|
||||
gstossgst.c \
|
||||
gstossclock.c \
|
||||
gstosscommon.c
|
||||
|
||||
libgstossaudio_la_CFLAGS = $(GST_CFLAGS)
|
||||
|
@ -18,4 +17,4 @@ libgstossaudio_la_LDFLAGS = $(GST_PLUGIN_LDFLAGS)
|
|||
libgstosshelper_la_SOURCES = gstosshelper.c
|
||||
libgstosshelper_la_LDFLAGS = $(GST_PLUGIN_LDFLAGS)
|
||||
|
||||
noinst_HEADERS = gstosssink.h gstosssrc.h gstossgst.h gstossclock.h gstosshelper.h gstosscommon.h
|
||||
noinst_HEADERS = gstosssink.h gstosssrc.h gstossgst.h gstosshelper.h gstosscommon.h
|
||||
|
|
|
@ -27,6 +27,9 @@ plugin_init (GModule *module, GstPlugin *plugin)
|
|||
{
|
||||
gboolean ret;
|
||||
|
||||
if (!gst_library_load ("gstaudio"))
|
||||
return FALSE;
|
||||
|
||||
ret = gst_osssink_factory_init (plugin);
|
||||
g_return_val_if_fail (ret == TRUE, FALSE);
|
||||
|
||||
|
|
|
@ -1,191 +0,0 @@
|
|||
/* GStreamer
|
||||
* Copyright (C) 1999,2000 Erik Walthinsen <omega@cse.ogi.edu>
|
||||
* 2000 Wim Taymans <wtay@chello.be>
|
||||
*
|
||||
* gstclock.c: Clock subsystem for maintaining time sync
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU Library General Public
|
||||
* License as published by the Free Software Foundation; either
|
||||
* version 2 of the License, or (at your option) any later version.
|
||||
*
|
||||
* This library is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* Library General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Library General Public
|
||||
* License along with this library; if not, write to the
|
||||
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
||||
* Boston, MA 02111-1307, USA.
|
||||
*/
|
||||
|
||||
#include "gstossclock.h"
|
||||
|
||||
static void gst_oss_clock_class_init (GstOssClockClass *klass);
|
||||
static void gst_oss_clock_init (GstOssClock *clock);
|
||||
|
||||
static GstClockTime gst_oss_clock_get_internal_time (GstClock *clock);
|
||||
static GstClockReturn gst_oss_clock_id_wait_async (GstClock *clock,
|
||||
GstClockEntry *entry);
|
||||
static void gst_oss_clock_id_unschedule (GstClock *clock,
|
||||
GstClockEntry *entry);
|
||||
|
||||
static GstSystemClockClass *parent_class = NULL;
|
||||
/* static guint gst_oss_clock_signals[LAST_SIGNAL] = { 0 }; */
|
||||
|
||||
GType
|
||||
gst_oss_clock_get_type (void)
|
||||
{
|
||||
static GType clock_type = 0;
|
||||
|
||||
if (!clock_type) {
|
||||
static const GTypeInfo clock_info = {
|
||||
sizeof (GstOssClockClass),
|
||||
NULL,
|
||||
NULL,
|
||||
(GClassInitFunc) gst_oss_clock_class_init,
|
||||
NULL,
|
||||
NULL,
|
||||
sizeof (GstOssClock),
|
||||
4,
|
||||
(GInstanceInitFunc) gst_oss_clock_init,
|
||||
NULL
|
||||
};
|
||||
clock_type = g_type_register_static (GST_TYPE_SYSTEM_CLOCK, "GstOssClock",
|
||||
&clock_info, 0);
|
||||
}
|
||||
return clock_type;
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
gst_oss_clock_class_init (GstOssClockClass *klass)
|
||||
{
|
||||
GObjectClass *gobject_class;
|
||||
GstObjectClass *gstobject_class;
|
||||
GstClockClass *gstclock_class;
|
||||
|
||||
gobject_class = (GObjectClass*) klass;
|
||||
gstobject_class = (GstObjectClass*) klass;
|
||||
gstclock_class = (GstClockClass*) klass;
|
||||
|
||||
parent_class = g_type_class_ref (GST_TYPE_SYSTEM_CLOCK);
|
||||
|
||||
gstclock_class->get_internal_time = gst_oss_clock_get_internal_time;
|
||||
gstclock_class->wait_async = gst_oss_clock_id_wait_async;
|
||||
gstclock_class->unschedule = gst_oss_clock_id_unschedule;
|
||||
}
|
||||
|
||||
static void
|
||||
gst_oss_clock_init (GstOssClock *clock)
|
||||
{
|
||||
gst_object_set_name (GST_OBJECT (clock), "GstOssClock");
|
||||
|
||||
clock->prev1 = 0;
|
||||
clock->prev2 = 0;
|
||||
}
|
||||
|
||||
GstOssClock*
|
||||
gst_oss_clock_new (gchar *name, GstOssClockGetTimeFunc func, gpointer user_data)
|
||||
{
|
||||
GstOssClock *oss_clock = GST_OSS_CLOCK (g_object_new (GST_TYPE_OSS_CLOCK, NULL));
|
||||
|
||||
oss_clock->func = func;
|
||||
oss_clock->user_data = user_data;
|
||||
oss_clock->adjust = 0;
|
||||
|
||||
return oss_clock;
|
||||
}
|
||||
|
||||
void
|
||||
gst_oss_clock_set_active (GstClock *clock, gboolean active)
|
||||
{
|
||||
GstOssClock *oss_clock = GST_OSS_CLOCK (clock);
|
||||
GTimeVal timeval;
|
||||
GstClockTime time;
|
||||
GstClockTime osstime;
|
||||
|
||||
g_get_current_time (&timeval);
|
||||
time = GST_TIMEVAL_TO_TIME (timeval);
|
||||
osstime = oss_clock->func (clock, oss_clock->user_data);
|
||||
|
||||
if (active) {
|
||||
oss_clock->adjust = time - osstime;
|
||||
}
|
||||
else {
|
||||
oss_clock->adjust = osstime - time;
|
||||
}
|
||||
|
||||
oss_clock->active = active;
|
||||
}
|
||||
|
||||
static GstClockTime
|
||||
gst_oss_clock_get_internal_time (GstClock *clock)
|
||||
{
|
||||
GstOssClock *oss_clock = GST_OSS_CLOCK (clock);
|
||||
|
||||
if (oss_clock->active) {
|
||||
GstClockTime osstime;
|
||||
|
||||
osstime = oss_clock->func (clock, oss_clock->user_data) + oss_clock->adjust;
|
||||
|
||||
return osstime;
|
||||
}
|
||||
else {
|
||||
GstClockTime time;
|
||||
GTimeVal timeval;
|
||||
|
||||
g_get_current_time (&timeval);
|
||||
time = GST_TIMEVAL_TO_TIME (timeval);
|
||||
|
||||
return time;
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
gst_oss_clock_update_time (GstClock *clock, GstClockTime time)
|
||||
{
|
||||
GstOssClock *oss_clock = (GstOssClock*)clock;
|
||||
|
||||
while (oss_clock->async_entries) {
|
||||
GstClockEntry *entry = (GstClockEntry*)oss_clock->async_entries->data;
|
||||
|
||||
if (entry->time > time)
|
||||
break;
|
||||
|
||||
entry->func (clock, time, entry, entry->user_data);
|
||||
|
||||
oss_clock->async_entries = g_slist_delete_link (oss_clock->async_entries,
|
||||
oss_clock->async_entries);
|
||||
/* do I need to free the entry? */
|
||||
}
|
||||
}
|
||||
|
||||
static gint
|
||||
compare_clock_entries (GstClockEntry *entry1, GstClockEntry *entry2)
|
||||
{
|
||||
return entry1->time - entry2->time;
|
||||
}
|
||||
|
||||
static GstClockReturn
|
||||
gst_oss_clock_id_wait_async (GstClock *clock, GstClockEntry *entry)
|
||||
{
|
||||
GstOssClock *oss_clock = (GstOssClock*)clock;
|
||||
|
||||
oss_clock->async_entries = g_slist_insert_sorted (oss_clock->async_entries,
|
||||
entry,
|
||||
(GCompareFunc)compare_clock_entries);
|
||||
|
||||
/* is this the proper return val? */
|
||||
return GST_CLOCK_EARLY;
|
||||
}
|
||||
|
||||
static void
|
||||
gst_oss_clock_id_unschedule (GstClock *clock, GstClockEntry *entry)
|
||||
{
|
||||
GstOssClock *oss_clock = (GstOssClock*)clock;
|
||||
|
||||
oss_clock->async_entries = g_slist_remove (oss_clock->async_entries,
|
||||
entry);
|
||||
}
|
|
@ -1,82 +0,0 @@
|
|||
/* GStreamer
|
||||
* Copyright (C) 1999,2000 Erik Walthinsen <omega@cse.ogi.edu>
|
||||
* 2000 Wim Taymans <wtay@chello.be>
|
||||
*
|
||||
* gstclock.h: Header for clock subsystem
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU Library General Public
|
||||
* License as published by the Free Software Foundation; either
|
||||
* version 2 of the License, or (at your option) any later version.
|
||||
*
|
||||
* This library is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* Library General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Library General Public
|
||||
* License along with this library; if not, write to the
|
||||
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
||||
* Boston, MA 02111-1307, USA.
|
||||
*/
|
||||
|
||||
|
||||
#ifndef __GST_OSS_CLOCK_H__
|
||||
#define __GST_OSS_CLOCK_H__
|
||||
|
||||
#include <gst/gstsystemclock.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif /* __cplusplus */
|
||||
|
||||
|
||||
#define GST_TYPE_OSS_CLOCK \
|
||||
(gst_oss_clock_get_type())
|
||||
#define GST_OSS_CLOCK(obj) \
|
||||
(G_TYPE_CHECK_INSTANCE_CAST((obj),GST_TYPE_OSS_CLOCK,GstOssClock))
|
||||
#define GST_OSS_CLOCK_CLASS(klass) \
|
||||
(G_TYPE_CHECK_CLASS_CAST((klass),GST_TYPE_OSS_CLOCK,GstOssClockClass))
|
||||
#define GST_IS_OSS_CLOCK(obj) \
|
||||
(G_TYPE_CHECK_INSTANCE_TYPE((obj),GST_TYPE_OSS_CLOCK))
|
||||
#define GST_IS_OSS_CLOCK_CLASS(obj) \
|
||||
(G_TYPE_CHECK_CLASS_TYPE((klass),GST_TYPE_OSS_CLOCK))
|
||||
|
||||
typedef struct _GstOssClock GstOssClock;
|
||||
typedef struct _GstOssClockClass GstOssClockClass;
|
||||
|
||||
typedef GstClockTime (*GstOssClockGetTimeFunc) (GstClock *clock, gpointer user_data);
|
||||
|
||||
|
||||
struct _GstOssClock {
|
||||
GstSystemClock clock;
|
||||
|
||||
GstOssClockGetTimeFunc func;
|
||||
gpointer user_data;
|
||||
|
||||
GstClockTime prev1, prev2;
|
||||
GstClockTimeDiff adjust;
|
||||
|
||||
GSList *async_entries;
|
||||
|
||||
gboolean active;
|
||||
};
|
||||
|
||||
struct _GstOssClockClass {
|
||||
GstSystemClockClass parent_class;
|
||||
};
|
||||
|
||||
GType gst_oss_clock_get_type (void);
|
||||
GstOssClock* gst_oss_clock_new (gchar *name, GstOssClockGetTimeFunc func,
|
||||
gpointer user_data);
|
||||
void gst_oss_clock_set_active (GstClock *clock, gboolean active);
|
||||
void gst_oss_clock_set_time (GstClock *clock, GstClockTime time);
|
||||
|
||||
void gst_oss_clock_update_time (GstClock *clock, GstClockTime time);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif /* __cplusplus */
|
||||
|
||||
|
||||
#endif /* __GST_OSS_CLOCK_H__ */
|
|
@ -243,7 +243,7 @@ gst_osssink_init (GstOssSink *osssink)
|
|||
osssink->mute = FALSE;
|
||||
osssink->sync = TRUE;
|
||||
osssink->sinkpool = NULL;
|
||||
osssink->provided_clock = GST_CLOCK (gst_oss_clock_new ("ossclock", gst_osssink_get_time, osssink));
|
||||
osssink->provided_clock = gst_audio_clock_new ("ossclock", gst_osssink_get_time, osssink);
|
||||
gst_object_set_parent (GST_OBJECT (osssink->provided_clock), GST_OBJECT (osssink));
|
||||
osssink->handled = 0;
|
||||
|
||||
|
@ -348,7 +348,7 @@ gst_osssink_chain (GstPad *pad, GstBuffer *buf)
|
|||
switch (GST_EVENT_TYPE (event)) {
|
||||
case GST_EVENT_EOS:
|
||||
ioctl (osssink->common.fd, SNDCTL_DSP_SYNC);
|
||||
gst_oss_clock_set_active (osssink->provided_clock, FALSE);
|
||||
gst_audio_clock_set_active (GST_AUDIO_CLOCK (osssink->provided_clock), FALSE);
|
||||
gst_pad_event_default (pad, event);
|
||||
return;
|
||||
case GST_EVENT_DISCONTINUOUS:
|
||||
|
@ -358,7 +358,7 @@ gst_osssink_chain (GstPad *pad, GstBuffer *buf)
|
|||
ioctl (osssink->common.fd, SNDCTL_DSP_RESET);
|
||||
if (gst_event_discont_get_value (event, GST_FORMAT_TIME, &value)) {
|
||||
if (!gst_clock_handle_discont (osssink->clock, value))
|
||||
gst_oss_clock_set_active (osssink->provided_clock, FALSE);
|
||||
gst_audio_clock_set_active (GST_AUDIO_CLOCK (osssink->provided_clock), FALSE);
|
||||
osssink->handled = 0;
|
||||
}
|
||||
osssink->resync = TRUE;
|
||||
|
@ -403,7 +403,7 @@ gst_osssink_chain (GstPad *pad, GstBuffer *buf)
|
|||
if (jitter >= 0) {
|
||||
gst_clock_handle_discont (osssink->clock, buftime - queued + jitter);
|
||||
to_write = size;
|
||||
gst_oss_clock_set_active (osssink->provided_clock, TRUE);
|
||||
gst_audio_clock_set_active ((GstAudioClock*)osssink->provided_clock, TRUE);
|
||||
osssink->resync = FALSE;
|
||||
}
|
||||
}
|
||||
|
@ -439,8 +439,7 @@ gst_osssink_chain (GstPad *pad, GstBuffer *buf)
|
|||
}
|
||||
}
|
||||
|
||||
if (osssink->clock)
|
||||
gst_oss_clock_update_time (osssink->clock, buftime);
|
||||
gst_audio_clock_update_time ((GstAudioClock*)osssink->provided_clock, buftime);
|
||||
|
||||
gst_buffer_unref (buf);
|
||||
}
|
||||
|
@ -627,7 +626,7 @@ gst_osssink_change_state (GstElement *element)
|
|||
{
|
||||
if (GST_FLAG_IS_SET (element, GST_OSSSINK_OPEN))
|
||||
ioctl (osssink->common.fd, SNDCTL_DSP_RESET, 0);
|
||||
gst_oss_clock_set_active (osssink->provided_clock, FALSE);
|
||||
gst_audio_clock_set_active (GST_AUDIO_CLOCK (osssink->provided_clock), FALSE);
|
||||
osssink->resync = TRUE;
|
||||
break;
|
||||
}
|
||||
|
|
|
@ -28,7 +28,7 @@
|
|||
#include <gst/gst.h>
|
||||
|
||||
#include "gstosscommon.h"
|
||||
#include "gstossclock.h"
|
||||
#include <gst/audio/audioclock.h>
|
||||
|
||||
G_BEGIN_DECLS
|
||||
|
||||
|
|
|
@ -34,7 +34,7 @@
|
|||
|
||||
#include <gstosssrc.h>
|
||||
#include <gstosscommon.h>
|
||||
#include <gstossclock.h>
|
||||
#include <gst/audio/audioclock.h>
|
||||
|
||||
/* elementfactory information */
|
||||
static GstElementDetails gst_osssrc_details = {
|
||||
|
@ -197,9 +197,7 @@ gst_osssrc_init (GstOssSrc *osssrc)
|
|||
osssrc->buffersize = 4096;
|
||||
osssrc->curoffset = 0;
|
||||
|
||||
osssrc->provided_clock = GST_CLOCK (gst_oss_clock_new ("ossclock",
|
||||
gst_osssrc_get_time,
|
||||
osssrc));
|
||||
osssrc->provided_clock = gst_audio_clock_new ("ossclock", gst_osssrc_get_time, osssrc);
|
||||
gst_object_set_parent (GST_OBJECT (osssrc->provided_clock), GST_OBJECT (osssrc));
|
||||
|
||||
osssrc->clock = NULL;
|
||||
|
@ -443,10 +441,10 @@ gst_osssrc_change_state (GstElement *element)
|
|||
osssrc->curoffset = 0;
|
||||
break;
|
||||
case GST_STATE_PAUSED_TO_PLAYING:
|
||||
gst_oss_clock_set_active (osssrc->provided_clock, TRUE);
|
||||
gst_audio_clock_set_active (GST_AUDIO_CLOCK (osssrc->provided_clock), TRUE);
|
||||
break;
|
||||
case GST_STATE_PLAYING_TO_PAUSED:
|
||||
gst_oss_clock_set_active (osssrc->provided_clock, FALSE);
|
||||
gst_audio_clock_set_active (GST_AUDIO_CLOCK (osssrc->provided_clock), FALSE);
|
||||
break;
|
||||
case GST_STATE_PAUSED_TO_READY:
|
||||
if (GST_FLAG_IS_SET (element, GST_OSSSRC_OPEN))
|
||||
|
|
Loading…
Reference in a new issue