mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-26 17:18:15 +00:00
Add new libgstcdda with GstCddaBaseSrc class.
Original commit message from CVS: * configure.ac: * gst-libs/gst/Makefile.am: * gst-libs/gst/cdda/Makefile.am: * gst-libs/gst/cdda/base64.c: * gst-libs/gst/cdda/base64.h: * gst-libs/gst/cdda/gstcddabasesrc.c: (gst_cdda_base_src_mode_get_type), (gst_cdda_base_src_base_init), (gst_cdda_base_src_class_init), (gst_cdda_base_src_init), (gst_cdda_base_src_finalize), (gst_cdda_base_src_set_property), (gst_cdda_base_src_get_property), (gst_cdda_base_src_get_track_from_sector), (gst_cdda_base_src_get_query_types), (gst_cdda_base_src_convert), (gst_cdda_base_src_query), (gst_cdda_base_src_is_seekable), (gst_cdda_base_src_do_seek), (gst_cdda_base_src_handle_track_seek), (gst_cdda_base_src_handle_event), (gst_cdda_base_src_uri_get_type), (gst_cdda_base_src_uri_get_protocols), (gst_cdda_base_src_uri_get_uri), (gst_cdda_base_src_uri_set_uri), (gst_cdda_base_src_uri_handler_init), (gst_cdda_base_src_setup_interfaces), (gst_cdda_base_src_add_track), (gst_cdda_base_src_update_duration), (cddb_sum), (gst_cddabasesrc_calculate_musicbrainz_discid), (lba_to_msf), (gst_cdda_base_src_calculate_cddb_id), (gst_cdda_base_src_add_tags), (gst_cdda_base_src_add_index_associations), (gst_cdda_base_src_set_index), (gst_cdda_base_src_get_index), (gst_cdda_base_src_track_sort_func), (gst_cdda_base_src_start), (gst_cdda_base_src_clear_tracks), (gst_cdda_base_src_stop), (gst_cdda_base_src_create): * gst-libs/gst/cdda/gstcddabasesrc.h: * gst-libs/gst/cdda/sha1.c: * gst-libs/gst/cdda/sha1.h: Add new libgstcdda with GstCddaBaseSrc class.
This commit is contained in:
parent
ab828f340f
commit
d129bea2be
10 changed files with 2477 additions and 0 deletions
35
ChangeLog
35
ChangeLog
|
@ -1,3 +1,38 @@
|
|||
2005-12-28 Tim-Philipp Müller <tim at centricular dot net>
|
||||
|
||||
* configure.ac:
|
||||
* gst-libs/gst/Makefile.am:
|
||||
* gst-libs/gst/cdda/Makefile.am:
|
||||
* gst-libs/gst/cdda/base64.c:
|
||||
* gst-libs/gst/cdda/base64.h:
|
||||
* gst-libs/gst/cdda/gstcddabasesrc.c:
|
||||
(gst_cdda_base_src_mode_get_type), (gst_cdda_base_src_base_init),
|
||||
(gst_cdda_base_src_class_init), (gst_cdda_base_src_init),
|
||||
(gst_cdda_base_src_finalize), (gst_cdda_base_src_set_property),
|
||||
(gst_cdda_base_src_get_property),
|
||||
(gst_cdda_base_src_get_track_from_sector),
|
||||
(gst_cdda_base_src_get_query_types), (gst_cdda_base_src_convert),
|
||||
(gst_cdda_base_src_query), (gst_cdda_base_src_is_seekable),
|
||||
(gst_cdda_base_src_do_seek), (gst_cdda_base_src_handle_track_seek),
|
||||
(gst_cdda_base_src_handle_event), (gst_cdda_base_src_uri_get_type),
|
||||
(gst_cdda_base_src_uri_get_protocols),
|
||||
(gst_cdda_base_src_uri_get_uri), (gst_cdda_base_src_uri_set_uri),
|
||||
(gst_cdda_base_src_uri_handler_init),
|
||||
(gst_cdda_base_src_setup_interfaces),
|
||||
(gst_cdda_base_src_add_track), (gst_cdda_base_src_update_duration),
|
||||
(cddb_sum), (gst_cddabasesrc_calculate_musicbrainz_discid),
|
||||
(lba_to_msf), (gst_cdda_base_src_calculate_cddb_id),
|
||||
(gst_cdda_base_src_add_tags),
|
||||
(gst_cdda_base_src_add_index_associations),
|
||||
(gst_cdda_base_src_set_index), (gst_cdda_base_src_get_index),
|
||||
(gst_cdda_base_src_track_sort_func), (gst_cdda_base_src_start),
|
||||
(gst_cdda_base_src_clear_tracks), (gst_cdda_base_src_stop),
|
||||
(gst_cdda_base_src_create):
|
||||
* gst-libs/gst/cdda/gstcddabasesrc.h:
|
||||
* gst-libs/gst/cdda/sha1.c:
|
||||
* gst-libs/gst/cdda/sha1.h:
|
||||
Add new libgstcdda with GstCddaBaseSrc class.
|
||||
|
||||
2005-12-28 Tim-Philipp Müller <tim at centricular dot net>
|
||||
|
||||
* ext/gnomevfs/gstgnomevfssink.h:
|
||||
|
|
|
@ -629,6 +629,7 @@ ext/vorbis/Makefile
|
|||
gst-libs/Makefile
|
||||
gst-libs/gst/Makefile
|
||||
gst-libs/gst/audio/Makefile
|
||||
gst-libs/gst/cdda/Makefile
|
||||
gst-libs/gst/floatcast/Makefile
|
||||
gst-libs/gst/interfaces/Makefile
|
||||
gst-libs/gst/netbuffer/Makefile
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
SUBDIRS = \
|
||||
audio \
|
||||
cdda \
|
||||
floatcast \
|
||||
interfaces \
|
||||
netbuffer \
|
||||
|
|
16
gst-libs/gst/cdda/Makefile.am
Normal file
16
gst-libs/gst/cdda/Makefile.am
Normal file
|
@ -0,0 +1,16 @@
|
|||
lib_LTLIBRARIES = libgstcdda-@GST_MAJORMINOR@.la
|
||||
|
||||
libgstcdda_@GST_MAJORMINOR@_la_SOURCES = \
|
||||
gstcddabasesrc.c \
|
||||
base64.c \
|
||||
base64.h \
|
||||
sha1.c \
|
||||
sha1.h
|
||||
|
||||
libgstcdda_@GST_MAJORMINOR@includedir = $(includedir)/gstreamer-@GST_MAJORMINOR@/gst/cdda
|
||||
libgstcdda_@GST_MAJORMINOR@include_HEADERS = \
|
||||
gstcddabasesrc.h
|
||||
|
||||
libgstcdda_@GST_MAJORMINOR@_la_LIBADD = $(GST_LIBS) $(GST_BASE_LIBS)
|
||||
libgstcdda_@GST_MAJORMINOR@_la_CFLAGS = $(GST_CFLAGS) $(GST_BASE_CFLAGS)
|
||||
libgstcdda_@GST_MAJORMINOR@_la_LDFLAGS = $(GST_LIB_LDFLAGS) $(GST_ALL_LDFLAGS) $(GST_LT_LDFLAGS)
|
115
gst-libs/gst/cdda/base64.c
Normal file
115
gst-libs/gst/cdda/base64.c
Normal file
|
@ -0,0 +1,115 @@
|
|||
/* --------------------------------------------------------------------------
|
||||
|
||||
MusicBrainz -- The Internet music metadatabase
|
||||
|
||||
Copyright (C) 2000 Robert Kaye
|
||||
|
||||
This library is free software; you can redistribute it and/or
|
||||
modify it under the terms of the GNU Lesser General Public
|
||||
License as published by the Free Software Foundation; either
|
||||
version 2.1 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
|
||||
Lesser General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU Lesser 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
|
||||
|
||||
$Id$
|
||||
|
||||
----------------------------------------------------------------------------*/
|
||||
/*
|
||||
* Program: RFC-822 routines (originally from SMTP)
|
||||
*
|
||||
* Author: Mark Crispin
|
||||
* Networks and Distributed Computing
|
||||
* Computing & Communications
|
||||
* University of Washington
|
||||
* Administration Building, AG-44
|
||||
* Seattle, WA 98195
|
||||
* Internet: MRC@CAC.Washington.EDU
|
||||
*
|
||||
* Date: 27 July 1988
|
||||
* Last Edited: 10 September 1998
|
||||
*
|
||||
* Sponsorship: The original version of this work was developed in the
|
||||
* Symbolic Systems Resources Group of the Knowledge Systems
|
||||
* Laboratory at Stanford University in 1987-88, and was funded
|
||||
* by the Biomedical Research Technology Program of the National
|
||||
* Institutes of Health under grant number RR-00785.
|
||||
*
|
||||
* Original version Copyright 1988 by The Leland Stanford Junior University
|
||||
* Copyright 1998 by the University of Washington
|
||||
*
|
||||
* Permission to use, copy, modify, and distribute this software and its
|
||||
* documentation for any purpose and without fee is hereby granted, provided
|
||||
* that the above copyright notices appear in all copies and that both the
|
||||
* above copyright notices and this permission notice appear in supporting
|
||||
* documentation, and that the name of the University of Washington or The
|
||||
* Leland Stanford Junior University not be used in advertising or publicity
|
||||
* pertaining to distribution of the software without specific, written prior
|
||||
* permission. This software is made available "as is", and
|
||||
* THE UNIVERSITY OF WASHINGTON AND THE LELAND STANFORD JUNIOR UNIVERSITY
|
||||
* DISCLAIM ALL WARRANTIES, EXPRESS OR IMPLIED, WITH REGARD TO THIS SOFTWARE,
|
||||
* INCLUDING WITHOUT LIMITATION ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
||||
* FITNESS FOR A PARTICULAR PURPOSE, AND IN NO EVENT SHALL THE UNIVERSITY OF
|
||||
* WASHINGTON OR THE LELAND STANFORD JUNIOR UNIVERSITY BE LIABLE FOR ANY
|
||||
* SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER
|
||||
* RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF
|
||||
* CONTRACT, TORT (INCLUDING NEGLIGENCE) OR STRICT LIABILITY, ARISING OUT OF
|
||||
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||
*
|
||||
*/
|
||||
|
||||
#include <ctype.h>
|
||||
#include <stdio.h>
|
||||
#include <time.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
#include "base64.h"
|
||||
|
||||
/* NOTE: This is not true RFC822 anymore. The use of the characters
|
||||
'/', '+', and '=' is no bueno when the ID will be used as part of a URL.
|
||||
'_', '.', and '-' have been used instead
|
||||
*/
|
||||
|
||||
/* Convert binary contents to BASE64
|
||||
* Accepts: source
|
||||
* length of source
|
||||
* pointer to return destination length
|
||||
* Returns: destination as BASE64
|
||||
*/
|
||||
|
||||
unsigned char *
|
||||
rfc822_binary (void *src, unsigned long srcl, unsigned long *len)
|
||||
{
|
||||
unsigned char *ret, *d;
|
||||
unsigned char *s = (unsigned char *) src;
|
||||
char *v = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789._";
|
||||
unsigned long i = ((srcl + 2) / 3) * 4;
|
||||
|
||||
*len = i += 2 * ((i / 60) + 1);
|
||||
d = ret = (unsigned char *) malloc ((size_t)++ i);
|
||||
for (i = 0; srcl; s += 3) { /* process tuplets */
|
||||
*d++ = v[s[0] >> 2]; /* byte 1: high 6 bits (1) */
|
||||
/* byte 2: low 2 bits (1), high 4 bits (2) */
|
||||
*d++ = v[((s[0] << 4) + (--srcl ? (s[1] >> 4) : 0)) & 0x3f];
|
||||
/* byte 3: low 4 bits (2), high 2 bits (3) */
|
||||
*d++ = srcl ? v[((s[1] << 2) + (--srcl ? (s[2] >> 6) : 0)) & 0x3f] : '-';
|
||||
/* byte 4: low 6 bits (3) */
|
||||
*d++ = srcl ? v[s[2] & 0x3f] : '-';
|
||||
if (srcl)
|
||||
srcl--; /* count third character if processed */
|
||||
if ((++i) == 15) { /* output 60 characters? */
|
||||
i = 0; /* restart line break count, insert CRLF */
|
||||
*d++ = '\015';
|
||||
*d++ = '\012';
|
||||
}
|
||||
}
|
||||
*d = '\0'; /* tie off string */
|
||||
|
||||
return ret; /* return the resulting string */
|
||||
}
|
75
gst-libs/gst/cdda/base64.h
Normal file
75
gst-libs/gst/cdda/base64.h
Normal file
|
@ -0,0 +1,75 @@
|
|||
/* --------------------------------------------------------------------------
|
||||
|
||||
MusicBrainz -- The Internet music metadatabase
|
||||
|
||||
Copyright (C) 2000 Robert Kaye
|
||||
|
||||
This library is free software; you can redistribute it and/or
|
||||
modify it under the terms of the GNU Lesser General Public
|
||||
License as published by the Free Software Foundation; either
|
||||
version 2.1 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
|
||||
Lesser General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU Lesser 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
|
||||
|
||||
$Id$
|
||||
|
||||
----------------------------------------------------------------------------*/
|
||||
/*
|
||||
* Program: RFC-822 routines (originally from SMTP)
|
||||
*
|
||||
* Author: Mark Crispin
|
||||
* Networks and Distributed Computing
|
||||
* Computing & Communications
|
||||
* University of Washington
|
||||
* Administration Building, AG-44
|
||||
* Seattle, WA 98195
|
||||
* Internet: MRC@CAC.Washington.EDU
|
||||
*
|
||||
* Date: 27 July 1988
|
||||
* Last Edited: 10 September 1998
|
||||
*
|
||||
* Sponsorship: The original version of this work was developed in the
|
||||
* Symbolic Systems Resources Group of the Knowledge Systems
|
||||
* Laboratory at Stanford University in 1987-88, and was funded
|
||||
* by the Biomedical Research Technology Program of the National
|
||||
* Institutes of Health under grant number RR-00785.
|
||||
*
|
||||
* Original version Copyright 1988 by The Leland Stanford Junior University
|
||||
* Copyright 1998 by the University of Washington
|
||||
*
|
||||
* Permission to use, copy, modify, and distribute this software and its
|
||||
* documentation for any purpose and without fee is hereby granted, provided
|
||||
* that the above copyright notices appear in all copies and that both the
|
||||
* above copyright notices and this permission notice appear in supporting
|
||||
* documentation, and that the name of the University of Washington or The
|
||||
* Leland Stanford Junior University not be used in advertising or publicity
|
||||
* pertaining to distribution of the software without specific, written prior
|
||||
* permission. This software is made available "as is", and
|
||||
* THE UNIVERSITY OF WASHINGTON AND THE LELAND STANFORD JUNIOR UNIVERSITY
|
||||
* DISCLAIM ALL WARRANTIES, EXPRESS OR IMPLIED, WITH REGARD TO THIS SOFTWARE,
|
||||
* INCLUDING WITHOUT LIMITATION ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
||||
* FITNESS FOR A PARTICULAR PURPOSE, AND IN NO EVENT SHALL THE UNIVERSITY OF
|
||||
* WASHINGTON OR THE LELAND STANFORD JUNIOR UNIVERSITY BE LIABLE FOR ANY
|
||||
* SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER
|
||||
* RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF
|
||||
* CONTRACT, TORT (INCLUDING NEGLIGENCE) OR STRICT LIABILITY, ARISING OUT OF
|
||||
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||
*
|
||||
*/
|
||||
|
||||
#ifndef __GST_CDDA_BASE64_H__
|
||||
#define __GST_CDDA_BASE64_H__
|
||||
|
||||
#define rfc822_binary _gst_cdda_rfc822_binary
|
||||
|
||||
unsigned char *rfc822_binary (void *src,unsigned long srcl,unsigned long *len);
|
||||
|
||||
#endif /* __GST_CDDA_BASE64_H__ */
|
||||
|
1541
gst-libs/gst/cdda/gstcddabasesrc.c
Normal file
1541
gst-libs/gst/cdda/gstcddabasesrc.c
Normal file
File diff suppressed because it is too large
Load diff
181
gst-libs/gst/cdda/gstcddabasesrc.h
Normal file
181
gst-libs/gst/cdda/gstcddabasesrc.h
Normal file
|
@ -0,0 +1,181 @@
|
|||
/* GStreamer
|
||||
* Copyright (C) 1999 Erik Walthinsen <omega@cse.ogi.edu>
|
||||
* Copyright (C) 2005 Tim-Philipp Müller <tim centricular net>
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU Library General Public
|
||||
* License as published by the Free Software Foundation; either
|
||||
* version 2 of the License, or (at your option) any later version.
|
||||
*
|
||||
* This library is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* Library General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Library General Public
|
||||
* License along with this library; if not, write to the
|
||||
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
||||
* Boston, MA 02111-1307, USA.
|
||||
*/
|
||||
|
||||
#ifndef __GST_CDDA_BASE_SRC_H__
|
||||
#define __GST_CDDA_BASE_SRC_H__
|
||||
|
||||
#include <gst/gst.h>
|
||||
#include <gst/base/gstpushsrc.h>
|
||||
|
||||
G_BEGIN_DECLS
|
||||
|
||||
#define GST_TYPE_CDDA_BASE_SRC (gst_cdda_base_src_get_type())
|
||||
#define GST_CDDA_BASE_SRC(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj), GST_TYPE_CDDA_BASE_SRC, GstCddaBaseSrc))
|
||||
#define GST_CDDA_BASE_SRC_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass), GST_TYPE_CDDA_BASE_SRC, GstCddaBaseSrcClass))
|
||||
#define GST_IS_CDDA_BASE_SRC(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj), GST_TYPE_CDDA_BASE_SRC))
|
||||
#define GST_IS_CDDA_BASE_SRC_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), GST_TYPE_CDDA_BASE_SRC))
|
||||
#define GST_CDDA_BASE_SRC_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GST_TYPE_CDDA_BASE_SRC, GstCddaBaseSrcClass))
|
||||
|
||||
typedef struct _GstCddaBaseSrc GstCddaBaseSrc;
|
||||
typedef struct _GstCddaBaseSrcClass GstCddaBaseSrcClass;
|
||||
typedef struct _GstCddaBaseSrcTrack GstCddaBaseSrcTrack;
|
||||
|
||||
/**
|
||||
* GstCddaBaseSrcMode:
|
||||
* @GST_CDDA_BASE_SRC_MODE_NORMAL : each single track is a stream
|
||||
* @GST_CDDA_BASE_SRC_MODE_CONTINUOUS : the entire disc is a single stream
|
||||
*
|
||||
* Mode in which the CD audio source operates. Influences timestamping,
|
||||
* EOS handling and seeking.
|
||||
*/
|
||||
typedef enum {
|
||||
GST_CDDA_BASE_SRC_MODE_NORMAL, /* stream = one track */
|
||||
GST_CDDA_BASE_SRC_MODE_CONTINUOUS /* stream = whole disc */
|
||||
} GstCddaBaseSrcMode;
|
||||
|
||||
/**
|
||||
* GstCddaBaseSrcTrack:
|
||||
* @is_audio: Whether this is an audio track
|
||||
* @num: Track number in TOC (usually starts from 1, but not always)
|
||||
* @start: The first sector of this track (LBA)
|
||||
* @end: The last sector of this track (LBA)
|
||||
* @tags: Track-specific tags (e.g. from cd-text information), or NULL
|
||||
*
|
||||
* CD track abstraction to communicate TOC entries to the base class.
|
||||
*/
|
||||
struct _GstCddaBaseSrcTrack {
|
||||
gboolean is_audio; /* TRUE if this is an audio track */
|
||||
guint num; /* real track number (usually starts from 1) */
|
||||
guint start; /* first sector of track (LBA, not LSN!) */
|
||||
guint end; /* last sector of track (LBA, not LSN!) */
|
||||
GstTagList *tags; /* NULL or tags for track (e.g. from cd-text) */
|
||||
|
||||
/*< private >*/
|
||||
guint _gst_reserved1[GST_PADDING/2];
|
||||
gpointer _gst_reserved2[GST_PADDING/2];
|
||||
};
|
||||
|
||||
struct _GstCddaBaseSrc {
|
||||
GstPushSrc pushsrc;
|
||||
|
||||
/*< protected >*/ /* for use by sub-classes only */
|
||||
GstTagList *tags; /* tags that apply to all tracks */
|
||||
|
||||
/*< private >*/
|
||||
GstCddaBaseSrcMode mode;
|
||||
|
||||
gchar *device;
|
||||
|
||||
guint num_tracks;
|
||||
guint num_all_tracks;
|
||||
GstCddaBaseSrcTrack *tracks;
|
||||
|
||||
gint cur_track; /* current track (starting from 0) */
|
||||
gint prev_track; /* current track last time */
|
||||
gint cur_sector; /* current sector */
|
||||
gint seek_sector; /* -1 or sector to seek to */
|
||||
|
||||
gint uri_track;
|
||||
gchar *uri;
|
||||
|
||||
guint32 discid; /* cddb disc id (for unit test) */
|
||||
gchar mb_discid[32]; /* musicbrainz discid */
|
||||
|
||||
GstIndex *index;
|
||||
gint index_id;
|
||||
|
||||
gint toc_offset;
|
||||
gboolean toc_bias;
|
||||
|
||||
/*< private >*/
|
||||
guint _gst_reserved1[GST_PADDING/2];
|
||||
gpointer _gst_reserved2[GST_PADDING/2];
|
||||
};
|
||||
|
||||
struct _GstCddaBaseSrcClass {
|
||||
GstPushSrcClass pushsrc_class;
|
||||
|
||||
/* open/close the CD device */
|
||||
gboolean (*open) (GstCddaBaseSrc *src, const gchar *device);
|
||||
void (*close) (GstCddaBaseSrc *src);
|
||||
|
||||
/* read one sector (LBA) */
|
||||
GstBuffer * (*read_sector) (GstCddaBaseSrc *src, gint sector);
|
||||
|
||||
/* return default device or NULL (optional) */
|
||||
gchar * (*get_default_device) (GstCddaBaseSrc *src);
|
||||
|
||||
/* return NULL-terminated string array of CD devices, or NULL (optional) */
|
||||
gchar ** (*probe_devices) (GstCddaBaseSrc *src);
|
||||
|
||||
/*< private >*/
|
||||
gpointer _gst_reserved[GST_PADDING];
|
||||
};
|
||||
|
||||
GType gst_cdda_base_src_get_type (void);
|
||||
|
||||
gboolean gst_cdda_base_src_add_track (GstCddaBaseSrc * src,
|
||||
GstCddaBaseSrcTrack * track);
|
||||
|
||||
|
||||
/* tags */
|
||||
|
||||
/**
|
||||
* GST_TAG_CDDA_CDDB_DISCID:
|
||||
*
|
||||
* CDDB disc id in its short form (e.g. 'aa063d0f')
|
||||
*/
|
||||
#define GST_TAG_CDDA_CDDB_DISCID "discid"
|
||||
|
||||
/**
|
||||
* GST_TAG_CDDA_CDDB_DISCID_FULL:
|
||||
*
|
||||
* CDDB disc id including all details
|
||||
*/
|
||||
#define GST_TAG_CDDA_CDDB_DISCID_FULL "discid-full"
|
||||
|
||||
/**
|
||||
* GST_TAG_CDDA_MUSICBRAINZ_DISCID:
|
||||
*
|
||||
* Musicbrainz disc id (e.g. 'ahg7JUcfR3vCYBphSDIogOOWrr0-')
|
||||
*/
|
||||
#define GST_TAG_CDDA_MUSICBRAINZ_DISCID "musicbrainz-discid"
|
||||
|
||||
/**
|
||||
* GST_TAG_CDDA_MUSICBRAINZ_DISCID_FULL:
|
||||
*
|
||||
* Musicbrainz disc id details
|
||||
*/
|
||||
#define GST_TAG_CDDA_MUSICBRAINZ_DISCID_FULL "musicbrainz-discid-full"
|
||||
|
||||
#if 0
|
||||
/**
|
||||
* GST_TAG_CDDA_TRACK_TAGS:
|
||||
*
|
||||
* Tag details for all available tracks
|
||||
* FiXME: find out which type we want for this!
|
||||
*/
|
||||
#define GST_TAG_CDDA_TRACK_TAGS "track-tags"
|
||||
#endif
|
||||
|
||||
G_END_DECLS
|
||||
|
||||
#endif /* __GST_CDDA_BASE_SRC_H__ */
|
||||
|
450
gst-libs/gst/cdda/sha1.c
Normal file
450
gst-libs/gst/cdda/sha1.c
Normal file
|
@ -0,0 +1,450 @@
|
|||
/* (PD) 2001 The Bitzi Corporation
|
||||
* Please see file COPYING or http://bitzi.com/publicdomain
|
||||
* for more info.
|
||||
*
|
||||
* NIST Secure Hash Algorithm
|
||||
* heavily modified by Uwe Hollerbach <uh@alumni.caltech edu>
|
||||
* from Peter C. Gutmann's implementation as found in
|
||||
* Applied Cryptography by Bruce Schneier
|
||||
* Further modifications to include the "UNRAVEL" stuff, below
|
||||
*
|
||||
* This code is in the public domain
|
||||
*
|
||||
* $Id$
|
||||
*/
|
||||
|
||||
#ifdef HAVE_CONFIG_H
|
||||
#include "config.h"
|
||||
#endif
|
||||
#include <glib.h>
|
||||
#define SHA_BYTE_ORDER G_BYTE_ORDER
|
||||
|
||||
#include <string.h>
|
||||
#include "sha1.h"
|
||||
|
||||
/* UNRAVEL should be fastest & biggest */
|
||||
/* UNROLL_LOOPS should be just as big, but slightly slower */
|
||||
/* both undefined should be smallest and slowest */
|
||||
|
||||
#define UNRAVEL
|
||||
/* #define UNROLL_LOOPS */
|
||||
|
||||
/* SHA f()-functions */
|
||||
|
||||
#define f1(x,y,z) ((x & y) | (~x & z))
|
||||
#define f2(x,y,z) (x ^ y ^ z)
|
||||
#define f3(x,y,z) ((x & y) | (x & z) | (y & z))
|
||||
#define f4(x,y,z) (x ^ y ^ z)
|
||||
|
||||
/* SHA constants */
|
||||
|
||||
#define CONST1 0x5a827999L
|
||||
#define CONST2 0x6ed9eba1L
|
||||
#define CONST3 0x8f1bbcdcL
|
||||
#define CONST4 0xca62c1d6L
|
||||
|
||||
/* truncate to 32 bits -- should be a null op on 32-bit machines */
|
||||
|
||||
#define T32(x) ((x) & 0xffffffffL)
|
||||
|
||||
/* 32-bit rotate */
|
||||
|
||||
#define R32(x,n) T32(((x << n) | (x >> (32 - n))))
|
||||
|
||||
/* the generic case, for when the overall rotation is not unraveled */
|
||||
|
||||
#define FG(n) \
|
||||
T = T32(R32(A,5) + f##n(B,C,D) + E + *WP++ + CONST##n); \
|
||||
E = D; D = C; C = R32(B,30); B = A; A = T
|
||||
|
||||
/* specific cases, for when the overall rotation is unraveled */
|
||||
|
||||
#define FA(n) \
|
||||
T = T32(R32(A,5) + f##n(B,C,D) + E + *WP++ + CONST##n); B = R32(B,30)
|
||||
|
||||
#define FB(n) \
|
||||
E = T32(R32(T,5) + f##n(A,B,C) + D + *WP++ + CONST##n); A = R32(A,30)
|
||||
|
||||
#define FC(n) \
|
||||
D = T32(R32(E,5) + f##n(T,A,B) + C + *WP++ + CONST##n); T = R32(T,30)
|
||||
|
||||
#define FD(n) \
|
||||
C = T32(R32(D,5) + f##n(E,T,A) + B + *WP++ + CONST##n); E = R32(E,30)
|
||||
|
||||
#define FE(n) \
|
||||
B = T32(R32(C,5) + f##n(D,E,T) + A + *WP++ + CONST##n); D = R32(D,30)
|
||||
|
||||
#define FT(n) \
|
||||
A = T32(R32(B,5) + f##n(C,D,E) + T + *WP++ + CONST##n); C = R32(C,30)
|
||||
|
||||
/* do SHA transformation */
|
||||
|
||||
static void
|
||||
sha_transform (SHA_INFO * sha_info)
|
||||
{
|
||||
int i;
|
||||
SHA_BYTE *dp;
|
||||
SHA_LONG T, A, B, C, D, E, W[80], *WP;
|
||||
|
||||
dp = sha_info->data;
|
||||
|
||||
/*
|
||||
the following makes sure that at least one code block below is
|
||||
traversed or an error is reported, without the necessity for nested
|
||||
preprocessor if/else/endif blocks, which are a great pain in the
|
||||
nether regions of the anatomy...
|
||||
*/
|
||||
#undef SWAP_DONE
|
||||
|
||||
#if (SHA_BYTE_ORDER == 1234)
|
||||
#define SWAP_DONE
|
||||
for (i = 0; i < 16; ++i) {
|
||||
T = *((SHA_LONG *) dp);
|
||||
dp += 4;
|
||||
W[i] = ((T << 24) & 0xff000000) | ((T << 8) & 0x00ff0000) |
|
||||
((T >> 8) & 0x0000ff00) | ((T >> 24) & 0x000000ff);
|
||||
}
|
||||
#endif /* SHA_BYTE_ORDER == 1234 */
|
||||
|
||||
#if (SHA_BYTE_ORDER == 4321)
|
||||
#define SWAP_DONE
|
||||
for (i = 0; i < 16; ++i) {
|
||||
T = *((SHA_LONG *) dp);
|
||||
dp += 4;
|
||||
W[i] = T32 (T);
|
||||
}
|
||||
#endif /* SHA_BYTE_ORDER == 4321 */
|
||||
|
||||
#if (SHA_BYTE_ORDER == 12345678)
|
||||
#define SWAP_DONE
|
||||
for (i = 0; i < 16; i += 2) {
|
||||
T = *((SHA_LONG *) dp);
|
||||
dp += 8;
|
||||
W[i] = ((T << 24) & 0xff000000) | ((T << 8) & 0x00ff0000) |
|
||||
((T >> 8) & 0x0000ff00) | ((T >> 24) & 0x000000ff);
|
||||
T >>= 32;
|
||||
W[i + 1] = ((T << 24) & 0xff000000) | ((T << 8) & 0x00ff0000) |
|
||||
((T >> 8) & 0x0000ff00) | ((T >> 24) & 0x000000ff);
|
||||
}
|
||||
#endif /* SHA_BYTE_ORDER == 12345678 */
|
||||
|
||||
#if (SHA_BYTE_ORDER == 87654321)
|
||||
#define SWAP_DONE
|
||||
for (i = 0; i < 16; i += 2) {
|
||||
T = *((SHA_LONG *) dp);
|
||||
dp += 8;
|
||||
W[i] = T32 (T >> 32);
|
||||
W[i + 1] = T32 (T);
|
||||
}
|
||||
#endif /* SHA_BYTE_ORDER == 87654321 */
|
||||
|
||||
#ifndef SWAP_DONE
|
||||
#error Unknown byte order -- you need to add code here
|
||||
#endif /* SWAP_DONE */
|
||||
|
||||
for (i = 16; i < 80; ++i) {
|
||||
W[i] = W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16];
|
||||
#if (SHA_VERSION == 1)
|
||||
W[i] = R32 (W[i], 1);
|
||||
#endif /* SHA_VERSION */
|
||||
}
|
||||
A = sha_info->digest[0];
|
||||
B = sha_info->digest[1];
|
||||
C = sha_info->digest[2];
|
||||
D = sha_info->digest[3];
|
||||
E = sha_info->digest[4];
|
||||
WP = W;
|
||||
#ifdef UNRAVEL
|
||||
FA (1);
|
||||
FB (1);
|
||||
FC (1);
|
||||
FD (1);
|
||||
FE (1);
|
||||
FT (1);
|
||||
FA (1);
|
||||
FB (1);
|
||||
FC (1);
|
||||
FD (1);
|
||||
FE (1);
|
||||
FT (1);
|
||||
FA (1);
|
||||
FB (1);
|
||||
FC (1);
|
||||
FD (1);
|
||||
FE (1);
|
||||
FT (1);
|
||||
FA (1);
|
||||
FB (1);
|
||||
FC (2);
|
||||
FD (2);
|
||||
FE (2);
|
||||
FT (2);
|
||||
FA (2);
|
||||
FB (2);
|
||||
FC (2);
|
||||
FD (2);
|
||||
FE (2);
|
||||
FT (2);
|
||||
FA (2);
|
||||
FB (2);
|
||||
FC (2);
|
||||
FD (2);
|
||||
FE (2);
|
||||
FT (2);
|
||||
FA (2);
|
||||
FB (2);
|
||||
FC (2);
|
||||
FD (2);
|
||||
FE (3);
|
||||
FT (3);
|
||||
FA (3);
|
||||
FB (3);
|
||||
FC (3);
|
||||
FD (3);
|
||||
FE (3);
|
||||
FT (3);
|
||||
FA (3);
|
||||
FB (3);
|
||||
FC (3);
|
||||
FD (3);
|
||||
FE (3);
|
||||
FT (3);
|
||||
FA (3);
|
||||
FB (3);
|
||||
FC (3);
|
||||
FD (3);
|
||||
FE (3);
|
||||
FT (3);
|
||||
FA (4);
|
||||
FB (4);
|
||||
FC (4);
|
||||
FD (4);
|
||||
FE (4);
|
||||
FT (4);
|
||||
FA (4);
|
||||
FB (4);
|
||||
FC (4);
|
||||
FD (4);
|
||||
FE (4);
|
||||
FT (4);
|
||||
FA (4);
|
||||
FB (4);
|
||||
FC (4);
|
||||
FD (4);
|
||||
FE (4);
|
||||
FT (4);
|
||||
FA (4);
|
||||
FB (4);
|
||||
sha_info->digest[0] = T32 (sha_info->digest[0] + E);
|
||||
sha_info->digest[1] = T32 (sha_info->digest[1] + T);
|
||||
sha_info->digest[2] = T32 (sha_info->digest[2] + A);
|
||||
sha_info->digest[3] = T32 (sha_info->digest[3] + B);
|
||||
sha_info->digest[4] = T32 (sha_info->digest[4] + C);
|
||||
#else /* !UNRAVEL */
|
||||
#ifdef UNROLL_LOOPS
|
||||
FG (1);
|
||||
FG (1);
|
||||
FG (1);
|
||||
FG (1);
|
||||
FG (1);
|
||||
FG (1);
|
||||
FG (1);
|
||||
FG (1);
|
||||
FG (1);
|
||||
FG (1);
|
||||
FG (1);
|
||||
FG (1);
|
||||
FG (1);
|
||||
FG (1);
|
||||
FG (1);
|
||||
FG (1);
|
||||
FG (1);
|
||||
FG (1);
|
||||
FG (1);
|
||||
FG (1);
|
||||
FG (2);
|
||||
FG (2);
|
||||
FG (2);
|
||||
FG (2);
|
||||
FG (2);
|
||||
FG (2);
|
||||
FG (2);
|
||||
FG (2);
|
||||
FG (2);
|
||||
FG (2);
|
||||
FG (2);
|
||||
FG (2);
|
||||
FG (2);
|
||||
FG (2);
|
||||
FG (2);
|
||||
FG (2);
|
||||
FG (2);
|
||||
FG (2);
|
||||
FG (2);
|
||||
FG (2);
|
||||
FG (3);
|
||||
FG (3);
|
||||
FG (3);
|
||||
FG (3);
|
||||
FG (3);
|
||||
FG (3);
|
||||
FG (3);
|
||||
FG (3);
|
||||
FG (3);
|
||||
FG (3);
|
||||
FG (3);
|
||||
FG (3);
|
||||
FG (3);
|
||||
FG (3);
|
||||
FG (3);
|
||||
FG (3);
|
||||
FG (3);
|
||||
FG (3);
|
||||
FG (3);
|
||||
FG (3);
|
||||
FG (4);
|
||||
FG (4);
|
||||
FG (4);
|
||||
FG (4);
|
||||
FG (4);
|
||||
FG (4);
|
||||
FG (4);
|
||||
FG (4);
|
||||
FG (4);
|
||||
FG (4);
|
||||
FG (4);
|
||||
FG (4);
|
||||
FG (4);
|
||||
FG (4);
|
||||
FG (4);
|
||||
FG (4);
|
||||
FG (4);
|
||||
FG (4);
|
||||
FG (4);
|
||||
FG (4);
|
||||
#else /* !UNROLL_LOOPS */
|
||||
for (i = 0; i < 20; ++i) {
|
||||
FG (1);
|
||||
}
|
||||
for (i = 20; i < 40; ++i) {
|
||||
FG (2);
|
||||
}
|
||||
for (i = 40; i < 60; ++i) {
|
||||
FG (3);
|
||||
}
|
||||
for (i = 60; i < 80; ++i) {
|
||||
FG (4);
|
||||
}
|
||||
#endif /* !UNROLL_LOOPS */
|
||||
sha_info->digest[0] = T32 (sha_info->digest[0] + A);
|
||||
sha_info->digest[1] = T32 (sha_info->digest[1] + B);
|
||||
sha_info->digest[2] = T32 (sha_info->digest[2] + C);
|
||||
sha_info->digest[3] = T32 (sha_info->digest[3] + D);
|
||||
sha_info->digest[4] = T32 (sha_info->digest[4] + E);
|
||||
#endif /* !UNRAVEL */
|
||||
}
|
||||
|
||||
/* initialize the SHA digest */
|
||||
|
||||
void
|
||||
sha_init (SHA_INFO * sha_info)
|
||||
{
|
||||
sha_info->digest[0] = 0x67452301L;
|
||||
sha_info->digest[1] = 0xefcdab89L;
|
||||
sha_info->digest[2] = 0x98badcfeL;
|
||||
sha_info->digest[3] = 0x10325476L;
|
||||
sha_info->digest[4] = 0xc3d2e1f0L;
|
||||
sha_info->count_lo = 0L;
|
||||
sha_info->count_hi = 0L;
|
||||
sha_info->local = 0;
|
||||
}
|
||||
|
||||
/* update the SHA digest */
|
||||
|
||||
void
|
||||
sha_update (SHA_INFO * sha_info, SHA_BYTE * buffer, int count)
|
||||
{
|
||||
int i;
|
||||
SHA_LONG clo;
|
||||
|
||||
clo = T32 (sha_info->count_lo + ((SHA_LONG) count << 3));
|
||||
if (clo < sha_info->count_lo) {
|
||||
++sha_info->count_hi;
|
||||
}
|
||||
sha_info->count_lo = clo;
|
||||
sha_info->count_hi += (SHA_LONG) count >> 29;
|
||||
if (sha_info->local) {
|
||||
i = SHA_BLOCKSIZE - sha_info->local;
|
||||
if (i > count) {
|
||||
i = count;
|
||||
}
|
||||
memcpy (((SHA_BYTE *) sha_info->data) + sha_info->local, buffer, i);
|
||||
count -= i;
|
||||
buffer += i;
|
||||
sha_info->local += i;
|
||||
if (sha_info->local == SHA_BLOCKSIZE) {
|
||||
sha_transform (sha_info);
|
||||
} else {
|
||||
return;
|
||||
}
|
||||
}
|
||||
while (count >= SHA_BLOCKSIZE) {
|
||||
memcpy (sha_info->data, buffer, SHA_BLOCKSIZE);
|
||||
buffer += SHA_BLOCKSIZE;
|
||||
count -= SHA_BLOCKSIZE;
|
||||
sha_transform (sha_info);
|
||||
}
|
||||
memcpy (sha_info->data, buffer, count);
|
||||
sha_info->local = count;
|
||||
}
|
||||
|
||||
/* finish computing the SHA digest */
|
||||
|
||||
void
|
||||
sha_final (unsigned char digest[20], SHA_INFO * sha_info)
|
||||
{
|
||||
int count;
|
||||
SHA_LONG lo_bit_count, hi_bit_count;
|
||||
|
||||
lo_bit_count = sha_info->count_lo;
|
||||
hi_bit_count = sha_info->count_hi;
|
||||
count = (int) ((lo_bit_count >> 3) & 0x3f);
|
||||
((SHA_BYTE *) sha_info->data)[count++] = 0x80;
|
||||
if (count > SHA_BLOCKSIZE - 8) {
|
||||
memset (((SHA_BYTE *) sha_info->data) + count, 0, SHA_BLOCKSIZE - count);
|
||||
sha_transform (sha_info);
|
||||
memset ((SHA_BYTE *) sha_info->data, 0, SHA_BLOCKSIZE - 8);
|
||||
} else {
|
||||
memset (((SHA_BYTE *) sha_info->data) + count, 0,
|
||||
SHA_BLOCKSIZE - 8 - count);
|
||||
}
|
||||
sha_info->data[56] = (unsigned char) ((hi_bit_count >> 24) & 0xff);
|
||||
sha_info->data[57] = (unsigned char) ((hi_bit_count >> 16) & 0xff);
|
||||
sha_info->data[58] = (unsigned char) ((hi_bit_count >> 8) & 0xff);
|
||||
sha_info->data[59] = (unsigned char) ((hi_bit_count >> 0) & 0xff);
|
||||
sha_info->data[60] = (unsigned char) ((lo_bit_count >> 24) & 0xff);
|
||||
sha_info->data[61] = (unsigned char) ((lo_bit_count >> 16) & 0xff);
|
||||
sha_info->data[62] = (unsigned char) ((lo_bit_count >> 8) & 0xff);
|
||||
sha_info->data[63] = (unsigned char) ((lo_bit_count >> 0) & 0xff);
|
||||
sha_transform (sha_info);
|
||||
digest[0] = (unsigned char) ((sha_info->digest[0] >> 24) & 0xff);
|
||||
digest[1] = (unsigned char) ((sha_info->digest[0] >> 16) & 0xff);
|
||||
digest[2] = (unsigned char) ((sha_info->digest[0] >> 8) & 0xff);
|
||||
digest[3] = (unsigned char) ((sha_info->digest[0]) & 0xff);
|
||||
digest[4] = (unsigned char) ((sha_info->digest[1] >> 24) & 0xff);
|
||||
digest[5] = (unsigned char) ((sha_info->digest[1] >> 16) & 0xff);
|
||||
digest[6] = (unsigned char) ((sha_info->digest[1] >> 8) & 0xff);
|
||||
digest[7] = (unsigned char) ((sha_info->digest[1]) & 0xff);
|
||||
digest[8] = (unsigned char) ((sha_info->digest[2] >> 24) & 0xff);
|
||||
digest[9] = (unsigned char) ((sha_info->digest[2] >> 16) & 0xff);
|
||||
digest[10] = (unsigned char) ((sha_info->digest[2] >> 8) & 0xff);
|
||||
digest[11] = (unsigned char) ((sha_info->digest[2]) & 0xff);
|
||||
digest[12] = (unsigned char) ((sha_info->digest[3] >> 24) & 0xff);
|
||||
digest[13] = (unsigned char) ((sha_info->digest[3] >> 16) & 0xff);
|
||||
digest[14] = (unsigned char) ((sha_info->digest[3] >> 8) & 0xff);
|
||||
digest[15] = (unsigned char) ((sha_info->digest[3]) & 0xff);
|
||||
digest[16] = (unsigned char) ((sha_info->digest[4] >> 24) & 0xff);
|
||||
digest[17] = (unsigned char) ((sha_info->digest[4] >> 16) & 0xff);
|
||||
digest[18] = (unsigned char) ((sha_info->digest[4] >> 8) & 0xff);
|
||||
digest[19] = (unsigned char) ((sha_info->digest[4]) & 0xff);
|
||||
}
|
62
gst-libs/gst/cdda/sha1.h
Normal file
62
gst-libs/gst/cdda/sha1.h
Normal file
|
@ -0,0 +1,62 @@
|
|||
/* NIST Secure Hash Algorithm */
|
||||
/* heavily modified by Uwe Hollerbach <uh@alumni.caltech edu> */
|
||||
/* from Peter C. Gutmann's implementation as found in */
|
||||
/* Applied Cryptography by Bruce Schneier */
|
||||
/* This code is in the public domain */
|
||||
/* $Id$ */
|
||||
|
||||
#ifndef __GST_CDDA_SHA_H__
|
||||
#define __GST_CDDA_SHA_H__
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <stdio.h>
|
||||
|
||||
/* Useful defines & typedefs */
|
||||
typedef unsigned char SHA_BYTE; /* 8-bit quantity */
|
||||
typedef unsigned long SHA_LONG; /* 32-or-more-bit quantity */
|
||||
|
||||
#define SHA_BLOCKSIZE 64
|
||||
#define SHA_DIGESTSIZE 20
|
||||
|
||||
typedef struct {
|
||||
SHA_LONG digest[5]; /* message digest */
|
||||
SHA_LONG count_lo, count_hi; /* 64-bit bit count */
|
||||
SHA_BYTE data[SHA_BLOCKSIZE]; /* SHA data buffer */
|
||||
int local; /* unprocessed amount in data */
|
||||
} SHA_INFO;
|
||||
|
||||
#define sha_init _gst_cdda_sha_init
|
||||
#define sha_update _gst_cdda_sha_update
|
||||
#define sha_final _gst_cdda_sha_final
|
||||
|
||||
void sha_init(SHA_INFO *);
|
||||
void sha_update(SHA_INFO *, SHA_BYTE *, int);
|
||||
void sha_final(unsigned char [20], SHA_INFO *);
|
||||
|
||||
#define SHA_VERSION 1
|
||||
|
||||
#ifdef HAVE_CONFIG_H
|
||||
#include "config.h"
|
||||
|
||||
|
||||
#ifdef WORDS_BIGENDIAN
|
||||
# if SIZEOF_LONG == 4
|
||||
# define SHA_BYTE_ORDER 4321
|
||||
# elif SIZEOF_LONG == 8
|
||||
# define SHA_BYTE_ORDER 87654321
|
||||
# endif
|
||||
#else
|
||||
# if SIZEOF_LONG == 4
|
||||
# define SHA_BYTE_ORDER 1234
|
||||
# elif SIZEOF_LONG == 8
|
||||
# define SHA_BYTE_ORDER 12345678
|
||||
# endif
|
||||
#endif
|
||||
|
||||
#else
|
||||
|
||||
#define SHA_BYTE_ORDER 1234
|
||||
|
||||
#endif
|
||||
|
||||
#endif /* __GST_CDDA_SHA_H__ */
|
Loading…
Reference in a new issue