mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-06-07 07:58:51 +00:00
ext/cdparanoia/gstcdparanoiasrc.*: Add back 'transport-error' and 'uncorrected-error' signals and make them actually ...
Original commit message from CVS: * ext/cdparanoia/gstcdparanoiasrc.c: (gst_cd_paranoia_src_class_init), (gst_cd_paranoia_dummy_callback), (gst_cd_paranoia_paranoia_callback), (gst_cd_paranoia_src_signal_is_being_watched), (gst_cd_paranoia_src_read_sector): * ext/cdparanoia/gstcdparanoiasrc.h: Add back 'transport-error' and 'uncorrected-error' signals and make them actually be fired when bad stuff happens (#319340).
This commit is contained in:
parent
3451a81879
commit
43db7b6e18
3 changed files with 106 additions and 4 deletions
11
ChangeLog
11
ChangeLog
|
@ -1,3 +1,14 @@
|
||||||
|
2006-02-17 Tim-Philipp Müller <tim at centricular dot net>
|
||||||
|
|
||||||
|
* ext/cdparanoia/gstcdparanoiasrc.c:
|
||||||
|
(gst_cd_paranoia_src_class_init), (gst_cd_paranoia_dummy_callback),
|
||||||
|
(gst_cd_paranoia_paranoia_callback),
|
||||||
|
(gst_cd_paranoia_src_signal_is_being_watched),
|
||||||
|
(gst_cd_paranoia_src_read_sector):
|
||||||
|
* ext/cdparanoia/gstcdparanoiasrc.h:
|
||||||
|
Add back 'transport-error' and 'uncorrected-error' signals and
|
||||||
|
make them actually be fired when bad stuff happens (#319340).
|
||||||
|
|
||||||
2006-02-17 Wim Taymans <wim@fluendo.com>
|
2006-02-17 Wim Taymans <wim@fluendo.com>
|
||||||
|
|
||||||
* gst-libs/gst/audio/gstringbuffer.c: (gst_ring_buffer_get_type),
|
* gst-libs/gst/audio/gstringbuffer.c: (gst_ring_buffer_get_type),
|
||||||
|
|
|
@ -30,6 +30,13 @@
|
||||||
#include "gstcdparanoiasrc.h"
|
#include "gstcdparanoiasrc.h"
|
||||||
#include "gst/gst-i18n-plugin.h"
|
#include "gst/gst-i18n-plugin.h"
|
||||||
|
|
||||||
|
enum
|
||||||
|
{
|
||||||
|
TRANSPORT_ERROR,
|
||||||
|
UNCORRECTED_ERROR,
|
||||||
|
NUM_SIGNALS
|
||||||
|
};
|
||||||
|
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
PROP_0,
|
PROP_0,
|
||||||
|
@ -68,6 +75,15 @@ static GstElementDetails cdparanoia_details = {
|
||||||
"Erik Walthinsen <omega@cse.ogi.edu>, " "Wim Taymans <wim@fluendo.com>"
|
"Erik Walthinsen <omega@cse.ogi.edu>, " "Wim Taymans <wim@fluendo.com>"
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* We use these to serialize calls to paranoia_read() among several
|
||||||
|
* cdparanoiasrc instances. We do this because it's the only reasonably
|
||||||
|
* easy way to find out the calling object from within the paranoia
|
||||||
|
* callback, and we need the object instance in there to emit our signals */
|
||||||
|
static GstCdParanoiaSrc *cur_cb_source;
|
||||||
|
static GStaticMutex cur_cb_mutex = G_STATIC_MUTEX_INIT;
|
||||||
|
|
||||||
|
static gint cdpsrc_signals[NUM_SIGNALS]; /* all 0 */
|
||||||
|
|
||||||
#define GST_TYPE_CD_PARANOIA_MODE (gst_cd_paranoia_mode_get_type())
|
#define GST_TYPE_CD_PARANOIA_MODE (gst_cd_paranoia_mode_get_type())
|
||||||
static GType
|
static GType
|
||||||
gst_cd_paranoia_mode_get_type (void)
|
gst_cd_paranoia_mode_get_type (void)
|
||||||
|
@ -142,6 +158,19 @@ gst_cd_paranoia_src_class_init (GstCdParanoiaSrcClass * klass)
|
||||||
g_param_spec_int ("search-overlap", "Search overlap",
|
g_param_spec_int ("search-overlap", "Search overlap",
|
||||||
"Force minimum overlap search during verification to n sectors", -1,
|
"Force minimum overlap search during verification to n sectors", -1,
|
||||||
75, DEFAULT_SEARCH_OVERLAP, G_PARAM_READWRITE));
|
75, DEFAULT_SEARCH_OVERLAP, G_PARAM_READWRITE));
|
||||||
|
|
||||||
|
/* FIXME: we don't really want signals for this, but messages on the bus,
|
||||||
|
* but then we can't check any longer whether anyone is interested in them */
|
||||||
|
cdpsrc_signals[TRANSPORT_ERROR] =
|
||||||
|
g_signal_new ("transport-error", G_TYPE_FROM_CLASS (klass),
|
||||||
|
G_SIGNAL_RUN_LAST,
|
||||||
|
G_STRUCT_OFFSET (GstCdParanoiaSrcClass, transport_error),
|
||||||
|
NULL, NULL, g_cclosure_marshal_VOID__INT, G_TYPE_NONE, 1, G_TYPE_INT);
|
||||||
|
cdpsrc_signals[UNCORRECTED_ERROR] =
|
||||||
|
g_signal_new ("uncorrected-error", G_TYPE_FROM_CLASS (klass),
|
||||||
|
G_SIGNAL_RUN_LAST,
|
||||||
|
G_STRUCT_OFFSET (GstCdParanoiaSrcClass, uncorrected_error),
|
||||||
|
NULL, NULL, g_cclosure_marshal_VOID__INT, G_TYPE_NONE, 1, G_TYPE_INT);
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
|
@ -246,12 +275,36 @@ gst_cd_paranoia_src_close (GstCddaBaseSrc * cddabasesrc)
|
||||||
src->next_sector = -1;
|
src->next_sector = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
gst_cd_paranoia_dummy_callback (long inpos, int function)
|
||||||
|
{
|
||||||
|
/* Used by instanced where no one is interested what's happening here */
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_cd_paranoia_paranoia_callback (long inpos, int function)
|
gst_cd_paranoia_paranoia_callback (long inpos, int function)
|
||||||
{
|
{
|
||||||
/* There is not much we can do here (not without a lot of trickery
|
GstCdParanoiaSrc *src = cur_cb_source;
|
||||||
* at least), since we don't have a pointer to our own element or at
|
gint sector = (gint) (inpos / CD_FRAMEWORDS);
|
||||||
* least the cdparanoia object */
|
|
||||||
|
switch (function) {
|
||||||
|
case PARANOIA_CB_SKIP:
|
||||||
|
GST_INFO_OBJECT (src, "Skip at sector %d", sector);
|
||||||
|
g_signal_emit (src, cdpsrc_signals[UNCORRECTED_ERROR], 0, sector);
|
||||||
|
break;
|
||||||
|
case PARANOIA_CB_READERR:
|
||||||
|
GST_INFO_OBJECT (src, "Transport error at sector %d", sector);
|
||||||
|
g_signal_emit (src, cdpsrc_signals[TRANSPORT_ERROR], 0, sector);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
gst_cd_paranoia_src_signal_is_being_watched (GstCdParanoiaSrc * src, gint sig)
|
||||||
|
{
|
||||||
|
return g_signal_has_handler_pending (src, cdpsrc_signals[sig], 0, FALSE);
|
||||||
}
|
}
|
||||||
|
|
||||||
static GstBuffer *
|
static GstBuffer *
|
||||||
|
@ -259,6 +312,7 @@ gst_cd_paranoia_src_read_sector (GstCddaBaseSrc * cddabasesrc, gint sector)
|
||||||
{
|
{
|
||||||
GstCdParanoiaSrc *src = GST_CD_PARANOIA_SRC (cddabasesrc);
|
GstCdParanoiaSrc *src = GST_CD_PARANOIA_SRC (cddabasesrc);
|
||||||
GstBuffer *buf;
|
GstBuffer *buf;
|
||||||
|
gboolean do_serialize;
|
||||||
gint16 *cdda_buf;
|
gint16 *cdda_buf;
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
|
@ -285,8 +339,25 @@ gst_cd_paranoia_src_read_sector (GstCddaBaseSrc * cddabasesrc, gint sector)
|
||||||
src->next_sector = sector;
|
src->next_sector = sector;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
do_serialize =
|
||||||
|
gst_cd_paranoia_src_signal_is_being_watched (src, TRANSPORT_ERROR) ||
|
||||||
|
gst_cd_paranoia_src_signal_is_being_watched (src, UNCORRECTED_ERROR);
|
||||||
|
|
||||||
|
if (do_serialize) {
|
||||||
|
GST_LOG_OBJECT (src, "Signal handlers connected, serialising access");
|
||||||
|
g_static_mutex_lock (&cur_cb_mutex);
|
||||||
|
GST_LOG_OBJECT (src, "Got lock");
|
||||||
|
cur_cb_source = src;
|
||||||
|
|
||||||
cdda_buf = paranoia_read (src->p, gst_cd_paranoia_paranoia_callback);
|
cdda_buf = paranoia_read (src->p, gst_cd_paranoia_paranoia_callback);
|
||||||
|
|
||||||
|
cur_cb_source = NULL;
|
||||||
|
GST_LOG_OBJECT (src, "Releasing lock");
|
||||||
|
g_static_mutex_unlock (&cur_cb_mutex);
|
||||||
|
} else {
|
||||||
|
cdda_buf = paranoia_read (src->p, gst_cd_paranoia_dummy_callback);
|
||||||
|
}
|
||||||
|
|
||||||
if (cdda_buf == NULL) {
|
if (cdda_buf == NULL) {
|
||||||
GST_WARNING_OBJECT (src, "read at sector %d failed!", sector);
|
GST_WARNING_OBJECT (src, "read at sector %d failed!", sector);
|
||||||
GST_ELEMENT_ERROR (src, RESOURCE, READ,
|
GST_ELEMENT_ERROR (src, RESOURCE, READ,
|
||||||
|
|
|
@ -64,6 +64,26 @@ struct _GstCdParanoiaSrc {
|
||||||
|
|
||||||
struct _GstCdParanoiaSrcClass {
|
struct _GstCdParanoiaSrcClass {
|
||||||
GstCddaBaseSrcClass parent_class;
|
GstCddaBaseSrcClass parent_class;
|
||||||
|
|
||||||
|
/* signal callbacks */
|
||||||
|
/**
|
||||||
|
* GstCdParanoiaSrcClass::transport-error:
|
||||||
|
* @src: the GstCddaBaseSrc source element object
|
||||||
|
* @sector: the sector at which the error happened
|
||||||
|
*
|
||||||
|
* This signal is emitted when a sector could not be read
|
||||||
|
* because of a transport error.
|
||||||
|
*/
|
||||||
|
void (*transport_error) (GstCdParanoiaSrc * src, gint sector);
|
||||||
|
/**
|
||||||
|
* GstCdParanoiaSrcClass::uncorrected-error:
|
||||||
|
* @src: the GstCddaBaseSrc source element object
|
||||||
|
* @sector: the sector at which the error happened
|
||||||
|
*
|
||||||
|
* This signal is emitted when a sector could not be read
|
||||||
|
* because of a transport error.
|
||||||
|
*/
|
||||||
|
void (*uncorrected_error) (GstCdParanoiaSrc * src, gint sector);
|
||||||
};
|
};
|
||||||
|
|
||||||
GType gst_cd_paranoia_src_get_type (void);
|
GType gst_cd_paranoia_src_get_type (void);
|
||||||
|
|
Loading…
Reference in a new issue