diff options
author | Kostya Shishkov <kostya.shishkov@gmail.com> | 2007-10-21 17:22:37 +0000 |
---|---|---|
committer | Kostya Shishkov <kostya.shishkov@gmail.com> | 2007-10-21 17:22:37 +0000 |
commit | dd55d4a315fc7beee0575a340cde08305d5a1d80 (patch) | |
tree | 353660aa4c3dbef02c0d4d2625bacbbdd4c1408d /libavcodec/rv10.c | |
parent | b96b441ad2b4f314f2549b40f3df3894df738a77 (diff) | |
download | ffmpeg-dd55d4a315fc7beee0575a340cde08305d5a1d80.tar.gz |
Make RV10/20 decoder work with new frame format
Originally committed as revision 10825 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/rv10.c')
-rw-r--r-- | libavcodec/rv10.c | 27 |
1 files changed, 19 insertions, 8 deletions
diff --git a/libavcodec/rv10.c b/libavcodec/rv10.c index 33939bd849..5b1c4ec0dc 100644 --- a/libavcodec/rv10.c +++ b/libavcodec/rv10.c @@ -711,6 +711,12 @@ static int rv10_decode_packet(AVCodecContext *avctx, return buf_size; } +static int get_slice_offset(AVCodecContext *avctx, uint8_t *buf, int n) +{ + if(avctx->slice_count) return avctx->slice_offset[n]; + else return AV_RL32(buf + n*8); +} + static int rv10_decode_frame(AVCodecContext *avctx, void *data, int *data_size, uint8_t *buf, int buf_size) @@ -718,6 +724,8 @@ static int rv10_decode_frame(AVCodecContext *avctx, MpegEncContext *s = avctx->priv_data; int i; AVFrame *pict = data; + int slice_count; + uint8_t *slices_hdr = NULL; #ifdef DEBUG av_log(avctx, AV_LOG_DEBUG, "*****frame %d size=%d\n", avctx->frame_number, buf_size); @@ -728,21 +736,24 @@ static int rv10_decode_frame(AVCodecContext *avctx, return 0; } - if(avctx->slice_count){ - for(i=0; i<avctx->slice_count; i++){ - int offset= avctx->slice_offset[i]; + if(!avctx->slice_count){ + slice_count = (*buf++) + 1; + slices_hdr = buf + 4; + buf += 8 * slice_count; + }else + slice_count = avctx->slice_count; + + for(i=0; i<slice_count; i++){ + int offset= get_slice_offset(avctx, slices_hdr, i); int size; - if(i+1 == avctx->slice_count) + if(i+1 == slice_count) size= buf_size - offset; else - size= avctx->slice_offset[i+1] - offset; + size= get_slice_offset(avctx, slices_hdr, i+1) - offset; rv10_decode_packet(avctx, buf+offset, size); } - }else{ - rv10_decode_packet(avctx, buf, buf_size); - } if(s->current_picture_ptr != NULL && s->mb_y>=s->mb_height){ ff_er_frame_end(s); |