Commit accf699f authored by kostya's avatar kostya

AASC can contain raw data in addition to MS-RLE

git-svn-id: file:///var/local/repositories/ffmpeg/trunk@16011 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent e18f0cfb
...@@ -62,6 +62,7 @@ static int aasc_decode_frame(AVCodecContext *avctx, ...@@ -62,6 +62,7 @@ static int aasc_decode_frame(AVCodecContext *avctx,
const uint8_t *buf, int buf_size) const uint8_t *buf, int buf_size)
{ {
AascContext *s = avctx->priv_data; AascContext *s = avctx->priv_data;
int compr, i, stride;
s->frame.reference = 1; s->frame.reference = 1;
s->frame.buffer_hints = FF_BUFFER_HINTS_VALID | FF_BUFFER_HINTS_PRESERVE | FF_BUFFER_HINTS_REUSABLE; s->frame.buffer_hints = FF_BUFFER_HINTS_VALID | FF_BUFFER_HINTS_PRESERVE | FF_BUFFER_HINTS_REUSABLE;
...@@ -70,7 +71,24 @@ static int aasc_decode_frame(AVCodecContext *avctx, ...@@ -70,7 +71,24 @@ static int aasc_decode_frame(AVCodecContext *avctx,
return -1; return -1;
} }
ff_msrle_decode(avctx, &s->frame, 8, buf, buf_size); compr = AV_RL32(buf);
buf += 4;
buf_size -= 4;
switch(compr){
case 0:
stride = (avctx->width * 3 + 3) & ~3;
for(i = avctx->height - 1; i >= 0; i--){
memcpy(s->frame.data[0] + i*s->frame.linesize[0], buf, avctx->width*3);
buf += stride;
}
break;
case 1:
ff_msrle_decode(avctx, &s->frame, 8, buf - 4, buf_size + 4);
break;
default:
av_log(avctx, AV_LOG_ERROR, "Unknown compression type %d\n", compr);
return -1;
}
*data_size = sizeof(AVFrame); *data_size = sizeof(AVFrame);
*(AVFrame*)data = s->frame; *(AVFrame*)data = s->frame;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment