aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec/vc1.c
diff options
context:
space:
mode:
authorKostya Shishkov <kostya.shishkov@gmail.com>2010-09-26 13:56:50 +0000
committerKostya Shishkov <kostya.shishkov@gmail.com>2010-09-26 13:56:50 +0000
commitcba322d76d4a00b659d7de030018d6003820c715 (patch)
treef72c85848ffa978d6f59fe419dd08c4f2f1a3d1e /libavcodec/vc1.c
parent10f93363b77b0fdd42acf5626ed896703908c9d3 (diff)
downloadffmpeg-cba322d76d4a00b659d7de030018d6003820c715.tar.gz
Make WMV3 decoder attempt to decode WMVP as well
Originally committed as revision 25209 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/vc1.c')
-rw-r--r--libavcodec/vc1.c22
1 files changed, 19 insertions, 3 deletions
diff --git a/libavcodec/vc1.c b/libavcodec/vc1.c
index d9d7d515ae..86904cbffd 100644
--- a/libavcodec/vc1.c
+++ b/libavcodec/vc1.c
@@ -315,8 +315,7 @@ int vc1_decode_sequence_header(AVCodecContext *avctx, VC1Context *v, GetBitConte
return -1;
}
if (v->res_sprite) {
- av_log(avctx, AV_LOG_ERROR, "WMVP is not supported\n");
- return -1;
+ av_log(avctx, AV_LOG_ERROR, "WMVP is not fully supported\n");
}
}
@@ -387,7 +386,21 @@ int vc1_decode_sequence_header(AVCodecContext *avctx, VC1Context *v, GetBitConte
v->quantizer_mode = get_bits(gb, 2); //common
v->finterpflag = get_bits1(gb); //common
- v->res_rtm_flag = get_bits1(gb); //reserved
+
+ if (v->res_sprite) {
+ v->s.avctx->width = v->s.avctx->coded_width = get_bits(gb, 11);
+ v->s.avctx->height = v->s.avctx->coded_height = get_bits(gb, 11);
+ skip_bits(gb, 5); //frame rate
+ v->res_x8 = get_bits1(gb);
+ if (get_bits1(gb)) { // something to do with DC VLC selection
+ av_log(avctx, AV_LOG_ERROR, "Unsupported sprite feature\n");
+ return -1;
+ }
+ skip_bits(gb, 3); //slice code
+ v->res_rtm_flag = 0;
+ } else {
+ v->res_rtm_flag = get_bits1(gb); //reserved
+ }
if (!v->res_rtm_flag)
{
// av_log(avctx, AV_LOG_ERROR,
@@ -566,6 +579,9 @@ int vc1_parse_frame_header(VC1Context *v, GetBitContext* gb)
{
int pqindex, lowquant, status;
+ if(v->res_sprite) {
+ skip_bits(gb, 2); //not yet deciphered
+ }
if(v->finterpflag) v->interpfrm = get_bits1(gb);
skip_bits(gb, 2); //framecnt unused
v->rangeredfrm = 0;