mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-12 10:25:33 +00:00
gst-libs/gst/riff/: Fix for unaligned RIFF files (i.e. where all the chunks together in a LIST chunk are not of the s...
Original commit message from CVS: * gst-libs/gst/riff/riff-media.c: (gst_riff_create_video_caps_with_data), (gst_riff_create_audio_caps), (gst_riff_create_audio_template_caps): * gst-libs/gst/riff/riff-read.c: (gst_riff_peek_head): Fix for unaligned RIFF files (i.e. where all the chunks together in a LIST chunk are not of the same size as the size given in the LIST chunk header). Fixes several odd WAVE files. Also fix ADPCM (block_align property) in audio, so that wavparse based on this works now as it used to stand-alone.
This commit is contained in:
parent
5dc93f5e7b
commit
7180b58bb3
3 changed files with 46 additions and 0 deletions
13
ChangeLog
13
ChangeLog
|
@ -1,3 +1,16 @@
|
|||
2004-05-09 Ronald Bultje <rbultje@ronald.bitfreak.net>
|
||||
|
||||
* gst-libs/gst/riff/riff-media.c:
|
||||
(gst_riff_create_video_caps_with_data),
|
||||
(gst_riff_create_audio_caps),
|
||||
(gst_riff_create_audio_template_caps):
|
||||
* gst-libs/gst/riff/riff-read.c: (gst_riff_peek_head):
|
||||
Fix for unaligned RIFF files (i.e. where all the chunks together
|
||||
in a LIST chunk are not of the same size as the size given in
|
||||
the LIST chunk header). Fixes several odd WAVE files. Also fix
|
||||
ADPCM (block_align property) in audio, so that wavparse based
|
||||
on this works now as it used to stand-alone.
|
||||
|
||||
2004-05-09 Edward Hervey <bilboed@bilboed.com>
|
||||
|
||||
reviewed by Benjamin Otte <otte@gnome.org>
|
||||
|
|
|
@ -323,6 +323,7 @@ GstCaps *
|
|||
gst_riff_create_audio_caps (guint16 codec_id,
|
||||
gst_riff_strh * strh, gst_riff_strf_auds * strf, char **codec_name)
|
||||
{
|
||||
gboolean block_align = FALSE;
|
||||
GstCaps *caps = NULL;
|
||||
|
||||
switch (codec_id) {
|
||||
|
@ -365,6 +366,15 @@ gst_riff_create_audio_caps (guint16 codec_id,
|
|||
"layout", G_TYPE_STRING, "microsoft", NULL);
|
||||
if (codec_name)
|
||||
*codec_name = g_strdup ("ADPCM audio");
|
||||
block_align = TRUE;
|
||||
break;
|
||||
|
||||
case GST_RIFF_WAVE_FORMAT_DVI_ADPCM:
|
||||
caps = gst_caps_new_simple ("audio/x-adpcm",
|
||||
"layout", G_TYPE_STRING, "dvi", NULL);
|
||||
if (codec_name)
|
||||
*codec_name = g_strdup ("DVI ADPCM audio");
|
||||
block_align = TRUE;
|
||||
break;
|
||||
|
||||
case GST_RIFF_WAVE_FORMAT_MULAW:
|
||||
|
@ -413,10 +423,16 @@ gst_riff_create_audio_caps (guint16 codec_id,
|
|||
gst_caps_set_simple (caps,
|
||||
"rate", G_TYPE_INT, strf->rate,
|
||||
"channels", G_TYPE_INT, strf->channels, NULL);
|
||||
if (block_align)
|
||||
gst_caps_set_simple (caps,
|
||||
"block_align", G_TYPE_INT, strf->blockalign, NULL);
|
||||
} else {
|
||||
gst_caps_set_simple (caps,
|
||||
"rate", GST_TYPE_INT_RANGE, 8000, 96000,
|
||||
"channels", GST_TYPE_INT_RANGE, 1, 2, NULL);
|
||||
if (block_align)
|
||||
gst_caps_set_simple (caps,
|
||||
"block_align", GST_TYPE_INT_RANGE, 1, 8192, NULL);
|
||||
}
|
||||
|
||||
return caps;
|
||||
|
@ -501,6 +517,7 @@ gst_riff_create_audio_template_caps (void)
|
|||
GST_RIFF_WAVE_FORMAT_ALAW,
|
||||
GST_RIFF_WAVE_FORMAT_MULAW,
|
||||
GST_RIFF_WAVE_FORMAT_ADPCM,
|
||||
GST_RIFF_WAVE_FORMAT_DVI_ADPCM,
|
||||
/* FILL ME */
|
||||
0
|
||||
};
|
||||
|
|
|
@ -154,8 +154,24 @@ gboolean
|
|||
gst_riff_peek_head (GstRiffRead * riff,
|
||||
guint32 * tag, guint32 * length, guint * level_up)
|
||||
{
|
||||
GList *last;
|
||||
guint8 *data;
|
||||
|
||||
/* if we're at the end of a chunk, but unaligned, then re-align.
|
||||
* Those are essentially broken files, but unfortunately they
|
||||
* exist. */
|
||||
if ((last = g_list_last (riff->level)) != NULL) {
|
||||
GstRiffLevel *level = last->data;
|
||||
guint64 pos = gst_bytestream_tell (riff->bs);
|
||||
|
||||
if (level->start + level->length - pos < 8) {
|
||||
if (!gst_bytestream_flush (riff->bs, level->start + level->length - pos)) {
|
||||
GST_ELEMENT_ERROR (riff, RESOURCE, READ, (NULL), (NULL));
|
||||
return FALSE;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/* read */
|
||||
while (gst_bytestream_peek_bytes (riff->bs, &data, 8) != 8) {
|
||||
GstEvent *event = NULL;
|
||||
|
|
Loading…
Reference in a new issue