diff options
author | Kostya Shishkov <kostya.shishkov@gmail.com> | 2009-02-07 10:46:51 +0000 |
---|---|---|
committer | Kostya Shishkov <kostya.shishkov@gmail.com> | 2009-02-07 10:46:51 +0000 |
commit | 432f1f11ea7f95b1c1f1adb546151f09c1d7a932 (patch) | |
tree | 7924428c26d29691d345fc97ca1b197337d37df7 /libavcodec/rv34.c | |
parent | 186f155e1c97c21573b5c707f94a6fd56933aa64 (diff) | |
download | ffmpeg-432f1f11ea7f95b1c1f1adb546151f09c1d7a932.tar.gz |
Move RV3/4 frame type check up so 1-slice unanchored B-frames are checked, too.
Originally committed as revision 17031 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/rv34.c')
-rw-r--r-- | libavcodec/rv34.c | 15 |
1 files changed, 13 insertions, 2 deletions
diff --git a/libavcodec/rv34.c b/libavcodec/rv34.c index 1f35b24a55..ae57973a3a 100644 --- a/libavcodec/rv34.c +++ b/libavcodec/rv34.c @@ -1396,6 +1396,19 @@ int ff_rv34_decode_frame(AVCodecContext *avctx, }else slice_count = avctx->slice_count; + //parse first slice header to check whether this frame can be decoded + if(get_slice_offset(avctx, slices_hdr, 0) > buf_size){ + av_log(avctx, AV_LOG_ERROR, "Slice offset is greater than frame size\n"); + return -1; + } + init_get_bits(&s->gb, buf+get_slice_offset(avctx, slices_hdr, 0), buf_size-get_slice_offset(avctx, slices_hdr, 0)); + if(r->parse_slice_header(r, &r->s.gb, &si) < 0){ + av_log(avctx, AV_LOG_ERROR, "First slice header is incorrect\n"); + return -1; + } + if((!s->last_picture_ptr || !s->last_picture_ptr->data[0]) && si.type == FF_B_TYPE) + return -1; + for(i=0; i<slice_count; i++){ int offset= get_slice_offset(avctx, slices_hdr, i); int size; @@ -1420,8 +1433,6 @@ int ff_rv34_decode_frame(AVCodecContext *avctx, }else r->si.end = si.start; } - if(!i && si.type == FF_B_TYPE && (!s->last_picture_ptr || !s->last_picture_ptr->data[0])) - return -1; last = rv34_decode_slice(r, r->si.end, buf + offset, size); s->mb_num_left = r->s.mb_x + r->s.mb_y*r->s.mb_width - r->si.start; if(last) |