Mercurial > libavcodec.hg
diff vp6.c @ 11350:7d9a1a807e91 libavcodec
move vp6 huffman table freeing code, out of common vp56 code
author | aurel |
---|---|
date | Wed, 03 Mar 2010 22:29:06 +0000 |
parents | 8d23ea397dda |
children | 8a4984c5cacc |
line wrap: on
line diff
--- a/vp6.c Wed Mar 03 21:10:08 2010 +0000 +++ b/vp6.c Wed Mar 03 22:29:06 2010 +0000 @@ -602,6 +602,23 @@ return 0; } +static av_cold int vp6_decode_free(AVCodecContext *avctx) +{ + VP56Context *s = avctx->priv_data; + int pt, ct, cg; + + vp56_free(avctx); + + for (pt=0; pt<2; pt++) { + free_vlc(&s->dccv_vlc[pt]); + free_vlc(&s->runv_vlc[pt]); + for (ct=0; ct<3; ct++) + for (cg=0; cg<6; cg++) + free_vlc(&s->ract_vlc[pt][ct][cg]); + } + return 0; +} + AVCodec vp6_decoder = { "vp6", CODEC_TYPE_VIDEO, @@ -609,7 +626,7 @@ sizeof(VP56Context), vp6_decode_init, NULL, - vp56_free, + vp6_decode_free, vp56_decode_frame, CODEC_CAP_DR1, .long_name = NULL_IF_CONFIG_SMALL("On2 VP6"), @@ -623,7 +640,7 @@ sizeof(VP56Context), vp6_decode_init, NULL, - vp56_free, + vp6_decode_free, vp56_decode_frame, CODEC_CAP_DR1, .long_name = NULL_IF_CONFIG_SMALL("On2 VP6 (Flash version)"), @@ -637,7 +654,7 @@ sizeof(VP56Context), vp6_decode_init, NULL, - vp56_free, + vp6_decode_free, vp56_decode_frame, CODEC_CAP_DR1, .long_name = NULL_IF_CONFIG_SMALL("On2 VP6 (Flash version, with alpha channel)"),