summaryrefslogtreecommitdiff
path: root/libavcodec/rv10.c
diff options
context:
space:
mode:
authorKostya Shishkov <kostya.shishkov@gmail.com>2007-10-21 17:22:37 +0000
committerKostya Shishkov <kostya.shishkov@gmail.com>2007-10-21 17:22:37 +0000
commitdd55d4a315fc7beee0575a340cde08305d5a1d80 (patch)
tree353660aa4c3dbef02c0d4d2625bacbbdd4c1408d /libavcodec/rv10.c
parentb96b441ad2b4f314f2549b40f3df3894df738a77 (diff)
downloadffmpeg-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.c27
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);