summaryrefslogtreecommitdiff
path: root/libavcodec/aasc.c
diff options
context:
space:
mode:
authorPiotr Bandurski <ami_stuff@o2.pl>2012-05-16 11:51:26 +0200
committerMichael Niedermayer <michaelni@gmx.at>2012-05-16 22:15:59 +0200
commit4d3787763218de4c3e838b31f0fb2153b8d6af20 (patch)
tree3fc275327556edb1c0ef3f5e211718125cedbd51 /libavcodec/aasc.c
parente556121ec15698cb57e59ae76d00a467b7716916 (diff)
aasc: support "Autodesk 24 bit RLE compressor" (FourCC: aas4)
fixes ticket #1310 Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavcodec/aasc.c')
-rw-r--r--libavcodec/aasc.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/libavcodec/aasc.c b/libavcodec/aasc.c
index a136360572..1e4264296d 100644
--- a/libavcodec/aasc.c
+++ b/libavcodec/aasc.c
@@ -68,6 +68,12 @@ static int aasc_decode_frame(AVCodecContext *avctx,
compr = AV_RL32(buf);
buf += 4;
buf_size -= 4;
+ switch (avctx->codec_tag) {
+ case MKTAG('A', 'A', 'S', '4'):
+ bytestream2_init(&s->gb, buf - 4, buf_size + 4);
+ ff_msrle_decode(avctx, (AVPicture*)&s->frame, 8, &s->gb);
+ break;
+ case MKTAG('A', 'A', 'S', 'C'):
switch(compr){
case 0:
stride = (avctx->width * 3 + 3) & ~3;
@@ -89,6 +95,11 @@ static int aasc_decode_frame(AVCodecContext *avctx,
av_log(avctx, AV_LOG_ERROR, "Unknown compression type %d\n", compr);
return -1;
}
+ break;
+ default:
+ av_log(avctx, AV_LOG_ERROR, "Unknown FourCC: %X\n", avctx->codec_tag);
+ return -1;
+ }
*data_size = sizeof(AVFrame);
*(AVFrame*)data = s->frame;