mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-23 12:43:46 +02:00
rv34: use AVERROR return values in ff_rv34_decode_frame()
Also adds an error message.
This commit is contained in:
parent
bf61ef2316
commit
29330721b0
@ -1652,15 +1652,19 @@ int ff_rv34_decode_frame(AVCodecContext *avctx,
|
|||||||
if(get_slice_offset(avctx, slices_hdr, 0) < 0 ||
|
if(get_slice_offset(avctx, slices_hdr, 0) < 0 ||
|
||||||
get_slice_offset(avctx, slices_hdr, 0) > buf_size){
|
get_slice_offset(avctx, slices_hdr, 0) > buf_size){
|
||||||
av_log(avctx, AV_LOG_ERROR, "Slice offset is invalid\n");
|
av_log(avctx, AV_LOG_ERROR, "Slice offset is invalid\n");
|
||||||
return -1;
|
return AVERROR_INVALIDDATA;
|
||||||
}
|
}
|
||||||
init_get_bits(&s->gb, buf+get_slice_offset(avctx, slices_hdr, 0), (buf_size-get_slice_offset(avctx, slices_hdr, 0))*8);
|
init_get_bits(&s->gb, buf+get_slice_offset(avctx, slices_hdr, 0), (buf_size-get_slice_offset(avctx, slices_hdr, 0))*8);
|
||||||
if(r->parse_slice_header(r, &r->s.gb, &si) < 0 || si.start){
|
if(r->parse_slice_header(r, &r->s.gb, &si) < 0 || si.start){
|
||||||
av_log(avctx, AV_LOG_ERROR, "First slice header is incorrect\n");
|
av_log(avctx, AV_LOG_ERROR, "First slice header is incorrect\n");
|
||||||
return -1;
|
return AVERROR_INVALIDDATA;
|
||||||
|
}
|
||||||
|
if ((!s->last_picture_ptr || !s->last_picture_ptr->f.data[0]) &&
|
||||||
|
si.type == AV_PICTURE_TYPE_B) {
|
||||||
|
av_log(avctx, AV_LOG_ERROR, "Invalid decoder state: B-frame without "
|
||||||
|
"reference data.\n");
|
||||||
|
return AVERROR_INVALIDDATA;
|
||||||
}
|
}
|
||||||
if ((!s->last_picture_ptr || !s->last_picture_ptr->f.data[0]) && si.type == AV_PICTURE_TYPE_B)
|
|
||||||
return -1;
|
|
||||||
if( (avctx->skip_frame >= AVDISCARD_NONREF && si.type==AV_PICTURE_TYPE_B)
|
if( (avctx->skip_frame >= AVDISCARD_NONREF && si.type==AV_PICTURE_TYPE_B)
|
||||||
|| (avctx->skip_frame >= AVDISCARD_NONKEY && si.type!=AV_PICTURE_TYPE_I)
|
|| (avctx->skip_frame >= AVDISCARD_NONKEY && si.type!=AV_PICTURE_TYPE_I)
|
||||||
|| avctx->skip_frame >= AVDISCARD_ALL)
|
|| avctx->skip_frame >= AVDISCARD_ALL)
|
||||||
|
Loading…
Reference in New Issue
Block a user