mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-12-22 00:06:36 +00:00
ext/ffmpeg/gstffmpegcodecmap.c: Improve debugging of codec data. realvideo caps are underspecified, use fields of alt...
Original commit message from CVS: * ext/ffmpeg/gstffmpegcodecmap.c: (gst_ffmpeg_caps_with_codecid): Improve debugging of codec data. realvideo caps are underspecified, use fields of alternative variant before we settle this. * ext/ffmpeg/gstffmpegdec.c: (gst_ffmpegdec_open), (gst_ffmpegdec_video_frame): Add more debugging of used parsers. Setup the realvideo slices correctly before calling the decoder, fixed realvideo in matroska.
This commit is contained in:
parent
907d7e40f5
commit
144b42608b
3 changed files with 49 additions and 2 deletions
13
ChangeLog
13
ChangeLog
|
@ -1,3 +1,16 @@
|
||||||
|
2007-08-07 Wim Taymans <wim.taymans@gmail.com>
|
||||||
|
|
||||||
|
* ext/ffmpeg/gstffmpegcodecmap.c: (gst_ffmpeg_caps_with_codecid):
|
||||||
|
Improve debugging of codec data.
|
||||||
|
realvideo caps are underspecified, use fields of alternative variant
|
||||||
|
before we settle this.
|
||||||
|
|
||||||
|
* ext/ffmpeg/gstffmpegdec.c: (gst_ffmpegdec_open),
|
||||||
|
(gst_ffmpegdec_video_frame):
|
||||||
|
Add more debugging of used parsers.
|
||||||
|
Setup the realvideo slices correctly before calling the decoder, fixed
|
||||||
|
realvideo in matroska.
|
||||||
|
|
||||||
2007-08-01 Stefan Kost <ensonic@users.sf.net>
|
2007-08-01 Stefan Kost <ensonic@users.sf.net>
|
||||||
|
|
||||||
* ext/ffmpeg/gstffmpegcfg.c: (gst_ffmpeg_cfg_install_property),
|
* ext/ffmpeg/gstffmpegcfg.c: (gst_ffmpeg_cfg_install_property),
|
||||||
|
|
|
@ -1523,12 +1523,14 @@ gst_ffmpeg_caps_with_codecid (enum CodecID codec_id,
|
||||||
av_mallocz (GST_ROUND_UP_16 (size + FF_INPUT_BUFFER_PADDING_SIZE));
|
av_mallocz (GST_ROUND_UP_16 (size + FF_INPUT_BUFFER_PADDING_SIZE));
|
||||||
memcpy (context->extradata, GST_BUFFER_DATA (buf), size);
|
memcpy (context->extradata, GST_BUFFER_DATA (buf), size);
|
||||||
context->extradata_size = size;
|
context->extradata_size = size;
|
||||||
|
GST_DEBUG ("have codec data of size %d", size);
|
||||||
} else if (context->extradata == NULL) {
|
} else if (context->extradata == NULL) {
|
||||||
/* no extradata, alloc dummy with 0 sized, some codecs insist on reading
|
/* no extradata, alloc dummy with 0 sized, some codecs insist on reading
|
||||||
* extradata anyway which makes then segfault. */
|
* extradata anyway which makes then segfault. */
|
||||||
context->extradata =
|
context->extradata =
|
||||||
av_mallocz (GST_ROUND_UP_16 (FF_INPUT_BUFFER_PADDING_SIZE));
|
av_mallocz (GST_ROUND_UP_16 (FF_INPUT_BUFFER_PADDING_SIZE));
|
||||||
context->extradata_size = 0;
|
context->extradata_size = 0;
|
||||||
|
GST_DEBUG ("no codec data");
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (codec_id) {
|
switch (codec_id) {
|
||||||
|
@ -1600,11 +1602,15 @@ gst_ffmpeg_caps_with_codecid (enum CodecID codec_id,
|
||||||
case CODEC_ID_RV40:
|
case CODEC_ID_RV40:
|
||||||
{
|
{
|
||||||
guint32 fourcc;
|
guint32 fourcc;
|
||||||
|
gint format;
|
||||||
|
|
||||||
if (gst_structure_get_fourcc (str, "rmsubid", &fourcc))
|
if (gst_structure_get_fourcc (str, "rmsubid", &fourcc))
|
||||||
context->sub_id = fourcc;
|
context->sub_id = fourcc;
|
||||||
}
|
if (gst_structure_get_int (str, "format", &format))
|
||||||
|
context->sub_id = format;
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
case CODEC_ID_COOK:
|
case CODEC_ID_COOK:
|
||||||
case CODEC_ID_RA_288:
|
case CODEC_ID_RA_288:
|
||||||
case CODEC_ID_RA_144:
|
case CODEC_ID_RA_144:
|
||||||
|
|
|
@ -93,6 +93,8 @@ struct _GstFFMpegDec
|
||||||
gboolean outoforder;
|
gboolean outoforder;
|
||||||
GstClockTime tstamp1, tstamp2;
|
GstClockTime tstamp1, tstamp2;
|
||||||
GstClockTime dur1, dur2;
|
GstClockTime dur1, dur2;
|
||||||
|
|
||||||
|
gboolean is_realvideo;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct _GstFFMpegDecClass GstFFMpegDecClass;
|
typedef struct _GstFFMpegDecClass GstFFMpegDecClass;
|
||||||
|
@ -485,6 +487,7 @@ gst_ffmpegdec_open (GstFFMpegDec * ffmpegdec)
|
||||||
goto could_not_open;
|
goto could_not_open;
|
||||||
|
|
||||||
ffmpegdec->opened = TRUE;
|
ffmpegdec->opened = TRUE;
|
||||||
|
ffmpegdec->is_realvideo = FALSE;
|
||||||
|
|
||||||
GST_LOG_OBJECT (ffmpegdec, "Opened ffmpeg codec %s, id %d",
|
GST_LOG_OBJECT (ffmpegdec, "Opened ffmpeg codec %s, id %d",
|
||||||
oclass->in_plugin->name, oclass->in_plugin->id);
|
oclass->in_plugin->name, oclass->in_plugin->id);
|
||||||
|
@ -509,9 +512,16 @@ gst_ffmpegdec_open (GstFFMpegDec * ffmpegdec)
|
||||||
ffmpegdec->pctx = NULL;
|
ffmpegdec->pctx = NULL;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case CODEC_ID_RV10:
|
||||||
|
case CODEC_ID_RV20:
|
||||||
|
ffmpegdec->is_realvideo = TRUE;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
GST_LOG_OBJECT (ffmpegdec, "Using parser");
|
|
||||||
ffmpegdec->pctx = av_parser_init (oclass->in_plugin->id);
|
ffmpegdec->pctx = av_parser_init (oclass->in_plugin->id);
|
||||||
|
if (ffmpegdec->pctx)
|
||||||
|
GST_LOG_OBJECT (ffmpegdec, "Using parser %p", ffmpegdec->pctx);
|
||||||
|
else
|
||||||
|
GST_LOG_OBJECT (ffmpegdec, "No parser for codec");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1315,6 +1325,24 @@ gst_ffmpegdec_video_frame (GstFFMpegDec * ffmpegdec,
|
||||||
/* in case we skip frames */
|
/* in case we skip frames */
|
||||||
ffmpegdec->picture->pict_type = -1;
|
ffmpegdec->picture->pict_type = -1;
|
||||||
|
|
||||||
|
if (ffmpegdec->is_realvideo && data != NULL) {
|
||||||
|
gint slice_count;
|
||||||
|
gint i;
|
||||||
|
|
||||||
|
/* setup the slice table for realvideo */
|
||||||
|
if (ffmpegdec->context->slice_offset == NULL)
|
||||||
|
ffmpegdec->context->slice_offset = g_malloc (sizeof (guint32) * 1000);
|
||||||
|
|
||||||
|
slice_count = (*data++) + 1;
|
||||||
|
ffmpegdec->context->slice_count = slice_count;
|
||||||
|
|
||||||
|
for (i = 0; i < slice_count; i++) {
|
||||||
|
data += 4;
|
||||||
|
ffmpegdec->context->slice_offset[i] = GST_READ_UINT32_LE (data);
|
||||||
|
data += 4;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* now decode the frame */
|
/* now decode the frame */
|
||||||
len = avcodec_decode_video (ffmpegdec->context,
|
len = avcodec_decode_video (ffmpegdec->context,
|
||||||
ffmpegdec->picture, &have_data, data, size);
|
ffmpegdec->picture, &have_data, data, size);
|
||||||
|
|
Loading…
Reference in a new issue